django 接口函数的request
时间: 2024-12-29 13:26:54 浏览: 5
### Django API视图函数中的Request对象用法
在Django框架内,API视图函数接收HTTP请求并返回响应。每当有客户端发起请求时,Django会自动创建一个`WSGIRequest`对象,并将其作为第一个参数传递给视图函数[^3]。
#### 获取查询字符串参数
对于URL中以查询字符串形式传入的参数,比如`/api/resource/?key=value`,可以利用`request.GET`字典样式的属性来访问这些键值对。为了安全起见,建议提供默认值以防某些可选参数未被发送:
```python
value = request.GET.get('key', 'default_value')
```
此方法适用于GET请求所携带的数据获取[^4]。
#### 处理路径参数
当定义路由模式时,如果指定了路径转换器,则可以在视图内部直接通过位置或关键字参数捕获这部分数据。例如,在URL配置中有如下设置:
```python
path('article/<int:pk>/', views.article_detail),
```
那么对应的视图可以直接接受名为`pk`的整型参数而无需手动解析URL。
#### 访问请求头信息
有时需要检查或操作来自浏览器或其他客户端应用程序附加至HTTP消息顶部的信息。这可通过查阅`request.META`字典实现,其中包含了所有可用元数据项,像用户代理、编码方式等[^2]。
#### 用户认证状态验证
借助于内置中间件的支持,每次成功建立连接后都会尝试识别已登录的身份。因此,开发人员能够轻松地调用`request.user`属性判断当前是否有合法账户关联此次交互过程。
#### 示例代码展示
下面给出一段综合运用上述特性的简单例子:
```python
from django.http import JsonResponse
from django.views.decorators.csrf import csrf_exempt
import json
@csrf_exempt
def my_api_view(request, pk=None):
response_data = {}
# 判断请求方法是否为POST
if request.method == "POST":
try:
data = json.loads(request.body.decode())
# 假设我们有一个JSON payload {"message": "..."}
message = data.get('message', '')
# 将接收到的消息存入数据库或者其他逻辑
status_code = 201 # Created
response_data['status'] = 'success'
except Exception as e:
status_code = 400 # Bad Request
response_data['error'] = str(e)
elif request.method == "GET":
query_param = request.GET.get('query_key', None)
user_info = {
'username': request.user.username,
'is_authenticated': request.user.is_authenticated
}
response_data.update({
'method': 'GET',
'query_param': query_param,
'user_info': user_info
})
status_code = 200
return JsonResponse(response_data, status=status_code)
```
阅读全文