本文介绍了关于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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# vue
# resource
# 450错误
# resource错误处理
# resource报错450
# 详解vue-Resource(与后端数据交互)
# 谈谈Vue.js——vue-resource全攻略
# Vue2学习笔记之请求数据交互vue-resource
# Vue-resource实现ajax请求和跨域请求示例
# 详解vue与后端数据交互(ajax):vue-resource
# vue-resource 拦截器使用详解
# 详解vue 配合vue-resource调用接口获取数据
# Vue.js使用$.ajax和vue-resource实现OAuth的注册、登录、注销和API调用
# 详解vue-resource promise兼容性问题
# 详解vue前后台数据交互vue-resource文档
# 报错
# 这行
# 这就是
# 是怎么
# 不多
# 可以通过
# 给大家
# 可以看到
# 不支持
# 影响到
# 很明显
# 设置为
# 错误信息
# 又没
# 这句
# 方法来
# 值为
# 大家多多
# 就可以
# 客户端
相关文章:
建站之星如何助力企业快速打造五合一网站?
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
文字头像制作网站推荐软件,醒图能自动配文字吗?
linux top下的 minerd 木马清除方法
如何在橙子建站中快速调整背景颜色?
官网自助建站平台指南:在线制作、快速建站与模板选择全解析
网站制作员失业,怎样查看自己网站的注册者?
如何快速搭建个人网站并优化SEO?
如何选择高效响应式自助建站源码系统?
建站之星与建站宝盒如何选择最佳方案?
网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?
Android自定义listview布局实现上拉加载下拉刷新功能
如何在Golang中指定模块版本_使用go.mod控制版本号
佛山企业网站制作公司有哪些,沟通100网上服务官网?
如何通过山东自助建站平台快速注册域名?
电脑免费海报制作网站推荐,招聘海报哪个网站多?
C#如何序列化对象为XML XmlSerializer用法
h5在线制作网站电脑版下载,h5网页制作软件?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
建站之星2.7模板快速切换与批量管理功能操作指南
c++怎么用jemalloc c++替换默认内存分配器【性能】
制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
Swift开发中switch语句值绑定模式
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
如何零基础在云服务器搭建WordPress站点?
如何在IIS中配置站点IP、端口及主机头?
早安海报制作网站推荐大全,企业早安海报怎么每天更换?
建站之星后台密码遗忘如何找回?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
小型网站制作HTML,*游戏网站怎么搭建?
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
一键网站制作软件,义乌购一件代发流程?
设计网站制作公司有哪些,制作网页教程?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
建站中国官网:模板定制+SEO优化+建站流程一站式指南
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
如何用花生壳三步快速搭建专属网站?
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
广州美橙建站如何快速搭建多端合一网站?
,南京靠谱的征婚网站?
如何选择域名并搭建高效网站?
建站之星如何优化SEO以实现高效排名?
公司网站的制作公司,企业网站制作基本流程有哪些?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
*请认真填写需求信息,我们会在24小时内与您取得联系。