Django–前后端分离-后端(二)实现简单的登陆接口进行跨域

前后端分离-登陆接口实现跨域

一、创建login项目

1、创建testBackends项目(如果做过第一章节这里可以跳过)

django-admin startproject testBackends

2、创建login模块应用

(1)cd进入testBackends项目
(2)创建任意项目模块如:login

python3 manage.py startapp login

3、把login应用配置到testBackends–>settings.py里面,(如果看过第一章那么安装Django依赖包这里可以跳过,如果没有看过在这里需要安装依赖包,并且也要配置到settings.py里面)

1、安装rest_framework框架
它是基于Django的,帮助我们快速开发符合restful规范的接口框架,它主要适用于前后端分离项目。
Django中文网:https://www.django.cn/course/show-20.html
Django官方文档:https://www.django-rest-framework.org/api-guide/serializers/

pip3 install djangorestframework

2、安装django-cors-headers依赖
django-cors-headers处理跨域请求,一个为响应添加跨源资源共享(CORS)头的Django应用。这允许从其他源向Django应用程序发出浏览器内请求。

pip3 install django-cors-headers

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域
或者写成下列这样也是可以的:
Django--前后端分离-后端(二)实现简单的登陆接口进行跨域

4、在login模块内添加下列.py文件

login/serializers.py 数据序列化
login/urls.py 添加login的路由

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域

; 二、创建登陆数据库

1、在login/models.py内编写数据表及名称

from django.db import models

class Login(models.Model):

    username = models.CharField(max_length=20)
    password = models.CharField(max_length=20)

    class Meta:

        db_table = "d_login"

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域

2、login/serializers.py序列化器编写


"""
序列化器
"""
from rest_framework import serializers
from .models import Login

class LoginSerializer(serializers.HyperlinkedModelSerializer):
    class Meta:

        model = Login

        fields = "__all__"

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域

3、然后在终端进行输入下列命令进行创建数据库

1、迁移模型,创建表结构

python3 manage.py makemigrations

2、创建数据库表

python3 manage.py migrate

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域
这样数据库表就生成了。这个是内置的sqlite。

三、进入login/views.py编写登陆逻辑

from django.shortcuts import render
from django.http import JsonResponse
from login import models

def apiLogin(request):

    res = {
        'code': 0,
        'msg': '登录成功'
    }

    if request.POST:

        username = request.POST.get('username')
        password = request.POST.get('password')
        Type = request.POST.get('type')

        if Type == "1":

            Login = models.Login.objects.values()

            for i in Login:
                if i['username'] == username and i['password'] == password:

                    return JsonResponse(res)

            res['code'] = 1
            res['msg'] = "账号密码不正确"
            return JsonResponse(res)

        elif Type == "2":
            if username and password:

                login_save = models.Login(username=username, password=password)

                login_save.save()
                res['msg'] = "账号密码注册成功"
                return JsonResponse(res)
            res['msg'] = "注册失败"
            return JsonResponse(res)

        else:
            res['msg'] = "类型错误"
            return JsonResponse(res)

    res['msg'] = "错误的请求方式"
    return JsonResponse(res)

四、在配置路由

1、打开login/urls.py 文件进行编写路由

在各自 app 目录下,写自己的 urls.py 文件,最后进行路径跳转


"""
路由
"""
from django.urls import path
from . import views
from django.views.decorators.csrf import csrf_exempt

urlpatterns = {

    path("login", csrf_exempt(views.apiLogin), name='login')
}

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域

2、主路由配置跳转到login模块的路由

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),

    path('api/', include("login.urls"))
]

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域

五、启动项目,进行前后端联调

python3 manage.py runserver

启动项目后,我们用postman或者VUE进行前后端联调就可以啦

1、postman

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域

; 2、VUE

Django--前后端分离-后端(二)实现简单的登陆接口进行跨域
Django--前后端分离-后端(二)实现简单的登陆接口进行跨域

在这里我们简单的前后端分离就完成了,具体的业务实现还是要看代码基础以及业务知识哦~~

六、额外小知识

1、HttpResponse与JsonResponse的区别

HttpResponse与JsonResponse都是django中后台给前台返回数据的方法,并且他们最后走的都是http协议。

HttpResponse:需要我们自己前后台进行序列化与反序列化

JsonResponse:则把序列化和反序列化封装了起来,我们直接传入可序列化的字符串,在前台就能收到对应的数据。

总结:主要是针对前端进行序列化与反序列化是否处理的区别。

