当前位置: 首页 > news >正文

Django工程获取请求参数的几种方式

在 Django 中获取请求参数的完整方法如下:

一、GET 请求参数获取

def view_func(request):
    # 获取单个参数(推荐方式)
    name = request.GET.get('name', 'default')  # 带默认值
    age = request.GET.get('age', 0)
    
    # 获取多个同名参数(如复选框)
    ids = request.GET.getlist('ids[]')  # 返回列表
    
    # 获取所有参数
    all_params = request.GET.dict()  # 返回字典

二、POST 请求参数获取

def view_func(request):
    # 表单数据获取
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        
        # 处理多选数据
        hobbies = request.POST.getlist('hobbies')
        
        # 获取所有参数
        post_data = request.POST.dict()

三、JSON 请求体参数获取

import json

def view_func(request):
    if request.method == 'POST':
        try:
            data = json.loads(request.body)
            username = data.get('username')
            age = data.get('age')
        except json.JSONDecodeError:
            return HttpResponseBadRequest("Invalid JSON")

四、URL 路径参数获取

# urls.py
from django.urls import path
from . import views

urlpatterns = [
    path('user/<int:user_id>/', views.user_detail),
]

# views.py
def user_detail(request, user_id):
    # 直接获取路径参数
    print(user_id)  # 自动转换为整数

五、文件上传处理

def upload_file(request):
    if request.method == 'POST':
        uploaded_file = request.FILES.get('myfile')
        if uploaded_file:
            # 保存文件到指定位置
            with open(f'uploads/{uploaded_file.name}', 'wb+') as destination:
                for chunk in uploaded_file.chunks():
                    destination.write(chunk)
            return HttpResponse("File uploaded")

六、请求头信息获取

def get_headers(request):
    user_agent = request.META.get('HTTP_USER_AGENT')
    content_type = request.META.get('CONTENT_TYPE')
    auth_token = request.headers.get('Authorization')  # Django 2.2+

七、综合示例

def complex_example(request, product_id):
    # 1. 获取路径参数
    print(f"Product ID: {product_id}")
    
    # 2. 获取GET参数
    page = request.GET.get('page', 1)
    search = request.GET.get('q', '')
    
    # 3. 获取POST参数
    if request.method == 'POST':
        data = {
            'form_data': request.POST.dict(),
            'json_data': {}
        }
        
        # 4. 处理JSON数据
        if request.content_type == 'application/json':
            try:
                data['json_data'] = json.loads(request.body)
            except json.JSONDecodeError:
                pass
    
    # 5. 获取文件
    uploaded_file = request.FILES.get('attachment')
    
    # 6. 获取请求头
    client_ip = request.META.get('REMOTE_ADDR')
    
    return JsonResponse(data)

八、注意事项

  1. 参数类型转换
# 安全转换示例
def safe_conversion(request):
    page = request.GET.get('page', '1')
    try:
        page_num = int(page)
    except ValueError:
        page_num = 1
    
    is_admin = request.GET.get('admin', 'false').lower() == 'true'
  1. 安全验证
from django.core.exceptions import PermissionDenied

def secure_view(request):
    # 验证必要参数存在
    if not all([request.GET.get('token'), request.POST.get('user_id')]):
        raise PermissionDenied
    
    # 参数白名单验证
    allowed_params = {'page', 'sort', 'filter'}
    if not set(request.GET.keys()).issubset(allowed_params):
        return HttpResponseBadRequest("Invalid parameters")
  1. Django REST Framework 方式
# serializers.py
from rest_framework import serializers

class UserSerializer(serializers.Serializer):
    username = serializers.CharField()
    email = serializers.EmailField()

# views.py
from rest_framework.decorators import api_view
from rest_framework.response import Response

@api_view(['POST'])
def drf_example(request):
    serializer = UserSerializer(data=request.data)
    if serializer.is_valid():
        username = serializer.validated_data['username']
        return Response({'status': 'success'})
    return Response(serializer.errors, status=400)

九、参数获取方法对比

参数位置获取方式适用场景
URL 查询字符串request.GET过滤、分页、搜索参数
表单数据request.POST传统表单提交
JSON 数据json.loads(request.body)API 接口、AJAX 请求
路径参数视图函数参数RESTful 资源定位
文件上传request.FILES文件上传表单
请求头信息request.META/request.headers认证、客户端信息获取

十、最佳实践建议

  1. 始终对用户输入进行验证和清理
  2. 优先使用 get() 方法避免 KeyError
  3. 对数值型参数进行类型转换和范围验证
  4. 使用 DRF 的 Serializer 处理复杂参数验证
  5. 对敏感参数使用 HTTPS 传输
  6. 限制 GET 参数的最大长度(Django 默认 2500 字符)

完整示例项目结构:

myproject/
├── myapp/
│   ├── views.py
│   ├── urls.py
│   └── serializers.py
├── utils/
│   └── param_utils.py
└── myproject/
    ├── settings.py
    └── urls.py

相关文章:

  • 一遍通俗易懂的新华三交换机文档指南操作手册
  • AI日报 - 2025年3月10日
  • [项目]基于FreeRTOS的STM32四轴飞行器: 六.2.4g通信
  • ArduPilot开源代码之AP_OSD
  • 基于Python的商品销量的数据分析及推荐系统
  • 使用 Docker 部署 GitLab 并持久化数据
  • comctl32!ListView_OnSetItem函数分析LISTSUBITEM结构中的image表示图标位置
  • 简单的 Python 示例,用于生成电影解说视频的第一人称独白解说文案
  • Oracle数据库监听学习
  • NoteGen是一款开源跨平台的 AI 笔记应用,专注于 recording 和 writing ,基于 Tauri 开发
  • Node.js 技术原理分析系列 4—— 使用 Chrome DevTools 分析 Node.js 性能问题
  • IMX6ULL驱动开发Linux篇02——移植Rootfs
  • 李沐《动手学深度学习》——14.9. 用于预训练BERT的数据集——wiki数据集问题以及存在的其他问题
  • 小白学习:rag向量数据库
  • 《C++ primer》第四章
  • FOC 控制笔记【二】无感控制、滑膜观测器和PLL
  • 用《设计模式》的角度优化 “枚举”
  • Python零基础学习第三天:函数与数据结构
  • PyTorch深度学习在硬件与资源限制下分布式训练和多GPU加速等技术的实例代码
  • 从零构建高可用MySQL自动化配置系统:核心技术、工具开发与企业级最佳实践
  • 农行再回应客户办理业务期间离世:亲属连续三次输错密码,理解亲属悲痛,将协助做好善后
  • 奥运“四朝元老”华天回国参赛,伤势未愈谨慎出战全国锦标赛
  • 国防部:菲方应停止一切侵权挑衅危险举动,否则只会自食苦果
  • 沪指跌0.68%报3380.82点,创指跌1.92%:券商、军工跌幅靠前
  • 外企聊营商|威能集团:公平环境增“暖”意
  • 北斗专访|特赞科技范凌:现在AI主要是“说话”,接下来要“干活”了