分析uniapp如何動(dòng)態(tài)獲取接口域名
背景
接口域名沒(méi)有寫(xiě)死,而是動(dòng)態(tài)獲取。具體實(shí)現(xiàn)就是 通過(guò)讀取一個(gè)靜態(tài)json文件,來(lái)設(shè)置真實(shí)的接口域名。好處是原域名有可能被封,這樣可以直接后臺(tái)操作修改該配置文件即可;不然的話,h5 項(xiàng)目可能還好說(shuō),app 的話必須重新發(fā)版。
代碼
// httpService.js 對(duì) uni.request 的封裝。
在數(shù)據(jù)請(qǐng)求入口處,統(tǒng)一先進(jìn)行 域名獲取,即 執(zhí)行 config.requestRemoteIp 方法
import config from '@/config'
import Vue from 'vue'
import cacheData from '@/service/cacheData.js'
const MockUtil = () => import('@/libs/mockUtil.js')
import Storage from '@/libs/storage.js'
class HttpRequest {
/**
* 讀取接口數(shù)據(jù)
* @param options 請(qǐng)求信息
* @param noMock 在整體使用mock數(shù)據(jù)的情形下,可 單獨(dú)設(shè)置 某個(gè)接口請(qǐng)求真實(shí)數(shù)據(jù)
* @param cacheId
* @returns {*}
*/
async requestResolve(options, urlCustom = '', noMock = false, cacheId = null) {
let remoteIP = await config.requestRemoteIp(); // 動(dòng)態(tài)設(shè)置接口請(qǐng)求域名
if (process.env.NODE_ENV === 'development' && config.isMockApi && !noMock) {
return this.getMockData(options)
}
if (cacheId && cacheData[cacheId]) {
return this.testHttp(cacheData[cacheId])
}
return new Promise((resolve, reject) => {
let baseUrl = process.env.NODE_ENV === 'development' ? config.baseUrl.dev : config.baseUrl.pro;
options.url = baseUrl + options.url + `${urlCustom}`;
uni.request(
Object.assign({
success: (res) => {
if (res.statusCode != '200'){
uni.showToast({
title: '服務(wù)器錯(cuò)誤:'+res.statusCode,
icon: "none"
})
reject()
}
else if (res.data.code == 10001) {
Storage.removeToken();
let vue = new Vue();
vue.$store.dispatch('logout')
vue.$routeUtil.reLaunch('main');
}
else if (res.data.code != 200) {
if (res.data.message) {
uni.showToast({
icon: 'none',
title: res.data.message
});
}
reject(res.data)
} else {
if (cacheId) {
cacheData[cacheId] = res.data.data
}
resolve(res.data.data)
}
},
fail: err => {
uni.showToast({
title: '服務(wù)器錯(cuò)誤',
icon: "none"
})
}
}, options)
);
})
}
/**
* mock數(shù)據(jù)按需導(dǎo)入
* @param options
* @returns {*}
*/
async getMockData(options) {
const Mock = await MockUtil()
const MockUrl = Mock.default[options.url]
if (typeof MockUrl !== 'function') {
return this.testHttp(MockUrl)
}
if (options.method === 'post') {
return this.testHttp(MockUrl(options.data, false))
}
return this.testHttp(MockUrl(options.params, true))
}
testHttp(data) {
let pro = new Promise(function(resolve, reject) {
setTimeout(function() {
resolve(data)
}, 50)
})
return pro
}
}
export default new HttpRequest()
// config.js
const config = {
isMockApi: false,
// requestUrl: 'http://qiniu.eightyin.cn/teacherpath.json?time=' + Math.random().toString(36),
requestUrl: 'http://qiniu.eightyin.cn/teacherpathtest.json?time=' + Math.random().toString(36),
baseUrl: {
dev: '',
pro: ''
},
img: {
ossDomain: ''
},
uuid: Math.random().toString(36).substring(3, 20),
requestRemoteIp: () => {
console.log('config:', config)
if (config.RemoteIpInited)
return Promise.resolve();
return new Promise((resolve, reject) => {
uni.request({
url: config.requestUrl,
success: (response) => {
//todo 測(cè)試
// config.baseUrl.pro = response.data.data.path;
config.baseUrl.dev = 'http://bayin5.mycwgs.com/';
config.img.ossDomain = response.data.data.ossDomain;
config.RemoteIpInited = true;
resolve()
},
fail: () => {
config.RemoteIpInited = true;
resolve()
}
})
});
}
}
export default config
以上就是分析uniapp如何動(dòng)態(tài)獲取接口域名的詳細(xì)內(nèi)容,更多關(guān)于uniapp動(dòng)態(tài)獲取接口域名的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
js定時(shí)器不準(zhǔn)確問(wèn)題的解決方法
本文主要介紹了js定時(shí)器不準(zhǔn)確問(wèn)題的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
嵌入式iframe子頁(yè)面與父頁(yè)面js通信的方法
這篇文章主要介紹了嵌入式iframe子頁(yè)面與父頁(yè)面js通信的方法,實(shí)例分析了嵌入式iframe子頁(yè)面與父頁(yè)面js通信的常用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-01-01
JavaScript中極易出錯(cuò)的操作符運(yùn)算總結(jié)
這篇文章主要給大家介紹了關(guān)于JavaScript中極易出錯(cuò)的操作符運(yùn)算的相關(guān)資料,包括了算術(shù)運(yùn)算符、比較運(yùn)算符、邏輯運(yùn)算符、賦值運(yùn)算符、一元運(yùn)算符以及運(yùn)算優(yōu)先級(jí)等問(wèn)題,需要的朋友可以參考下2021-08-08
js文件中引入另一個(gè)js文件的4種方法總結(jié)
JavaScript文件是一個(gè)文本類(lèi)型的文件,在任何文本編輯器中都可以被打開(kāi)和編輯,JavaScript文件的擴(kuò)展名為js,這篇文章主要給大家介紹了關(guān)于js文件中引入另一個(gè)js文件的4種方法總結(jié),需要的朋友可以參考下2023-12-12
JS題解leetcode去掉最低工資和最高工資后的工資平均值
這篇文章主要為大家介紹了JS題解leetcode去掉最低工資和最高工資后的工資平均值,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
js函數(shù)與php函數(shù)的區(qū)別實(shí)例淺析
這篇文章主要介紹了js函數(shù)與php函數(shù)的區(qū)別,以實(shí)例形式較為簡(jiǎn)單的分析了js函數(shù)與php函數(shù)語(yǔ)法及應(yīng)用上的不同點(diǎn),具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-01-01
深入講解xhr(XMLHttpRequest)/jsonp請(qǐng)求之a(chǎn)bort
這篇文章主要給大家深入的介紹了關(guān)于xhr(XMLHttpRequest)/jsonp請(qǐng)求之a(chǎn)bort的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-07-07

