Claude Code security

API Keys and Secrets Hardcoded in Source Code

Claude Code generated code with API keys, database passwords, or other secrets hardcoded directly in source files. These credentials are now committed to your Git repository and visible to anyone with access to the code.

This is one of the most common security mistakes in AI-assisted development. The AI often places real credentials inline to make the code immediately functional, without considering that the code will be version-controlled and potentially shared.

You may discover this when GitHub sends a secret scanning alert, when a third-party service notifies you of leaked credentials, or when you notice unexpected charges on your cloud account.

Error Messages You Might See

GitHub Secret Scanning: API key detected in commit Warning: Possible credential leak found Authentication failed: API key has been revoked Billing alert: Unauthorized usage detected on your account
GitHub Secret Scanning: API key detected in commitWarning: Possible credential leak foundAuthentication failed: API key has been revokedBilling alert: Unauthorized usage detected on your account

Common Causes

  • Credentials pasted into prompts — You shared API keys in your prompt and Claude Code embedded them directly in the generated files
  • No .env file pattern — The generated project doesn't use environment variables or a .env file for configuration
  • Missing .gitignore — Even if a .env file exists, it's not listed in .gitignore and gets committed
  • Config files with real values — Application config files (config.json, settings.py) contain production credentials as defaults
  • Test files with real keys — Integration tests or seed scripts use actual API keys instead of test/mock credentials

How to Fix It

  1. Search your entire codebase — Use tools like trufflehog, gitleaks, or grep for patterns like 'sk-', 'AKIA', 'ghp_', or 'password=' across all files and Git history
  2. Move all secrets to environment variables — Replace hardcoded values with process.env.KEY_NAME or os.environ['KEY_NAME'] and create a .env.example with placeholder values
  3. Rotate every exposed credential immediately — Generate new keys for every service whose credentials were committed, even if the repo is private
  4. Scrub Git history — Use git filter-branch or BFG Repo Cleaner to remove secrets from past commits
  5. Add pre-commit hooks — Install detect-secrets or gitleaks as a pre-commit hook to prevent future leaks

Real developers can help you.

Jaime Orts-Caroff Jaime Orts-Caroff I'm a Senior Android developer, currently working at Aircall. I'm open to work in various fields! rayush33 rayush33 JavaScript (React.js, React Native, Node.js) Developer with demonstrated industry experience of 4+ years, actively looking for opportunities to hone my skills as well as help small-scale business owners with solutions to technical problems Dor Yaloz Dor Yaloz SW engineer with 6+ years of experience, I worked with React/Node/Python did projects with React+Capacitor.js for ios Supabase expert BurnHavoc BurnHavoc Been around fixing other peoples code for 20 years. MFox MFox Full-stack professional senior engineer (15+years). Extensive experience in software development, qa, and IP networking. Milan Surelia Milan Surelia Milan Surelia is a Mobile App Developer with 5+ years of experience crafting scalable, cross-platform apps at 7Span and Meticha. At 7Span, he engineers feature-rich Flutter apps with smooth performance and modern UI. As the Co-Founder of Meticha, he builds open-source tools and developer-focused products that solve real-world problems. Expertise: 💡 Developing cross-platform apps using Flutter, Dart, and Jetpack Compose for Android, iOS, and Web. 🖋️ Sharing insights through technical writing, blogging, and open-source contributions. 🤝 Collaborating closely with designers, PMs, and developers to build seamless mobile experiences. Notable Achievements: 🎯 Revamped the Vepaar app into Vepaar Store & CRM with a 2x performance boost and smoother UX. 🚀 Launched Compose101 — a Jetpack Compose starter kit to speed up Android development. 🌟 Open source contributions on Github & StackOverflow for Flutter & Dart 🎖️ Worked on improving app performance and user experience with smart solutions. Milan is always happy to connect, work on new ideas, and explore the latest in technology. Victor Denisov Victor Denisov Developer Krishna Sai Kuncha Krishna Sai Kuncha Experienced Professional Full stack Developer with 8+ years of experience across react, python, js, ts, golang and react-native. Developed inhouse websearch tooling for AI before websearch was solved : ) Jared Hasson Jared Hasson Full time lead founding dev at a cyber security saas startup, with 10 yoe and a bachelor's in CS. Building & debugging software products is what I've spent my time on for forever prajwalfullstack prajwalfullstack Hi Im a full stack developer, a vibe coded MVP to Market ready product, I'm here to help

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help

Frequently Asked Questions

Are my API keys compromised if they were in a private repo?

Treat them as compromised. Private repos can be forked, cloned by team members, or exposed through CI logs. Always rotate keys that were ever committed to any repository.

How do I remove secrets from Git history?

Use BFG Repo Cleaner or git filter-repo to rewrite history. After cleaning, force-push and have all collaborators re-clone. The old commits may still exist in forks or cached copies.

Related Claude Code Issues

Can't fix it yourself?
Real developers can help.

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help