Original: https://blog.csdn.net/zhouzongxin94/article/details/122382992
Author: ZongXin.Zhou
Title: Django–前后端分离-后端(二)实现简单的登陆接口进行跨域

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/733476/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • django 笔记第二节

    一. 启动项目 命令行进入自己想放代码的目录 激活虚拟环境(命令行最前端出现虚拟环境名称证明环境已激活) 这样就在你指定的目录下生成了HelloWorld工程 进入HelloWor…

    Python 2023年8月6日
    049
  • Django网站部署

    1.安装django 可通过以下两种方式来安装django(二择一即可): sudo pip3 install django==1.11.28 sudo pip3 install …

    Python 2023年8月4日
    047
  • AirSim无人机键盘控制

    AirSim仿真中实现多键盘按键控制 前言 本文实现效果 一、环境依赖 二、多按键检测 * 1.Pygame中的常用的键盘鼠标事件 2.利用Pygame实现的多按键检测 AirSi…

    Python 2023年9月18日
    030
  • 从 0 到 1 搞一个 Compose Desktop 版本的玩天气之踩坑

    从 0 到 1 搞一个 Compose Desktop 版本的玩天气之踩坑 大家好,好久不见,接下来一段时间我会系统性地写一套关于 Compose Desktop 的文章,带大家从…

    Python 2023年9月29日
    065
  • 数据预处理(考试版1)

    数据预处理的主要任务数据清理填充缺失值,识别/去除离群点,光滑噪音,并纠正数据中的不一致数据集成多个数据库,数据立方体或文件的集成数据归约得到数据的归约表示,它小得多,但产生相同或…

    Python 2023年8月21日
    085
  • Python标准库笔记(10) — itertools模块

    itertools 用于更高效地创建迭代器的函数工具。 itertools 提供的功能受Clojure,Haskell,APL和SML等函数式编程语言的类似功能的启发。它们的目的是…

    Python 2023年6月3日
    044
  • Matplotlib绘制折线图,条形图,柱状图,面积图

    Matplotlib绘制折线图,条形图,柱状图,面积图 一.折线图 * 实例1,绘制未来15天内的最高气温和最低气温 二.绘制柱形图或者堆积柱形图 * 1. 绘制一个具有两组形状的…

    Python 2023年9月3日
    056
  • Python tkinter 一个Music download software的界面

    前言 本次案例最终实现效果 ; 开发环境 python 3.8: 解释器 pycharm: 代码编辑器 界面代码实现 先导入所需模块 import tkinter as tk fr…

    Python 2023年10月31日
    052
  • 【Pygame小游戏】这款“吃掉一切”游戏简直奇葩了?通通都吃掉嘛?(附源码免费领)

    前言 嗨!我是栗子同学。很久不见甚是思念!我回来啦~ 今天给大家写点儿什么呢?!嘿嘿,其实这么久没写代码啦,手都不会打字了,代码都不会敲 了,容我慢慢道来!先来点儿简单的吧(其实是…

    Python 2023年9月18日
    071
  • Django——jinja2配置与使用

    一、准备 1、首先创建一个新的项目 django-admin startproject jinja2、下载一下jinja的依赖: pip install jinja23、进入jin…

    Python 2023年8月4日
    059
  • 如何创建Django项目

    创建Django 项目前置条件:已完成 Python环境和 PyCharm安装 Django的安装和项目的创建 | 在命令行输入pip 命令安装 pip install -i ht…

    Python 2023年10月30日
    044
  • 基于 Python 的 M-K(Mann-Kendall)突变检验 的简单实现

    M-K(Mann-Kendall)法是一种气候诊断与预测技术,可以判断气候序列中是否存在气候突变,如果存在,可确定出突变发生的时间。Mann-Kendall检验法也经常用于气候变化…

    Python 2023年8月1日
    0171
  • pytest文档9-参数化parametrize

    前言 pytest.mark.parametrize装饰器可以实现测试用例参数化。 parametrizing 1.这里是一个实现检查一定的输入和期望输出测试功能的典型例子 con…

    Python 2023年9月15日
    040
  • Unity架构之详解域重新加载和场景重新加载

    一、unity进入运行模式包括以下主要阶段 备份当前场景:这仅在场景被修改后发生。这样当退出运行模式时,Unity 将场景恢复为运行模式开始前的状态。 Domain Reload:…

    Python 2023年9月30日
    041
  • 【WPF】实现动态切换语言(国际化)以及动态换肤功能

    前言:以下内容,手把手从搭建到最终实现,完成多语言切换以及换装功能。 本地系统环境:win 10 编译器环境:VS2022 社区版 .NET 环境: .NET 6 1、新建一个WP…

    Python 2023年10月21日
    041
  • tensorflow学习笔记 | 02 – 线性回归问题Numpy实战

    一、引言 机器学习的目标是希望从已有数据中学习到一些高层次的规律,从而在给定某个新的 x 时,根据机器学习的结果,可以给出一个预测的y。 结果y通常有两种类型: 连续型变量和离散型…

    Python 2023年8月26日
    065
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球