赞
踩
API Key 基本上可以认为是一个长字符串,允许 API 消费者(即使用 API 的人)访问受限的功能和数据。它作为一种安全措施,确保了 API 服务能够控制谁有权限访问什么数据,同时也帮助跟踪API的使用情况。生成API key来调用API是为了安全、控制和管理API访问的。这也就是为啥生产环境往往都需要加上key来进行第一步验证了。下面对此进行简单总结:
身份验证:
访问控制:
使用限制:
监控和记录:
安全性:
生成API key的过程可能会因平台或服务提供商的不同而有所差异,但一般步骤如下:
注册和登录:
创建API项目:
生成API key:
保存API key:
配置API key:
》在Google Cloud Platform上生成API key
不同平台的具体操作可能会有所不同,但基本流程是相似的。如果你有特定的平台或API需要生成API key,可以提供更多信息,我可以提供更详细的指导。比如大模型openai qwen等提供的API key访问,申请流程差不多,按需付费即可。
》基于python和fastapi快速生成一个自己api服务的key,以及如何使用验证
(1)sever端main.py
from fastapi import FastAPI, Depends, HTTPException, Header from typing import Optional import uuid app = FastAPI() # 这里我们将API key存储在内存中,实际应用中应使用数据库或其他安全存储 api_keys = {} # 生成API key并存储 def create_api_key(user: str) -> str: api_key = str(uuid.uuid4()) api_keys[api_key] = user return api_key # 验证API key def verify_api_key(x_api_key: str = Header(...)): if x_api_key not in api_keys: raise HTTPException(status_code=401, detail="Invalid API Key") # 生成API key的端点 @app.post("/generate_api_key") def generate_api_key(user: str): api_key = create_api_key(user) return {"api_key": api_key} # 需要验证API key的端点 @app.get("/secure_endpoint") def secure_endpoint(api_key: str = Depends(verify_api_key)): return {"message": "You have access to this endpoint"} if __name__ == "__main__": ###generate api key user="test_user1" user_key=create_api_key(user) print("{}:{}".format(user,user_key)) import uvicorn uvicorn.run(app, host="0.0.0.0", port=8000)
(2)client端
import requests # 生成API key def generate_api_key(user: str): response = requests.post("http://127.0.0.1:8000/generate_api_key", params={"user": user}) return response.json().get("api_key") # 使用API key调用受保护的端点 def call_secure_endpoint(api_key: str): headers = {"X-API-Key": api_key} response = requests.get("http://127.0.0.1:8000/secure_endpoint", headers=headers) return response.json() if __name__ == "__main__": """ user = "test_user" api_key = generate_api_key(user) print("Generated API Key:", api_key) """ ###从server端拿到key #api_key="8deb0e23-f2e7-4c01-a306-352bcf7dcf2d" ##right api_key="8deb0e23-f2e7-4c01-a306-352bcf7dcf2a" ##error response = call_secure_endpoint(api_key) print("Response from secure endpoint:", response)
(3)启动服务
启动FastAPI服务:
uvicorn main:app --reload
运行客户端脚本:
python client.py
(4)其他
验证和区分接口
from flask import Flask, request, jsonify app = Flask(__name__) API_KEY = "YOUR_API_KEY" def check_api_key(): api_key = request.headers.get('Authorization') if api_key != f"Bearer {API_KEY}": return jsonify({"error": "Unauthorized"}), 401 @app.before_request def before_request(): if request.endpoint != 'health_check': # 忽略不需要验证的端点 check_api_key() @app.route('/api/v1/users/<int:user_id>', methods=['GET']) def get_user(user_id): # 处理获取用户信息的逻辑 return jsonify({"user_id": user_id, "name": "John Doe"}) @app.route('/api/v1/orders/<int:order_id>', methods=['GET']) def get_order(order_id): # 处理获取订单信息的逻辑 return jsonify({"order_id": order_id, "status": "shipped"}) @app.route('/api/v1/products/<int:product_id>', methods=['GET']) def get_product(product_id): # 处理获取产品信息的逻辑 return jsonify({"product_id": product_id, "name": "Widget"}) @app.route('/health_check', methods=['GET']) def health_check(): return jsonify({"status": "ok"}) if __name__ == '__main__': app.run(debug=True)
通过before_request钩子函数在每个请求之前验证API密钥,并通过不同的URL路径来区分多个接口。这样可以确保在访问API接口前都进行了验证,并且可以清楚地区分每个接口调用。
》生成key的其他方式
import uuid
def generate_uuid_api_key():
return str(uuid.uuid4())
import hashlib
import time
def generate_hash_api_key():
return hashlib.sha256(str(time.time()).encode('utf-8')).hexdigest()
加密随机数生成器可以生成高强度的随机字符串,用于API key。
import secrets
def generate_secure_api_key():
return secrets.token_urlsafe(32)
import jwt
import datetime
def generate_jwt_api_key(secret_key, user_id):
payload = {
'user_id': user_id,
'exp': datetime.datetime.utcnow() + datetime.timedelta(days=1) # 过期时间
}
return jwt.encode(payload, secret_key, algorithm='HS256')
import base64
import hashlib
import time
def generate_user_based_api_key(user_id):
raw_key = f"{user_id}:{time.time()}"
return base64.urlsafe_b64encode(hashlib.sha256(raw_key.encode('utf-8')).digest()).decode('utf-8')
选择合适的生成方法
选择生成API key的方法时,应考虑以下因素:
在日常对API key的使用过程中,需要注意以下几点:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。