DjangoRF-14-创建request子应用

注意,本应该是requests模块,为了区分,避免错误,用request

1、进入apps,创建request django-admin startapp request

2、因为只发送请求,没有数据库相关,不需要model。

3、进行序列化

from rest_framework import serializers

这里没u有进行引入ModeSer

class SingleRequestSerializer(serializers.Serializer):

method_choices = [

('get', 'get'),

('post', 'post'),

('delete', 'delete'),

('put', 'put'),

('patch', 'patch'),

]

url = serializers.CharField(help_text='url', label='url')

method = serializers.ChoiceField(choices=method_choices, help_text='请求方法', label='请求方法')

request = serializers.JSONField(help_text='请求参数', required=False, label='请求参数', default={})

复制代码
def validate_request(self, value):
    """解决json数据为空的问题"""
    if value.get('json') == {}:
        value.pop('json')
    return value

4views代码

from django.shortcuts import render

Create your views here.

import base64

import requests

from rest_framework.decorators import api_view

from rest_framework.response import Response

from .serializers import SingleRequestSerializer

@api_view(http_method_names=['POST'])

def request_view(request, format=None):

1. 接受请求数据并校验

serializer = SingleRequestSerializer(data=request.data)

serializer.is_valid(raise_exception=True)

2. 发送请求

data = serializer.validated_data

res = requests.request(method=data['method'], url=data['url'], **data['request'])

3. 组织响应数据并返回

res_data = {

'status_code': res.status_code,

'headers': dict(res.headers),

'cookies': dict(res.cookies)

}

content_type = res_data['headers'].get('Content-Type')

if content_type:

根据不同类型构造数据

if 'html' in content_type:

res_data['text'] = res.text

elif 'json' in content_type:

res_data['json'] = res.json()

else:

res_data['content'] = base64.b64encode(res.content).decode()

else:

res_data['content'] = base64.b64encode(res.content).decode()

复制代码
return Response(res_data, status=200)

5、urls的代码

from django.urls import path

from .views import request_view

urlpatterns = [

path('', request_view, name='request')

]

6.进行调试

相关推荐
绝无仅有16 分钟前
京东面试题解析:SSO、Token与Redis交互、Dubbo负载均衡等
后端·面试·github
懒惰蜗牛17 分钟前
Day44 | J.U.C中的LockSupport详解
java·开发语言·后端·java-ee
闲人编程20 分钟前
Python设计模式实战:用Pythonic的方式实现单例、工厂模式
开发语言·python·单例模式·设计模式·工厂模式·codecapsule·pythonic
Mintopia25 分钟前
🧠 Next.js 还是 Nuxt.js?——当 JavaScript 碰上命运的分叉路
前端·后端·全栈
Moniane1 小时前
API技术深度解析:从基础原理到最佳实践
开发语言
扶苏-su1 小时前
Java---String类
java·开发语言·string类
nexttake1 小时前
5.go-zero集成gorm 和 go-redis
开发语言·后端·golang
Victor3561 小时前
Redis(84)如何解决Redis的缓存击穿问题?
后端
Victor3561 小时前
Redis(85)Redis缓存与Memcached缓存有何区别?
后端
lang201509282 小时前
Spring环境配置与属性管理完全指南
java·python·spring