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 相关文章推荐
web前端开发也需要日志
Dec 09 Javascript
神奇的7个jQuery 3D插件整理
Jan 06 Javascript
javascript中的self和this用法小结
Feb 08 Javascript
深入理解JavaScript系列(41):设计模式之模板方法详解
Mar 04 Javascript
javascript正则表达式模糊匹配IP地址功能示例
Jan 06 Javascript
jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法
Mar 08 Javascript
jQuery插件HighCharts实现气泡图效果示例【附demo源码】
Mar 13 Javascript
JS+HTML5实现上传图片预览效果完整实例【测试可用】
Apr 20 Javascript
jQuery.Sumoselect插件实现下拉复选框效果
Nov 09 jQuery
vue router使用query和params传参的使用和区别
Nov 13 Javascript
js中this的指向问题归纳总结
Nov 28 Javascript
vue 封装 Adminlte3组件的实现
Mar 18 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
elgg 获取文件图标地址的方法
2010/03/20 PHP
php ci框架中加载css和js文件失败的原因及解决方法
2014/07/29 PHP
Yii查询生成器(Query Builder)用法实例教程
2014/09/04 PHP
PHP中echo,print_r与var_dump区别分析
2014/09/29 PHP
PHP也能干大事 随机函数
2015/04/14 PHP
PHP数学运算与数据处理实例分析
2016/04/01 PHP
php反射学习之依赖注入示例
2019/06/14 PHP
限制文本字节数js代码
2007/03/06 Javascript
基于jQuery的日期选择控件
2009/10/27 Javascript
JQuery下关于$.Ready()的分析
2009/12/13 Javascript
js Array操作的最简短最容易理解方法
2013/12/09 Javascript
45个JavaScript编程注意事项、技巧大全
2015/02/11 Javascript
JavaScript中逗号运算符介绍及使用示例
2015/03/13 Javascript
JavaScript+html5 canvas实现本地截图教程
2020/04/16 Javascript
JS实现太极旋转思路分析
2016/12/09 Javascript
基于Vue实现图书管理功能
2017/10/17 Javascript
JavaScript日期工具类DateUtils定义与用法示例
2018/09/03 Javascript
vue addRoutes路由动态加载操作
2020/08/04 Javascript
VUE使用 wx-open-launch-app 组件开发微信打开APP功能
2020/08/11 Javascript
jQuery实现简单评论区功能
2020/10/26 jQuery
Vue 数据绑定的原理分析
2020/11/16 Javascript
[01:56]无止竞 再出发——中国军团出征2017年DOTA2国际邀请赛
2017/07/05 DOTA
[06:57]DOTA2-DPC中国联赛 正赛 Ehome vs PSG.LGD 选手采访
2021/03/11 DOTA
Python实现将绝对URL替换成相对URL的方法
2015/06/28 Python
python opencv将图片转为灰度图的方法示例
2019/07/31 Python
Python爬虫如何破解JS加密的Cookie
2020/11/19 Python
Django filter动态过滤与排序实现过程解析
2020/11/26 Python
Python中对象的比较操作==和is区别详析
2021/02/12 Python
html5 CSS过度-webkit-transition使用介绍
2013/07/02 HTML / CSS
html5清空画布方法(三种)
2017/10/16 HTML / CSS
英国香水店:The Perfume Shop
2017/03/27 全球购物
股东授权委托书范文
2014/09/13 职场文书
2015年财务个人工作总结范文
2015/05/22 职场文书
安全生产会议制度
2015/08/06 职场文书
优秀党员主要事迹范文
2015/11/05 职场文书
导游词之寿县报恩寺
2020/01/19 职场文书