zoukankan      html  css  js  c++  java
  • Django-前后端分离

    新建一个子项目testcase

     在Django里新建一个子项目testcase,新建的项目需要在settings.py->INSTALLED_APPS里增加子项目的名字,即'testcase',否则后续建表的时候是找不到这个子项目的,也会生效。

    建表时不同的表之间都会有一些公共的字段,如果建表的时候每个类里的都写一遍很麻烦,此时我们可以把公共的字段抽离出来写一个父类,其余表在使用的时候继承即可。需要注意的是父类这个表在建表时是不应该被创建的,所以需要有一个特殊的声明。详情见例子

    建表时,多对多关系的两张表在django里是通过创建第三张表来实现的多对多关系的,

    class BaseModel(models.Model):  #父类
        create_time = models.DateTimeField(auto_now_add=True, verbose_name='创建时间')
        update_time = models.DateTimeField(auto_now=True, verbose_name='修改时间')
        is_delete = models.BooleanField(verbose_name='是否删除', default=False) #default=False表示删除的时候不会真的被删除,会被标记false
        class Meta:
            abstract = True #声明这个类只是用来继承的,不会创建这张表
    
    class CaseSet(BaseModel):  #继承父类
        name = models.CharField(verbose_name='集合名称',max_length=60)
        desc = models.CharField(verbose_name='集合描述',max_length=70)
    
    
        def __str__(self):
            return self.name
    
        class Meta:
            db_table = 'case_set'
            verbose_name ='用例集合表'
            verbose_name_plural = verbose_name
    class Case(BaseModel):  #用例表
    title = models.CharField(verbose_name='用例标题',max_length=80,db_index=True,unique=True)
    desc = models.CharField(verbose_name='用例描述',max_length=120)
    method_choice = [
    [0,'get'],
    [1,'post'],
    [2,'put'],
    [3,'delete'],
    ]
    method = models.SmallIntegerField(choices=method_choice,verbose_name='请求方式',default=0)
    url = models.URLField(max_length=50,verbose_name='请求url')
    params = models.TextField(verbose_name='请求参数')
    run_count = models.IntegerField(verbose_name='运行次数',default=0,null=True,blank=True)
    run_time = models.DateTimeField(verbose_name='运行时间',null=True,blank=True)
    case_set = models.ManyToManyField(CaseSet,db_constraint=False,verbose_name='用例集合',null=True,blank=True)
        #ManyToManyField表示多对多关系,case与case_set表是多对多关系,上面这一行实际会创建出第三张表来记录多对多关系。
        def __str__(self):
    return self.title

    class Meta:
    db_table = 'case'
    verbose_name ='用例表'
    verbose_name_plural = verbose_name

    前后端分离的项目后端返回的结果就不能用render了,要返回json串,需要导入from django.http import JsonResponse

    多个子项目时如何管理url?

    一个项目里有多个子项目,如果把所有的url都配置在django项目下的urls.py里会比较乱,这时我们可以在每一个子项目里单独创建一个urls.py文件,用于单独配置每个项目的url,只需在django项目里总的urls.py里把子项目的url配置进去即可。

     Django里的参数校验form

    导入:from django import forms

    form校验通过够会返回一个字典,在使用字典数据时用**form.cleaned_data

    form里可以自定义校验规则,例如校验methon字段,要以clean开头,即def clean_method,这属于校验单个字段,如果要校验多个字段,直接def clean

     方法一:

    # form 校验请求参数
    class CaseForm(forms.Form):
        """校验请求参数"""
        title = forms.CharField(max_length=50, min_length=2)
        desc = forms.CharField(max_length=60, required=False)
        method = forms.IntegerField()  # 0 1 2 3
        url = forms.URLField()
        params = forms.CharField(max_length=100)
    
        def clean_title(self):  # 校验单个字段
            title = self.cleaned_data.get('title')
            if models.Case.objects.filter(title=title).count() > 0:
                raise ValidationError('用例标题已经存在') #抛出一个异常,代码不会再往下走
            return title
    
        def clean(self):  # 校验多个字段
            title = self.cleaned_data.get('title')
            method = self.cleaned_data.get('method')
    
    引用的时候:
    class CaseView(View):
        def post(self, request):
            form = CaseForm(request.POST)
            if form.is_valid():
                print('这是用了form校验的')
                models.Case.objects.create(**form.cleaned_data)
                data = {'code': 0, 'msg': '添加成功'}
    
            else:
                print(form.errors.as_data())
                data = {'code': -1, 'msg': '参数错误'}
    
            return JsonResponse(data)

    方法二:这种和数据库有关系的校验还有一种简便的方法

    class CaseForm2(forms.ModelForm):
        class Meta:
            # fields = '__all__' #代表所有字段
            # fields=['method','url'] #代表校验这两个字段
            exclude=['case_set'] #排除某个字段
            model = models.Case #指关联哪张表
    
    引用的时候:
    class CaseView(View):
        def post(self, request):
            form = CaseForm2(request.POST)
            if form.is_valid():
                print('这是用了form校验的')
                form.save() #save方法就是直接连数据库保存,同下面一行,方法二才可以这么写
                #models.Case.objects.create(**form.cleaned_data)  #手动找到这张表进行操作,把检验通过的数据插入到表里
                data = {'code': 0, 'msg': '添加成功'}
    
            else:
                print(form.errors.as_data())
                data = {'code': -1, 'msg': '参数错误'}
    
            return JsonResponse(data)

    自定义返回类型

    from django.http import JsonResponse
    
    def NbResponse(code=0,msg='操作成功',**kwargs):
        response = {'code':code,'msg':msg}
        response.update(kwargs)
        return JsonResponse(response,json_dumps_params={'ensure_ascii': False})

    如果不知道数据库表的信息,可通过下方命令将数据库的表生成到model1.py文件中,就不需要自己在写了,这种方法只会生成单张表,如果表和表之间有关联关系,需自己手动关联。

    python manage.py inspectdb > model1.py

    Django如何连接redis

    在settings.py中配置如下内容

    CACHES = {
        "default": {
            "BACKEND": "django_redis.cache.RedisCache",
            "LOCATION": "redis://118.23.3.41:6399/0",
            "OPTIONS": {
                "CLIENT_CLASS": "django_redis.client.DefaultClient",
                "CONNECTION_POOL_KWARGS": {"max_connections": 100},
                "PASSWORD": "666667&*",  # 密码
            }
        },
        "redis2": {
            "BACKEND": "django_redis.cache.RedisCache",
            "LOCATION": "redis://127.0.0.1:6379/1",
            "OPTIONS": {
                "CLIENT_CLASS": "django_redis.client.DefaultClient",
                "CONNECTION_POOL_KWARGS": {"max_connections": 100, 'decode_responses': True},
                "PASSWORD": "123456",  # 密码
            }
        }
    }  # redis配置



  • 相关阅读:
    alpha冲刺9
    alpha冲刺8
    alpha冲刺7
    alpha冲刺6
    团队作业——随堂小测(同学录)
    alpha冲刺5
    【麻瓜制造者】团队项目测试报告与用户反馈
    Android基础学习
    学习博客之工具的学习、安装和使用
    学习博客之Java继承多态接口
  • 原文地址:https://www.cnblogs.com/tata-learning/p/12216046.html
Copyright © 2011-2022 走看看