- 🚀 批量测试多个 API 密钥
- 🎯 支持 OpenAI、Claude、Gemini 三大平台
- 🔄 智能重试机制,提高检测准确性
- 🌐 中英文界面切换
- 🌙 浅色/深色主题切换
- 📊 实时统计和错误详情显示
- 📋 一键复制有效/无效/速率限制密钥
- 🎛️ 支持输入自定义模型名称
- ⚡ 可调节并发数和重试次数
- 💻 纯前端,无需安装
- 访问:https://weiruchenai1.github.io/api-key-tester
- 选择 API 类型
- 填写代理服务器 URL(必需)
- 粘贴或者导入(.txt) API 密钥列表
- 使用预设模型或输入自定义模型名
- 根据需要选择合适的并发数和重试次数
- 点击开始测试
由于浏览器 CORS 限制,必须使用代理服务器:
公共代理风险提醒:
⚠️ 安全风险:API密钥可能被代理服务器记录- 📉 稳定性差:可能随时失效或速度很慢
- 🚫 使用限制:可能有请求频率或数量限制
强烈建议使用自己的反向代理以获得更好的安全性、稳定性和成功率。
🛠️ 如何搭建自己的反向代理
如果你有自己的海外服务器,可以使用 Nginx 搭建反向代理:
前置要求:
- 一台海外服务器(VPS)
- 一个域名,并将以下子域名解析到服务器IP:
openai.your-domain.com
claude.your-domain.com
gemini.your-domain.com
1. 安装 Nginx
sudo apt-get update
sudo apt-get install nginx
2. 配置域名和SSL证书
# 申请SSL证书(使用 Let's Encrypt)
sudo apt-get install certbot python3-certbot-nginx
sudo certbot --nginx -d your-domain.com
3. 创建反向代理配置
# 为每个API创建单独的配置文件
sudo nano /etc/nginx/sites-available/openai-proxy
4. 添加OpenAI配置内容
# OpenAI 反向代理
server {
listen 443 ssl;
server_name openai.your-domain.com;
ssl_certificate /etc/letsencrypt/live/claude.your-domain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/claude.your-domain.com/privkey.pem;
location / {
# DNS解析器,禁用IPv6
resolver 8.8.8.8 ipv6=off;
# 反向代理配置
proxy_pass https://api.openai.com/;
proxy_ssl_server_name on;
proxy_set_header Host api.openai.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# 隐藏后端服务器的CORS头,避免重复
proxy_hide_header Access-Control-Allow-Origin;
proxy_hide_header Access-Control-Allow-Methods;
proxy_hide_header Access-Control-Allow-Headers;
proxy_hide_header Access-Control-Allow-Credentials;
# 处理OPTIONS预检请求
if ($request_method = 'OPTIONS') {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods 'GET, POST, PUT, DELETE, OPTIONS';
add_header Access-Control-Allow-Headers '*';
add_header Access-Control-Max-Age 86400;
return 204;
}
# 为所有其他请求添加CORS头
add_header Access-Control-Allow-Origin * always;
add_header Access-Control-Allow-Methods 'GET, POST, PUT, DELETE, OPTIONS' always;
add_header Access-Control-Allow-Headers '*' always;
}
}
5. 创建Claude配置
sudo nano /etc/nginx/sites-available/claude-proxy
添加以下内容:
# Claude 反向代理
server {
listen 443 ssl;
server_name claude.your-domain.com;
ssl_certificate /etc/letsencrypt/live/claude.your-domain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/claude.your-domain.com/privkey.pem;
location / {
# DNS解析器,禁用IPv6
resolver 8.8.8.8 ipv6=off;
# 反向代理配置
proxy_pass https://api.anthropic.com/;
proxy_ssl_server_name on;
proxy_set_header Host api.anthropic.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# 隐藏后端服务器的CORS头,避免重复
proxy_hide_header Access-Control-Allow-Origin;
proxy_hide_header Access-Control-Allow-Methods;
proxy_hide_header Access-Control-Allow-Headers;
proxy_hide_header Access-Control-Allow-Credentials;
# 处理OPTIONS预检请求
if ($request_method = 'OPTIONS') {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods 'GET, POST, PUT, DELETE, OPTIONS';
add_header Access-Control-Allow-Headers '*';
add_header Access-Control-Max-Age 86400;
return 204;
}
# 为所有其他请求添加CORS头
add_header Access-Control-Allow-Origin * always;
add_header Access-Control-Allow-Methods 'GET, POST, PUT, DELETE, OPTIONS' always;
add_header Access-Control-Allow-Headers '*' always;
}
}
6. 创建Gemini配置
sudo nano /etc/nginx/sites-available/gemini-proxy
添加以下内容:
# Gemini 反向代理
server {
listen 443 ssl;
server_name gemini.your-domain.com;
ssl_certificate /etc/letsencrypt/live/claude.your-domain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/claude.your-domain.com/privkey.pem;
location / {
# DNS解析器,禁用IPv6
resolver 8.8.8.8 ipv6=off;
# 反向代理配置
proxy_pass https://generativelanguage.googleapis.com/;
proxy_ssl_server_name on;
proxy_set_header Host generativelanguage.googleapis.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# 隐藏后端服务器的CORS头,避免重复
proxy_hide_header Access-Control-Allow-Origin;
proxy_hide_header Access-Control-Allow-Methods;
proxy_hide_header Access-Control-Allow-Headers;
proxy_hide_header Access-Control-Allow-Credentials;
# 处理OPTIONS预检请求
if ($request_method = 'OPTIONS') {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods 'GET, POST, PUT, DELETE, OPTIONS';
add_header Access-Control-Allow-Headers '*';
add_header Access-Control-Max-Age 86400;
return 204;
}
# 为所有其他请求添加CORS头
add_header Access-Control-Allow-Origin * always;
add_header Access-Control-Allow-Methods 'GET, POST, PUT, DELETE, OPTIONS' always;
add_header Access-Control-Allow-Headers '*' always;
}
}
7. 启用配置
# 启用所有代理配置
sudo ln -s /etc/nginx/sites-available/openai-proxy /etc/nginx/sites-enabled/
sudo ln -s /etc/nginx/sites-available/claude-proxy /etc/nginx/sites-enabled/
sudo ln -s /etc/nginx/sites-available/gemini-proxy /etc/nginx/sites-enabled/
配置说明:
- 将
your-domain.com
替换为你的实际域名 - 每个API使用单独的配置文件,便于管理
- 证书路径会在申请SSL证书后自动生成,无需手动修改
8. 重启 Nginx
sudo nginx -t # 检查配置
sudo nginx -s reload # 重新加载配置
代理地址: 测试成功后,在API Key测试工具中使用以下代理地址:
- OpenAI:
https://openai.your-domain.com
- Claude:
https://claude.your-domain.com
- Gemini:
https://gemini.your-domain.com
- Node.js >= 16.0.0
- npm >= 8.0.0
npm install
npm start
应用将在 http://localhost:3000 启动
npm run build
构建产物将生成到 build/
目录
docker run -d \
--name api-key-tester \
-p 8080:80 \
--restart unless-stopped \
ghcr.io/weiruchenai1/api-key-tester:latest
使用提供的 docker-compose.yml 文件:
# 下载配置文件
curl -O https://raw.githubusercontent.com/weiruchenai1/api-key-tester/main/docker-compose.yml
# 启动服务
docker-compose up -d
# 查看日志
docker-compose logs -f
# 停止服务
docker-compose down
自定义配置:
services:
web:
image: ghcr.io/weiruchenai1/api-key-tester:latest
ports:
- "3000:80" # 修改端口
restart: unless-stopped
environment:
- TZ=Asia/Shanghai
- Fork 此仓库到你的 GitHub 账户
- 登录 Cloudflare Dashboard
- 进入
Workers & Pages
>Create application
>Pages
>Connect to Git
- 选择你 Fork 的仓库
- 配置构建设置:
- 构建命令:
npm run build
- 构建输出目录:
build
- Node.js 版本:
18
或20
- 构建命令:
- 点击
Save and Deploy
一键部署:
适用于任何支持静态文件的服务器:
# 构建项目
npm run build
# 将 build 目录的内容上传到你的 Web 服务器
# 确保服务器配置了正确的路由规则(SPA 支持)
Nginx 配置示例:
server {
listen 80;
server_name your-domain.com;
root /path/to/build;
index index.html;
location / {
try_files $uri $uri/ /index.html;
}
# 启用 gzip 压缩
gzip on;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
}
- API 密钥批量验证
- 清理过期的密钥
- 快速检测密钥状态
- 团队密钥管理
- ✅ 纯前端运行,密钥不会上传
- ✅ 开源透明,代码可审查
- ✅ 仅用于验证,不存储任何数据
纯前端:HTML + CSS + JavaScript
MIT License
如果有用的话,给个 ⭐ 吧!