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 相关文章推荐
使用jquery实现图文切换效果另加特效
Jan 20 Javascript
浅谈javascript中createElement事件
Dec 05 Javascript
jquery实现的Accordion折叠面板效果代码
Sep 02 Javascript
基于javascript代码检测访问网页的浏览器呈现引擎、平台、Windows操作系统、移动设备和游戏系统
Dec 03 Javascript
vue学习笔记之v-if和v-show的区别
Sep 20 Javascript
vue.js 获取select中的value实例
Mar 01 Javascript
vue2.0 自定义 饼状图 (Echarts)组件的方法
Mar 02 Javascript
Element-UI Table组件上添加列拖拽效果实现方法
Apr 14 Javascript
JS中移除非数字最多保留一位小数
May 09 Javascript
微信小程序实现授权登录
May 15 Javascript
Vue+Node实现商品列表的分页、排序、筛选,添加购物车功能详解
Dec 07 Javascript
Vue Element校验validate的实例
Sep 21 Javascript
如何在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
如何开发一个虚拟域名系统
2006/10/09 PHP
PHP获取163、gmail、126等邮箱联系人地址【已测试2009.10.10】
2009/10/11 PHP
PHP简单检测网址是否能够正常打开的方法
2016/09/04 PHP
js判断选择的时间是否大于今天的代码
2013/08/20 Javascript
JavaScript获取XML数据附示例截图
2014/03/05 Javascript
小结Node.js中非阻塞IO和事件循环
2014/09/18 Javascript
jQuery中:disabled选择器用法实例
2015/01/04 Javascript
让JavaScript中setTimeout支持链式操作的方法
2015/06/19 Javascript
微信小程序 绘图之饼图实现
2016/10/24 Javascript
原生js编写基于面向对象的分页组件
2016/12/05 Javascript
js实现百度地图定位于地址逆解析,显示自己当前的地理位置
2016/12/08 Javascript
解析JavaScript实现DDoS攻击原理与保护措施
2016/12/26 Javascript
Bootstrap输入框组件简单实现代码
2017/03/06 Javascript
jQuery EasyUI 为Combo,Combobox添加清除值功能的实例
2017/04/13 jQuery
利用PM2部署node.js项目的方法教程
2017/05/10 Javascript
Angular5.1新功能分享
2017/12/21 Javascript
Angular @HostBinding()和@HostListener()用法
2018/03/05 Javascript
React如何实现浏览器打印部分内容详析
2019/05/19 Javascript
用 js 写一个 js 解释器过程详解
2019/08/02 Javascript
使用Vue实现调用接口加载页面初始数据
2019/10/28 Javascript
BootStrap前端框架使用方法详解
2020/02/26 Javascript
详解vue-router的Import异步加载模块问题的解决方案
2020/05/13 Javascript
Vue项目移动端滚动穿透问题的实现
2020/05/19 Javascript
[04:16]DOTA2英雄梦之声_第09期_斧王
2014/06/21 DOTA
python3使用urllib示例取googletranslate(谷歌翻译)
2014/01/23 Python
使用Python写CUDA程序的方法
2017/03/27 Python
Python之修改图片像素值的方法
2019/07/03 Python
Python内置加密模块用法解析
2019/11/25 Python
纯css3实现的动画按钮的实例教程
2014/11/17 HTML / CSS
日本著名的平价时尚女性购物网站:Fifth
2016/08/24 全球购物
阿迪达斯德国官方网站:adidas德国
2017/07/12 全球购物
商务英语应届生自我鉴定
2013/12/08 职场文书
毕业实习证明范本
2015/06/16 职场文书
React Hook用法示例详解(6个常见hook)
2021/04/28 Javascript
 python中的元类metaclass详情
2022/05/30 Python
HTML静态页面获取url参数和UserAgent的实现
2022/08/05 HTML / CSS