django drf 案例--实现url编码和json和dict格式转化小工具(涉及定义模型类,序列化器,类视图,路由),接口测试

简介: django drf 案例--实现url编码和json和dict格式转化小工具(涉及定义模型类,序列化器,类视图,路由),接口测试

整体目录

模型类models.py

from django.db import models
class UrlCoding(models.Model):
    raw_data = models.CharField(max_length=128, verbose_name='原始数据')
    coding_count = models.IntegerField(verbose_name='编码次数')
    new_data = models.CharField(max_length=128, verbose_name='新数据')
class JsonDict(models.Model):
    raw_data = models.TextField(verbose_name='原始数据', default='1')
    who_change = models.CharField(max_length=32, verbose_name='谁发起的格式转化')
    new_data = models.TextField(verbose_name='新数据', default='1')

序列化serializers.py

from rest_framework import serializers
from apps.tool.models import UrlCoding, JsonDict
#ModelSerializer会根据模型自动生成一组字段
class UrlCodingSerializer(serializers.ModelSerializer):
    class Meta:
        model = UrlCoding
        fields = '__all__' #返回数据展示字段为全部
        read_only_fields = ('id', 'new_data') #只读字段
class JsonDictSerializer(serializers.ModelSerializer):
    class Meta:
        model = JsonDict
        fields = '__all__'
        read_only_fields = ('id', 'new_data')

视图views.py

from rest_framework import status
from rest_framework.response import Response
from rest_framework.views import APIView
from apps.tool.gj import check_contain_chinese
from apps.tool.models import UrlCoding, JsonDict
from apps.tool.serializers import UrlCodingSerializer, JsonDictSerializer
import urllib.parse
class UrlCodingView(APIView):
    def get(self,request):#request没用到也必须写,不然会报错
        url_coding = UrlCoding.objects.all()#获取数据库所有数据
         #many=True表示允许有多条数据,instance=url_coding设置要反序列化的数据
        us = UrlCodingSerializer(instance=url_coding, many=True)
        return Response(data=us.data, status=status.HTTP_200_OK)
    def post(self, request):
      #序列化是python对象转化为json数据,反序列化是把json数据转为python对象
      #反序列化
        u = UrlCodingSerializer(data=request.data)
        #数据验证is_valid(),验证反序列化时的请求参数是否满足序列化器的要求,我这里使用的是ModelSerializer数据库序列化器
        #这里的检验要求就是UrlCoding模型类的raw_data 字段的设置就是最大长度不超过128,max_length=128,下面测试我会使用到
        if u.is_valid():
            raw_data = request.data['raw_data']
            coding_count = request.data['coding_count'] #编码次数
            if check_contain_chinese(raw_data):
                new_data = urllib.parse.quote(raw_data)
                for i in range(coding_count - 1):
                    new_data = urllib.parse.quote(new_data)
                #ModelSerializer序列化器默认实现了sava保存数据入库的方法,会自动把反序列化的数据存入到数据库
                #也可以在里面直接写值
                u.save(new_data=new_data)
                #status状态码,框架自带
                return Response(data=u.data, status=status.HTTP_200_OK)
            return Response({'err': '不包含中文不需要解码'}, status=status.HTTP_400_BAD_REQUEST)
        return Response(data=u.errors, status=status.HTTP_400_BAD_REQUEST)
class JsonDictView(APIView):
    def get(self,request):
        json_dict = JsonDict.objects.all()
        jd = JsonDictSerializer(instance=json_dict, many=True)
        return Response(data=jd.data, status=status.HTTP_200_OK)
    def post(self, request):
        print(request.data)
        j = JsonDictSerializer(data=request.data)
        if j.is_valid():
            raw_data = request.data['raw_data']
            who_change = request.data['who_change']
            if who_change == 'json_dict':
                new_data = raw_data.replace("\"", "'").title().replace('Null', 'None')
                j.save(new_data=new_data)
                return Response(data=j.data, status=status.HTTP_200_OK)
            elif who_change == 'dict_json':
                new_data = raw_data.replace("'", "\"").lower().replace('none', 'null')
                j.save(new_data=new_data)
                return Response(data=j.data, status=status.HTTP_200_OK)
            return Response({'err': '请填写json_dict或dict_json'})
        return Response(data=j.errors, status=status.HTTP_400_BAD_REQUEST)

二级路由apps.tool.urls.py

from django.urls import path, include
from apps.tool import views
urlpatterns=[
    #二级路由
    path('url_coding/', views.UrlCodingView.as_view()),
    path('json_dict',views.JsonDictView.as_view())
]

一级路由gadget.urls.py

from django.contrib import admin
from django.urls import path, include
urlpatterns = [
    #一级路由
    path('admin/', admin.site.urls),
    path('tool/',include('apps.tool.urls')),
]

测试

长度超过128

相关文章
|
1月前
|
JSON 前端开发 搜索推荐
关于商品详情 API 接口 JSON 格式返回数据解析的示例
本文介绍商品详情API接口返回的JSON数据解析。最外层为`product`对象,包含商品基本信息(如id、name、price)、分类信息(category)、图片(images)、属性(attributes)、用户评价(reviews)、库存(stock)和卖家信息(seller)。每个字段详细描述了商品的不同方面,帮助开发者准确提取和展示数据。具体结构和字段含义需结合实际业务需求和API文档理解。
|
2月前
|
JSON 人工智能 算法
探索大型语言模型LLM推理全阶段的JSON格式输出限制方法
本篇文章详细讨论了如何确保大型语言模型(LLMs)输出结构化的JSON格式,这对于提高数据处理的自动化程度和系统的互操作性至关重要。
|
3月前
|
JSON JavaScript Java
对比JSON和Hessian2的序列化格式
通过以上对比分析,希望能够帮助开发者在不同场景下选择最适合的序列化格式,提高系统的整体性能和可维护性。
118 3
|
3月前
|
JSON API 数据安全/隐私保护
拍立淘按图搜索API接口返回数据的JSON格式示例
拍立淘按图搜索API接口允许用户通过上传图片来搜索相似的商品,该接口返回的通常是一个JSON格式的响应,其中包含了与上传图片相似的商品信息。以下是一个基于淘宝平台的拍立淘按图搜索API接口返回数据的JSON格式示例,同时提供对其关键字段的解释
|
3月前
|
JSON 人工智能 算法
探索LLM推理全阶段的JSON格式输出限制方法
文章详细讨论了如何确保大型语言模型(LLMs)输出结构化的JSON格式,这对于提高数据处理的自动化程度和系统的互操作性至关重要。
567 12
|
3月前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
3月前
|
JSON Java 数据格式
springboot中表字段映射中设置JSON格式字段映射
springboot中表字段映射中设置JSON格式字段映射
180 1
|
4月前
|
JSON 数据格式
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
300 2
|
5月前
|
XML JSON JavaScript
js的json格式
js的json格式
|
5月前
|
JSON 前端开发 中间件
React读取properties配置文件转化为json对象并使用在url地址中
本文介绍了如何在React项目中读取properties配置文件,将其内容转化为JSON对象,并在请求URL地址时使用这些配置。文章详细说明了异步读取文件、处理字符串转换为JSON对象的过程,并提供了一个封装函数,用于在发起请求前动态生成配置化的URL地址。
127 1

热门文章

最新文章