关于vue-resource报错450的解决方案


Posted in Javascript onJuly 24, 2017

本文介绍了关于vue-resource报错450的解决方案,分享给大家,具体如下:

一、基本使用:

1.页面引入

import vueResource from 'vue-resource'
 Vue.use(vueResource)

2. 调取接口

Vue.http.post(url, {
 'data1': data1,
 'data2': 'data2'
}).then(response => {
 console.log('success', response)
}, response => {
 console.log('error', response)
})

二、报错450

定位错误信息:请求header没有完全一一对应。Content-Type: application/x-www-form-urlencoded; charset=UTF-8应为Content-Type: application/json; charset=UTF-8,检查页面代码,发现已经设置了

Vue.http.interceptors.push(function (request, next) {
 request.headers.set('Content-Type', 'application/json; charset=UTF-8')
 request.headers.set('Content-Type', 'application/json')
 next()
})

只是页面没有起作用而已,那究竟是什么原因导致页面设置的Content-Type失效了呢?继续追溯,发现跟这行代码有关

// Vue.http.options.crossOrigin = true 
 // Vue.http.options.emulateHTTP = true
 Vue.http.options.emulateJSON = true //(跟这行代码有关)

三、分析

下面分别来讲一下这几行代码的用处,以及emulateJSON是怎么影响到Content-Type设置的。

1. Vue.http.options.crossOrigin

这个很明显是设置跨域的,此处不多讲。

2. Vue.http.options.emulateHTTP

参考地址:https://github.com/pagekit/vue-resource/blob/develop/src/http/interceptor/method.js

摘出源码

/**
 * HTTP method override Interceptor.
 */

export default function (request, next) {

  if (request.emulateHTTP && /^(PUT|PATCH|DELETE)$/i.test(request.method)) {
    request.headers.set('X-HTTP-Method-Override', request.method);
    request.method = 'POST';
  }

  next();
}

大概的意思就是如果请求方式为PUT|PATCH|DELETE,服务器又没法处理这几类请求的时候,设置Vue.http.options.emulateHTTP = true的话可以将X-HTTP-Method-Override设置为PUT|PATCH|DELETE,然后使用普通的post进行请求。

关于X-HTTP-Method-Override讲一下,它的使用场景是:

在某些HTTP代理不支持类似PUT|PATCH|DELETE这些类型HTTP请求的情况下,可以通过另一种完全违背协议的HTTP方法来"代理"。这种协议就是,使客户端发出HTTP POST请求并设置header里X-HTTP-Method-Override值为PUT|PATCH|DELETE。

3. Vue.http.options.emulateJSON

参考地址:https://github.com/pagekit/vue-resource/blob/develop/src/http/interceptor/form.js

摘出源码

/**
 * Form data Interceptor.
 */

import Url from '../../url/index';
import { isObject, isFormData } from '../../util';

export default function (request, next) {

  if (isFormData(request.body)) {

    request.headers.delete('Content-Type');

  } else if (isObject(request.body) && request.emulateJSON) {

    request.body = Url.params(request.body);
    request.headers.set('Content-Type', 'application/x-www-form-urlencoded');
  }

  next();
}

从第17行可以看到,如果设置了emulateJSON的话会默认加上这句

request.headers.set('Content-Type', 'application/x-www-form-urlencoded');

这就是为什么我们设置的Content-Type失效了。只要去掉Vue.http.options.emulateHTTP = true 或者直接置为false就可以了。

vue-resource(github)地址:https://github.com/pagekit/vue-resource

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

Javascript 相关文章推荐
Juqery Html(),append()等方法的Bug解决方法
Dec 13 Javascript
JavaScript高级程序设计 阅读笔记(二十) js错误处理
Aug 14 Javascript
js点击更换背景颜色或图片的实例代码
Jun 25 Javascript
jQuery 获取兄弟元素的几种不错方法
May 23 Javascript
浅谈javascript的分号的使用
May 12 Javascript
jQuery+formdata实现上传进度特效遇到的问题
Feb 24 Javascript
详解Angular中的自定义服务Service、Provider以及Factory
Apr 22 Javascript
Node做中转服务器转发接口
Oct 18 Javascript
webpack+vue-cli项目中引入外部非模块格式js的方法
Sep 28 Javascript
JavaScript中的"=、==、==="区别讲解
Jan 22 Javascript
vue搜索和vue模糊搜索代码实例
May 07 Javascript
vue(2.x,3.0)配置跨域代理
Nov 27 Javascript
JavaScript中的FileReader图片预览上传功能实现代码
Jul 24 #Javascript
react-router4 嵌套路由的使用方法
Jul 24 #Javascript
关于react-router的几种配置方式详解
Jul 24 #Javascript
简单实现js放大镜效果
Jul 24 #Javascript
Vue列表页渲染优化详解
Jul 24 #Javascript
javascript cookie的基本操作(添加和删除)
Jul 24 #Javascript
JavaScript取得gridview中获取checkbox选中的值
Jul 24 #Javascript
You might like
PHP实现多条件查询实例代码
2010/07/17 PHP
PHP代码保护--Zend Guard的使用详解
2013/06/03 PHP
php修改上传图片尺寸的方法
2015/04/14 PHP
PHP中类的自动加载的方法
2017/03/17 PHP
PHP中error_reporting函数用法详细介绍
2017/06/11 PHP
php表单文件iframe异步上传实例讲解
2017/07/26 PHP
IE JS无提示关闭窗口不提示的方法
2010/04/29 Javascript
JavaScript 通过模式匹配实现重载
2010/08/12 Javascript
jQuery队列操作方法实例
2014/06/11 Javascript
js检测用户输入密码强度
2015/10/22 Javascript
js设置和获取自定义属性的方法
2016/10/20 Javascript
javascript简易画板开发
2020/04/12 Javascript
js事件冒泡与事件捕获详解
2017/02/20 Javascript
vue-resource 拦截器使用详解
2017/02/21 Javascript
JavaScript中最常见的三个面试题解析
2017/03/04 Javascript
axios全局请求参数设置,请求及返回拦截器的方法
2018/03/05 Javascript
vuejs点击class变化的实例
2018/09/05 Javascript
微信小程序实现tab左右切换效果
2020/11/15 Javascript
Python中用format函数格式化字符串的用法
2015/04/08 Python
Python打印scrapy蜘蛛抓取树结构的方法
2015/04/08 Python
python利用不到一百行代码实现一个小siri
2017/03/02 Python
Python实现字符串与数组相互转换功能示例
2017/09/22 Python
Python+tkinter模拟“记住我”自动登录实例代码
2018/01/16 Python
python3实现SMTP发送邮件详细教程
2018/06/19 Python
Python3实现对列表按元组指定列进行排序的方法分析
2018/12/22 Python
Python列表切片操作实例总结
2019/02/19 Python
Python单元测试与测试用例简析
2019/11/09 Python
Python 可视化神器Plotly详解
2020/12/26 Python
新加坡最佳婴儿用品店:Mamahood.com.sg
2018/08/26 全球购物
质检部岗位职责
2013/11/11 职场文书
民主生活会整改措施(党员)
2014/09/18 职场文书
2015年世界无车日活动总结
2015/03/23 职场文书
介绍信格式样本
2015/05/05 职场文书
举起手来观后感
2015/06/09 职场文书
Java使用Unsafe类的示例详解
2021/09/25 Java/Android
win10以太网连接不上怎么办?Win10连接以太网详细教程
2022/04/08 数码科技