Django+vue跨域问题解决的详细步骤


Posted in Javascript onJanuary 20, 2019

跨域

由于开发模式为前后端分离式开发,故而通常情况下,前端和后端可能运行不同的ip或者port下,导致出现跨域问题,故而单独说明

什么是跨域

跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的。

其实我们通常所说的跨域是狭义的,是由浏览器同源策略限制的一类请求场景。

什么是同源策略?

同源策略/SOP(Same origin policy)是一种约定,由Netscape公司1995年引入浏览器,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,浏览器很容易受到XSS、CSFR等攻击。所谓同源是指"协议+域名+端口"三者相同,即便两个不同的域名指向同一个ip地址,也非同源。

同源策略限制以下几种行为:

  1. Cookie、LocalStorage 和 IndexDB 无法读取
  2. DOM 和 Js对象无法获得
  3. AJAX 请求不能发送

跨域错误浏览器会在控制台中出现如下错误:

报错信息如下:

Access to XMLHttpRequest at ' http://127.0.0.1 :8000/api/test/' from origin ' http://127.0.0.1 :3000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

翻译过来即是:从源地址 http://127.0.0.1 :3000 发起的到 http://127.0.0.1 :8000/api/test/ 的XMLHttpRequest访问违反了同源策略:因为在请求头中没有Access-Control-Allow-Origin的值

前端解决跨域

既然跨域是因为不同源,那我同源不就完事儿了,但是后端请求地址不可能改变,所以可以在前端和后端的中间加一层代理,前端通过代理访问后端。

在Vue-cli工具中已经提供了代理的功能,只需要配置即可。

在根目录下的config/index.js文件中有如下配置项:

proxyTable: {
   '/': { 
    target: 'http://127.0.0.1:8000/',
    changeOrigin: true,
    pathRewrite: {
     '^/api': ''
    }
   }
  },
  1. '/'表示以'/'(即所有的路径)开头的路径均需要代理,
  2. target:代理的目标服务器地址(即后端服务器地址)为 ' http://127.0.0.1 :8000/',
  3. changeOrigin,为修改源:修改请求中的源地址
  4. pathReWrite:URL路径重写,对于以'/api'开头的路径将'/api'替换为''

后端解决跨域

后端出于安全考虑,也会对于跨域有限制,解决方法如下:

安装django-cors-headers

$ pip install django-cors-headers

配置settings.py文件

INSTALLED_APPS = [
  ...
  'corsheaders',
  ...
 ] 

MIDDLEWARE_CLASSES = (
  ...
  'corsheaders.middleware.CorsMiddleware',
  'django.middleware.common.CommonMiddleware', # 注意顺序
  ...
)
#跨域增加忽略
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_ALLOW_ALL = True
CORS_ORIGIN_WHITELIST = (
  '*'
)

CORS_ALLOW_METHODS = (
  'DELETE',
  'GET',
  'OPTIONS',
  'PATCH',
  'POST',
  'PUT',
  'VIEW',
)

CORS_ALLOW_HEADERS = (
  'XMLHttpRequest',
  'X_FILENAME',
  'accept-encoding',
  'authorization',
  'content-type',
  'dnt',
  'origin',
  'user-agent',
  'x-csrftoken',
  'x-requested-with',
  'Pragma',
)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js模拟弹出效果代码修正版
Aug 07 Javascript
清除网页历史记录,屏蔽后退按钮!
Dec 22 Javascript
Riot.js 快速的JavaScript单元测试框架
Nov 09 Javascript
javascript中的float运算精度实例分析
Aug 21 Javascript
js实现键盘上下左右键选择文字并显示在文本框的方法
May 07 Javascript
浅析jquery数组删除指定元素的方法:grep()
May 19 Javascript
Javascript Promise用法详解
May 10 Javascript
vue2.0的虚拟DOM渲染思路分析
Aug 09 Javascript
vue项目使用高德地图的定位及关键字搜索功能的实例代码(踩坑经验)
Mar 07 Javascript
如何构建 vue-ssr 项目的方法步骤
Aug 04 Javascript
微信小程序中data-key属性之数据传输(经验总结)
Aug 22 Javascript
vue动态设置路由权限的主要思路
Jan 13 Vue.js
如何在vue里面优雅的解决跨域(路由冲突问题)
Jan 20 #Javascript
JavaScript禁用右键单击优缺点分析
Jan 20 #Javascript
JavaScript中concat复制数组方法浅析
Jan 20 #Javascript
JavaScript中import用法总结
Jan 20 #Javascript
如何优雅的在一台vps(云主机)上面部署vue+mongodb+express项目
Jan 20 #Javascript
js序列化和反序列化的使用讲解
Jan 19 #Javascript
vue-router传参用法详解
Jan 19 #Javascript
You might like
PHP制作图型计数器的例子
2006/10/09 PHP
php+ajax实现图片文件上传功能实例
2014/06/17 PHP
PHP文件锁定写入实例解析
2014/07/14 PHP
PHP中魔术变量__METHOD__与__FUNCTION__的区别
2014/09/29 PHP
PHP编程实现脚本异步执行的方法
2017/08/09 PHP
编写兼容IE和FireFox的脚本
2009/05/18 Javascript
基于jQuery的弹出框插件
2012/03/18 Javascript
JS的replace方法详细介绍
2012/11/09 Javascript
JAVASCRIPT函数作用域和提前声明 分享
2013/08/22 Javascript
点击弹出层效果&弹出窗口后网页背景变暗效果的实现代码
2014/02/10 Javascript
js实现当复选框选择匿名登录时隐藏登录框效果
2015/08/14 Javascript
使用grunt合并压缩js和css文件的方法
2017/03/02 Javascript
微信小程序 this.triggerEvent()的具体使用
2019/12/10 Javascript
详解Vue3 Composition API中的提取和重用逻辑
2020/04/29 Javascript
微信小程序整个页面的自动适应布局的实现
2020/07/12 Javascript
[02:32]“虐狗”镜头慎点 2016国际邀请赛中国区预选赛现场玩家采访
2016/06/28 DOTA
[01:10:27]DOTA2-DPC中国联赛正赛 SAG vs XG BO3 第二场 3月5日
2021/03/11 DOTA
Python3.6连接Oracle数据库的方法详解
2018/05/18 Python
使用pandas对两个dataframe进行join的实例
2018/06/08 Python
Python多继承原理与用法示例
2018/08/23 Python
python顺序执行多个py文件的方法
2019/06/29 Python
Python递归函数 二分查找算法实现解析
2019/08/12 Python
python实现身份证实名认证的方法实例
2019/11/08 Python
Python开发之身份证验证库id_validator验证身份证号合法性及根据身份证号返回住址年龄等信息
2020/03/20 Python
Python使用多进程运行含有任意个参数的函数
2020/05/02 Python
详解用python -m http.server搭一个简易的本地局域网
2020/09/24 Python
美国学校校服,儿童和婴儿服装:Cookie’s Kids
2016/10/14 全球购物
adidas菲律宾官网:adidas PH
2020/02/07 全球购物
三好生演讲稿
2014/09/12 职场文书
副乡长民主生活会个人对照检查材料思想汇报
2014/10/01 职场文书
2014年督导工作总结
2014/11/19 职场文书
复兴之路观后感
2015/06/02 职场文书
领导离职感言
2015/08/03 职场文书
幼儿体育课教学反思
2016/02/16 职场文书
演讲开头怎么书写?
2019/08/06 职场文书
Oracle配置dblink访问PostgreSQL的操作方法
2022/03/21 PostgreSQL