[python]django rest framework写POST和GET接口,,版本声明python


版本声明

python3.6.5
Django-2.0.6
djangorestframework-3.8.2
mysqlclient-1.3.12

1.写一个登录接口,不多说,直接上代码

login_models.py

# -*- coding: utf-8from django.db import models# Create your models here.# 用户表class tbl_user(models.Model):    user_name = models.TextField(max_length=10)    email = models.TextField(max_length=50,default=‘‘)    phone=models.CharField(max_length=11,default=‘‘)    password=models.TextField(max_length=30,default=‘‘)    token_value=models.TextField(max_length=100)    status=models.CharField(max_length=100)    creat_time = models.DateTimeField(auto_now_add=True)    # desc排序数据    class Meta:        ordering = [‘-creat_time‘]

 

post请求

login_userIn.py

# coding:utf-8import jsonfrom django.http import HttpResponsefrom rest_framework.views import APIViewfrom ApiSoftware.loginApi.PublicParameters import meta_json_Response,_Response_publicfrom ApiSoftware.modes import login_modelsfrom ApiSoftware.loginApi.PublicParameters import get_datesimport time,datetimeimport hashlibclass usr_login(APIView):# 定义请求方法为post,这种方法需要继承rest_framework的APIView    def post(self,request):        #初始化登录的model        register_models = login_models        # 取到request对象的body(json)        parameter_json = request.body        # json转字典        parameter = json.loads(parameter_json)        #定义请求里的key        get_phone = ‘phone‘        get_password = ‘password‘        #这是我写的一个方法用来把字典转成json的        get_json_Response = meta_json_Response()        #这个是初始化一个公共类,后面无效参数都调用这里的一个无效参数的字典,然后再转json,返回给客户端        get_Response_public = _Response_public()        # 如果定义的get_phone和get_password都在请求的json中忘下走        if get_phone in parameter and get_password in parameter:            #取出其request.json中的phone和password            phone=parameter[get_phone]            password=parameter[get_password]            # 如果phone和password都不为空            if phone and password:                #通过在model创建用户表通过取出的手机号和密码模糊查询是否有这个手机号和对应的密码                inspect_phone = register_models.tbl_user.objects.filter(phone__contains=phone,password__contains=get_password)                #判断inspect_phone是否为空                if  inspect_phone:                    inspect=True                else:                    inspect=False                #如果用户表没有这个手机号,走正常登录逻辑                if inspect == True:                    #写一个方法通过sha256加密生成token                    def _token_value(value):                        hash = hashlib.sha256()                        hash.update(value.encode(‘utf-8‘))                        return (hash.hexdigest())                    #获取现在的时间转str                    nowTime_to_token = datetime.datetime.today()                    nowTime_to_token=str(nowTime_to_token)                    #定义原字符串是目前时间加上手机号和密码                    get_user_str=str(phone+password+nowTime_to_token)                    #通过上面sha256加密原字符串                    get_token=_token_value(get_user_str)                    # 根据请求的手机号密码查询出用户                    inster_token = login_models.tbl_user.objects.filter(phone__contains=phone, password__contains=password)                    # 取出对象(查询到的用户数据),这个for可以不用因为唯一性的数据,直接索引,懒得改了                    for value in inster_token:                        #                        value.token_value=get_token                        #把上面的加密的token保存到这个用户数据库token_value字段中                        value.save()                    user_list = []                    #取出对象(查询到的用户数据),这个for可以不用因为唯一性的数据,直接索引,懒得改了,其实上面已经取过了,懒得改                    #想把用户名取出来返回出去                    for users in inster_token:                        name_info=[users.user_name,users.token_value]                        user_list.append(name_info)                    usersInfo=user_list[0]                   # 返回字典                    datas = {                        ‘status‘: ‘true‘,                        ‘message‘: ‘登录成功!‘,                        ‘name‘:usersInfo[0],                        ‘token‘:get_token                    }                    # 字典转json返回给客户端                    return HttpResponse(get_json_Response.json_Response(datas),                                        content_type="application/json,charset=utf-8")               # 异常情况                else:                    datas = {                        ‘status‘: ‘false‘,                        ‘message‘: ‘手机号或密码不正确!‘,                        ‘data‘: ‘null‘                    }                    return HttpResponse(get_json_Response.json_Response(datas),                                        content_type="application/json,charset=utf-8")            # 异常情况 公共方法            else:                return HttpResponse(get_Response_public.InvalidParameter(),                                    content_type="application/json,charset=utf-8")                # 异常情况 公共方法        else:            return HttpResponse(get_Response_public.InvalidParameter(), content_type="application/json,charset=utf-8")

1.1.设置路由 

 url.py

"""TestWebApi URL ConfigurationThe `urlpatterns` list routes URLs to views. For more information please see:    https://docs.djangoproject.com/en/2.0/topics/http/urls/Examples:Function views    1. Add an import:  from my_app import views    2. Add a URL to urlpatterns:  path(‘‘, views.home, name=‘home‘)Class-based views    1. Add an import:  from other_app.views import Home    2. Add a URL to urlpatterns:  path(‘‘, Home.as_view(), name=‘home‘)Including another URLconf    1. Import the include() function: from django.urls import include, path    2. Add a URL to urlpatterns:  path(‘blog/‘, include(‘blog.urls‘))"""from django.conf.urls import urlfrom django.contrib import adminfrom django.urls import path# import上面写的类from ApiSoftware.loginApi.login_userIn import usr_loginurlpatterns = [    path(‘admin/‘, admin.site.urls),       url(r‘login/userin/‘,usr_login().as_view()) #前面login/userin/自己定义访问路径,后面写类.as_view()
]

 1.2启动服务python manage.py runserver127.0.0.1:8100 测试写的post接口,postman调试工具

技术分享图片

请求ok

2.写一个GET接口

今天周日了,早点睡 明天抽空写下吧~

[python]django rest framework写POST和GET接口

评论关闭