Django实现接口token检测的实现方案
创作时间:
作者:
@小白创作中心
Django实现接口token检测的实现方案
引用
CSDN
1.
https://blog.csdn.net/sixpp/article/details/146031460
一、Token认证的实现思路
- 用户登录后生成Token:用户登录成功后,服务器生成一个Token,并返回给客户端。
- 客户端请求时携带Token:客户端在每次请求时,将Token放入HTTP请求头(Headers)中。
- 服务器端验证Token:Django后端解析请求中的Token,并验证其合法性。
- Token校验通过,允许访问接口;否则,返回未授权的错误信息。
二、环境准备
在Django项目中,我们可以使用rest_framework.authtoken或者自定义Token认证逻辑。这里介绍两种方式:
- 基于 Django REST framework(DRF) 的 Token 认证
- 自定义 Token 认证
三、基于 Django REST Framework(DRF)的 Token 认证
Django REST Framework 提供了现成的 Token 认证机制,下面是实现步骤。
1. 安装 Django REST framework
如果还未安装 Django REST framework,请使用 pip 安装:
pip install djangorestframework
pip install djangorestframework.authtoken
2. 添加到 Django 配置
在 settings.py 中启用 Django REST framework 和 Token 认证:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'rest_framework.authtoken',
]
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework.authentication.TokenAuthentication',
),
'DEFAULT_PERMISSION_CLASSES': (
'rest_framework.permissions.IsAuthenticated',
),
}
3. 生成 Token 表
运行 Django 迁移命令,创建 Token 认证所需的数据表:
python manage.py migrate
4. 创建 API 视图
创建用户登录接口,生成并返回 Token。
from django.contrib.auth import authenticate
from rest_framework.authtoken.models import Token
from rest_framework.response import Response
from rest_framework.views import APIView
from rest_framework import status
class LoginView(APIView):
def post(self, request):
username = request.data.get("username")
password = request.data.get("password")
user = authenticate(username=username, password=password)
if user:
token, created = Token.objects.get_or_create(user=user)
return Response({"token": token.key})
return Response({"error": "Invalid Credentials"}, status=status.HTTP_401_UNAUTHORIZED)
5. 保护 API 端点
在 API 视图中使用 TokenAuthentication 保护 API,仅允许持有有效 Token 的用户访问:
from rest_framework.authentication import TokenAuthentication
from rest_framework.permissions import IsAuthenticated
from rest_framework.views import APIView
from rest_framework.response import Response
class ProtectedView(APIView):
authentication_classes = [TokenAuthentication]
permission_classes = [IsAuthenticated]
def get(self, request):
return Response({"message": "You have access to this protected endpoint."})
6. 测试 API
- 获取 Token:
curl -X POST http://127.0.0.1:8000/api/login/ -H "Content-Type: application/json" -d '{"username": "admin", "password": "password"}'
服务器返回:
{"token": "abc123xyz456"}
- 访问受保护的 API:
curl -X GET http://127.0.0.1:8000/api/protected/ -H "Authorization: Token abc123xyz456"
服务器返回:
{"message": "You have access to this protected endpoint."}
四、自定义 Token 认证方案
如果不使用 DRF 自带的 TokenAuthentication,我们也可以自定义 Token 认证。
1. 自定义 Token 模型
在 models.py 中创建 Token 存储表:
from django.db import models
from django.contrib.auth.models import User
import uuid
class CustomToken(models.Model):
user = models.OneToOneField(User, on_delete=models.CASCADE)
key = models.CharField(max_length=255, unique=True, default=uuid.uuid4)
created_at = models.DateTimeField(auto_now_add=True)
def __str__(self):
return self.key
2. 创建 Token 生成逻辑
在 views.py 中定义登录逻辑,生成自定义 Token:
from django.contrib.auth import authenticate
from django.http import JsonResponse
from .models import CustomToken
def custom_login(request):
if request.method == "POST":
username = request.POST.get("username")
password = request.POST.get("password")
user = authenticate(username=username, password=password)
if user:
token, created = CustomToken.objects.get_or_create(user=user)
return JsonResponse({"token": token.key})
return JsonResponse({"error": "Invalid credentials"}, status=401)
3. 中间件拦截 Token
在 middleware.py 中定义 Token 验证逻辑:
from django.http import JsonResponse
from .models import CustomToken
class TokenMiddleware:
def __init__(self, get_response):
self.get_response = get_response
def __call__(self, request):
token = request.headers.get("Authorization")
if not token:
return JsonResponse({"error": "Token missing"}, status=401)
try:
user_token = CustomToken.objects.get(key=token)
request.user = user_token.user
except CustomToken.DoesNotExist:
return JsonResponse({"error": "Invalid token"}, status=401)
return self.get_response(request)
然后,在 settings.py 中启用中间件:
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.middleware.authentication.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'myapp.middleware.TokenMiddleware', # 添加自定义 Token 认证中间件
]
4. 受保护的 API
在 views.py 中定义需要 Token 认证的接口:
from django.http import JsonResponse
def protected_view(request):
return JsonResponse({"message": "Welcome, you are authenticated!"})
5. 测试
- 获取 Token:
curl -X POST http://127.0.0.1:8000/custom_login/ -d "username=admin&password=admin"
返回:
{"token": "abc123xyz456"}
- 访问受保护 API:
curl -X GET http://127.0.0.1:8000/protected_view/ -H "Authorization: abc123xyz456"
返回:
{"message": "Welcome, you are authenticated!"}
五、总结
本方案介绍了 Django 中实现接口 Token 认证的两种方法:
- 使用 Django REST framework(DRF)的 Token 认证:适用于 REST API,简单易用。
- 自定义 Token 认证:适用于更灵活的需求,可定制 Token 规则、过期策略等。
以上代码和步骤确保了 API 的安全性,避免未经授权的访问,适用于 Django Web 项目的用户身份验证。
热门推荐
望天门山注释和译文,详解这首诗的含义和翻译
Win11自带压缩工具在哪?压缩文件无需第三方软件的全指南
论飞行汽车的发展现状、前景及对社会经济的影响
避免陷入高利贷陷阱:了解合法借款途径
制造费用包括哪些明细科目?
芒果是热性还是凉性?孕妇可以吃吗?
孕妇吃芒果,可以吗?专家解读,健康享受芒果时光
电器分类及其应用领域概述
肝好百病消!5味中药强力护肝,疏肝、补血、滋阴,养生必知
专家解答:308光疗治疗是否安全?
睡莲种植全攻略:从选种到养护的完整指南
拳皇97包子是哪个
梦见打台球是什么意思,好不好
梦见打台球是什么意思,好不好
拆解胖东来茶市:日销20万的卖茶模式,能大规模复制吗?
【全国护肤日】儿童也要防晒吗?该怎么选?
8种维生素C含量最高的水果,猕猴桃仅排第4,第一种你见过么
给宝宝吃鱼别只知道买鳕鱼了!这 12 种淡水鱼刺少营养好还便宜
扫雷技巧有哪些?提高扫雷游戏胜率的实用攻略
小区自管,业主委员会有权收取物业费吗?
向生命致敬,绍剧现代戏《台风眼》巡演受好评
帕洛玛天文台巨眼望远镜:探索宇宙,揭秘天文学先辈的传奇征程
DeepSeek引发家长新一轮焦虑,选什么专业可以避免被淘汰?
干细胞将糖尿病带入细胞治疗时代,治愈可期!
如何在虚拟机中正确安装Ubuntu操作系统?
清爽可口的冬瓜排骨汤制作方法与营养价值解析
泸州黄粑考证,它的起源和覆盖比你想象的更早和更广
湘西土家族苗族自治州的风土人情与民间习俗
中外合作办学学生自主学习能力提升研究——以宁波工程学院为例
吃得好≠营养够!点外卖也要学会科学搭配,让营养更加均衡