關(guān)于vue-resource報錯450的解決方案
本文介紹了關(guān)于vue-resource報錯450的解決方案,分享給大家,具體如下:
一、基本使用:
1.頁面引入
import vueResource from 'vue-resource' Vue.use(vueResource)
2. 調(diào)取接口
Vue.http.post(url, {
'data1': data1,
'data2': 'data2'
}).then(response => {
console.log('success', response)
}, response => {
console.log('error', response)
})
二、報錯450
定位錯誤信息:請求header沒有完全一一對應(yīng)。Content-Type: application/x-www-form-urlencoded; charset=UTF-8應(yīng)為Content-Type: application/json; charset=UTF-8,檢查頁面代碼,發(fā)現(xiàn)已經(jīng)設(shè)置了
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()
})
只是頁面沒有起作用而已,那究竟是什么原因?qū)е马撁嬖O(shè)置的Content-Type失效了呢?繼續(xù)追溯,發(fā)現(xiàn)跟這行代碼有關(guān)
// Vue.http.options.crossOrigin = true // Vue.http.options.emulateHTTP = true Vue.http.options.emulateJSON = true //(跟這行代碼有關(guān))
三、分析
下面分別來講一下這幾行代碼的用處,以及emulateJSON是怎么影響到Content-Type設(shè)置的。
1. Vue.http.options.crossOrigin
這個很明顯是設(shè)置跨域的,此處不多講。
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,服務(wù)器又沒法處理這幾類請求的時候,設(shè)置Vue.http.options.emulateHTTP = true的話可以將X-HTTP-Method-Override設(shè)置為PUT|PATCH|DELETE,然后使用普通的post進(jìn)行請求。
關(guān)于X-HTTP-Method-Override講一下,它的使用場景是:
在某些HTTP代理不支持類似PUT|PATCH|DELETE這些類型HTTP請求的情況下,可以通過另一種完全違背協(xié)議的HTTP方法來"代理"。這種協(xié)議就是,使客戶端發(fā)出HTTP POST請求并設(shè)置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行可以看到,如果設(shè)置了emulateJSON的話會默認(rèn)加上這句
request.headers.set('Content-Type', 'application/x-www-form-urlencoded');
這就是為什么我們設(shè)置的Content-Type失效了。只要去掉Vue.http.options.emulateHTTP = true 或者直接置為false就可以了。
vue-resource(github)地址:https://github.com/pagekit/vue-resource
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解vue-Resource(與后端數(shù)據(jù)交互)
- 談?wù)刅ue.js——vue-resource全攻略
- Vue2學(xué)習(xí)筆記之請求數(shù)據(jù)交互vue-resource
- Vue-resource實(shí)現(xiàn)ajax請求和跨域請求示例
- 詳解vue與后端數(shù)據(jù)交互(ajax):vue-resource
- vue-resource 攔截器使用詳解
- 詳解vue 配合vue-resource調(diào)用接口獲取數(shù)據(jù)
- Vue.js使用$.ajax和vue-resource實(shí)現(xiàn)OAuth的注冊、登錄、注銷和API調(diào)用
- 詳解vue-resource promise兼容性問題
- 詳解vue前后臺數(shù)據(jù)交互vue-resource文檔
相關(guān)文章
vue+antDesign實(shí)現(xiàn)樹形數(shù)據(jù)展示及勾選聯(lián)動
本文主要介紹了vue+antDesign實(shí)現(xiàn)樹形數(shù)據(jù)展示及勾選聯(lián)動,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
vue3中做文件預(yù)覽的項(xiàng)目實(shí)踐
本文主要介紹了在Vue3項(xiàng)目中實(shí)現(xiàn)常見文件類型的預(yù)覽功能,包括docx、xlsx、pdf、txt、png、jpg、jpeg、mp4和mp3,具有一定的參考價值,感興趣的可以了解一下2025-01-01
Vue報錯Syntax?Error:TypeError:?this.getOptions?is?not?a?
前幾天在vue運(yùn)行項(xiàng)目過程中報錯了,所以下面這篇文章主要給大家介紹了關(guān)于Vue報錯Syntax?Error:TypeError:?this.getOptions?is?not?a?function的解決方法,需要的朋友可以參考下2022-07-07
vue項(xiàng)目使用定時器每隔幾秒運(yùn)行一次某方法代碼實(shí)例
有時候在項(xiàng)目中我們經(jīng)常需要設(shè)置簡單的倒計(jì)時功能,這個可以通過定時器來實(shí)現(xiàn),下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目使用定時器每隔幾秒運(yùn)行一次某方法的相關(guān)資料,需要的朋友可以參考下2023-04-04
Vue實(shí)現(xiàn)渲染數(shù)據(jù)后控制滾動條位置(推薦)
這篇文章主要介紹了Vue實(shí)現(xiàn)渲染數(shù)據(jù)后控制滾動條位置,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12
Vue中用JSON實(shí)現(xiàn)刷新界面不影響倒計(jì)時
這篇文章主要為大家詳細(xì)介紹了Vue中用JSON實(shí)現(xiàn)刷新界面不影響倒計(jì)時,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-10-10

