1.创建一个测试项目
 
1.1 创建项目和APP
 
'''1.创建项目和APP'''
django-admin startproject BookManage   # 创建项目
python manage.py startapp books     # 创建APP
 
'''2.在settings中注册books模型'''
INSTALLED_APPS = [
  'books.apps.BooksConfig'
]
# 注:pycharm无法联想,需要把apps文件夹设置为源根
 
'''3.urls.py中添加路由'''
urlpatterns = [
  path('books/', include('books.urls')),
]
 
'''4.books/urls.py中添加子路由'''
from django.urls import path
urlpatterns = [
 
]
 
2.配置跨域
 
2.1 跨域原理
 
1. 首先浏览器安全策略限制js ajax跨域访问服务器
2. 如果服务器返回的头部信息中有当前域:
 
// 允许 http://localhost:8080 这个网站打开的页面中的js访问我
Access-Control-Allow-Origin: http://localhost:8080
 
// 允许携带cookie访问我
Access-Control-Allow-Credentials: true
 
那么, 浏览器可以让js 请求该服务器

2.2 cors设置
 
1. 安装包
pip install django-cors-headers
 
2. 注册应用
INSTALLED_APPS = [
  ...
  # 添加 django-cors-headers 使其可以进行 cors 跨域
  'corsheaders'
]
 
3. 添加中间件
MIDDLEWARE = [
  # 放在中间件第一个
  'corsheaders.middleware.CorsMiddleware',
  ...
]
 
4. 设置
# CORS跨域请求白名单设置
CORS_ORIGIN_WHITELIST = (
  'http://127.0.0.1:8080',
  'http://localhost:8080',
)
CORS_ALLOW_CREDENTIALS = True # 允许携带cookie
 
3.登录接口
 
3.1 urls.py 中配置路由
urlpatterns = [
  path('login/', views.login),
]
 
3.2 user/views.py 中写一个login视图函数
 
from django.http import JsonResponse
import json
 
def login(request):
  body_json = request.body.decode()
  body_dict = json.loads(body_json)
  name = body_dict.get('name')
  pwd = body_dict.get('pwd')
  if not all([name, pwd]):
    resp = {
      "code": 999,
      "msg": '信息不全'
    }
    return JsonResponse(resp)
 
if name == 'zhangsan' and pwd == '1234':
  data = {
    "code": 0,
    "msg": '登录成功',
    "data": {
      "id": 1,
      "name": '张三',
      "age": 18
    }
  }
  resp = JsonResponse(data)
  return resp
else:
  data = {
    "code": 999,
    "msg": '用户名密码不正确'
  }
  resp = JsonResponse(data)
  return resp
 
3.3 测试接口
 
http://127.0.0.1:8000/login/
 
{
  "name":"zhangsan",
  "pwd":"1234"
}
 

02.django配置跨域并开发测试接口的更多相关文章

  1. django配置跨域并开发测试接口

    1.创建一个测试项目 1.1 创建项目和APP django-admin startproject BookManage # 创建项目 python manage.py startapp books ...

  2. day3(django配置跨域)

    1.跨越原理 1. 首先浏览器安全策略限制js ajax跨域访问服务器 2. 如果服务器返回的头部信息中有当前域: // 允许 http://localhost:8080 这个网站打开的页面中的js访 ...

  3. django允许跨域请求配置

    django允许跨域请求配置 下载corsheader pip install django-cors-headers 修改setting.py中配置 在INSTALLED_APPS中增加corshe ...

  4. vue开发环境配置跨域,一步到位

    本文要实现的是:使用vue-cli搭建的项目在开发时配置跨域,上线后不做任何任何修改,接口也可以访问,前端跨域解决方案 production:产品 生产环境 development:开发 开发环境 1 ...

  5. Django 处理跨域的配置、前台处理ajax

    一. Django处理跨域 跨域的处理方式有很多,使用最多的就是CORS(跨域资源共享),接下来大致提一下django中处理跨域的配置. 首先安装django-cors-headers模块: pip ...

  6. System.Web.Http.Cors配置跨域访问的两种方式

    System.Web.Http.Cors配置跨域访问的两种方式 使用System.Web.Http.Cors配置跨域访问,众多大神已经发布了很多文章,我就不在详细描述了,作为小白我只说一下自己的使用心 ...

  7. WebApi使用cors配置跨域问题

    1.首先安装CORS,在WebApiCors项目上面使用Nuget搜索“microsoft.aspnet.webapi.cors”,安装第一个 2.当我们安装这个包之后,现有的packages目录下会 ...

  8. ASP.NET MVC4应用程序配置跨域访问

    开发框架是使用webapi做后台,HTML5做前台,通过ajax调用webapi后台,返回json结果. 用的编译器是visual Studio2013,下面是配置方法 1.web.config文件 ...

  9. nginx配置跨域、gzip加速、代理详细讲解

    1.配置跨域 这个很简单,直接打开配置nginx.conf ,在http下配置下面三行代码:当然如果你是想某一个虚拟主机下跨域,那就在哪个server下面添加 add_header Access-Co ...

随机推荐

  1. 64位系统 system32 和 syswow64

    \Windows\SysWOW64  文件夹下存放32位的库和应用程序 (WOW64 == Windows on Windows 64 bit ) \Windows\System32  文件夹下存放6 ...

  2. 南方IT比赛项目

    注意: 出现以下提示点击否就可以了 导入工作台: 导入模型 安装 安装到工作台上 修改模型位置 更新工具位置 点击是 改角度 九十度 添加组件 改一下名字,方便记忆 把工具移到组件 拆除后将工具移到S ...

  3. Jmeter之『如果(If)控制器』

    判断方法 ${__jexl3("${projectName}"=="${targetDir}",)} ${__groovy("${projectNam ...

  4. 一、Vuforia_AR

    一.AR概念: 增强现实(Augmented Reality,简称AR),是一种将虚拟信息与真实世界巧妙融合的技术,广泛运用了多媒体.三维建模.实时跟踪及注册.智能交互.传感等多种技术手段,将计算机生 ...

  5. Linux系统编程—有名管道

    ▋****1. 管道的概念 管道,又名「无名管理」,或「匿名管道」,管道是一种非常基本,也是使用非常频繁的IPC方式. 1.1 管道本质 管道的本质也是一种文件,不过是伪文件,实际上是一块内核缓冲区, ...

  6. 在自己电脑上查看git远程分支列表比实际云端的远程分支要多一些

    问题 最近打开一个很久没有打开过的项目,使用git branch -a查看了一下所以分支,其中有些远程分支没有什么用了 于是准备去gitlab上删除它,结果到gitlab上发现没有这些分支,猜测是自己 ...

  7. ubuntu20 使用命令安装 nginx

    安装 nginx sudo apt-get install nginx -y 配置文件 nginx 服务管理 # 启动 nginx 服务 service nginx start # 关闭 nginx ...

  8. [Docker] redis 全配置

    启动容器,加载配置文件并持久化数据 docker run -d --privileged=true -p 6379:6379 --restart always -v /usr/redis/conf:/ ...

  9. python的PEP8代码规范

    一.缩进:每级缩进用4个空格.如果缩进不正确或缩进格式不统一,一般错误信息会明确告诉你,但有时也会出现invalid syntax报错.所谓缩进不正确,python的缩进是四个空格或一个TAB,如果缩 ...

  10. 迅雷bt种子的制作

    BT是目前最热门的下载方式之一,它的全称为"BitTorrent"简称"BT",中文全称"比特流",但很多朋友将它戏称为"变态下载 ...