日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue接口請求加密實例

瀏覽:174日期:2022-12-10 10:00:14

1. 安裝vue項目 npm init webpack project

2 安裝iview npm i iview --save (這里是結合iview框架使用的 可根據自己的需求安裝 當然也可以不安裝)

3 在src目錄下建一個utils文件夾 里面需要放5個js 都是封裝好的js文件 功能不僅僅局限于加密 可以研究一下 你會學到很多東西

1.api.js

/** * 為vue實例添加http方法 * Vue.use(http) */import http from ’./http’ export default { /** * install鉤子 * @param {Vue} Vue Vue */ install (Vue) { Vue.prototype.http = http }}

2. filters.js

// 公共使用的filtersimport Vue from ’vue’;import {getTime, getPrdType} from ’../utils/time’; // 區(qū)分支付方式的filterVue.filter(’paywayType’, function (value) { return value;}); // 時間Vue.filter(’newdate’, function (value) { return getTime(value);});// 時間-分鐘Vue.filter(’minute’, function (str, n) { const num = parseInt(n); return str.split(’ ’)[num];});// 分割以:連接多個參數的stringVue.filter(’valStr’, function (str, n) { const num = parseInt(n); return str.split(’:’)[num];});// 根據提供時間計算倒計時Vue.filter(’countDown’, function (str) { const dateStr = new Date(str).getTime(); const timeNow = new Date().getTime(); const countDown = dateStr - timeNow; const countDownDay = Math.floor((dateStr - timeNow) / 86400000);// 計算剩余天數 const countDownHour = Math.floor((dateStr - timeNow) / 3600000 % 24);// 計算剩余小時 const countDownMin = Math.floor((dateStr - timeNow) / 60000 % 60);// 計算剩余分鐘 // const countDownSec = Math.floor((dateStr - timeNow) / 1000 % 60);// 計算剩余秒 if (countDown <= 0) { return ’- - - -’; } else { return countDownDay + ’天’ + countDownHour + ’小時’ + countDownMin + ’分鐘’; }});// 取絕對值Vue.filter(’numberFn’, function (numberStr) { return Math.abs(numberStr);});// 處理圖片地址的filterVue.filter(’imgSrc’, function (src) { const env = getPrdType(); switch (env) { case ’pre’: return `https://preres.bldz.com/${src}`; case ’pro’: return `https://res.bldz.com/${src}`; case ’test’: default: return `https://testimg.bldz.com/${src}`; }});// 直接轉化剩余時間Vue.filter(’dateShow’, function (dateStr) { const countDownDay = Math.floor(dateStr / 86400);// 計算剩余天數 const countDownHour = Math.floor(dateStr / 3600 % 24);// 計算剩余小時 const countDownMin = Math.floor(dateStr / 60 % 60);// 計算剩余分鐘 // const countDownSec = Math.floor((dateStr - timeNow) / 1000 % 60);// 計算剩余秒 if (dateStr <= 0) { return ’- - - -’; } else if (countDownDay <= 0 && countDownHour <= 0) { return countDownMin + ’分鐘’; } else if (countDownDay <= 0) { return countDownHour + ’小時’ + countDownMin + ’分鐘’; } else { return countDownDay + ’天’ + countDownHour + ’小時’ + countDownMin + ’分鐘’; }});// 處理圖片Vue.filter(’imgLazy’, function (src) { return { src, error: ’../static/images/load-failure.png’, loading: ’../static/images/default-picture.png’ };});Vue.filter(’imgHandler’, function (src) { return src.replace(/,jpg/g, ’.jpg’);});

3.http.js

import axios from ’axios’import utils from ’../utils/utils’import {Modal} from ’iview’// import qs from ’qs’;axios.defaults.timeout = 1000*60axios.defaults.baseURL = ’’const defaultHeaders = { Accept: ’application/json, text/plain, */*; charset=utf-8’, ’Content-Type’: ’application/json; charset=utf-8’, Pragma: ’no-cache’, ’Cache-Control’: ’no-cache’}// 設置默認頭Object.assign(axios.defaults.headers.common, defaultHeaders) const methods = [’get’, ’post’, ’put’, ’delete’] const http = {}methods.forEach(method => { http[method] = axios[method].bind(axios)})export default httpexport const addRequestInterceptor = axios.interceptors.request.use.bind(axios.interceptors.request)// request前自動添加api配置addRequestInterceptor( (config) => { if (utils.getlocal(’token’)) { // 判斷是否存在token,如果存在的話,則每個http header都加上token config.headers.Authentication = utils.getlocal(’token’) } // config.url = `/api${config.url}` return config }, (error) => { return Promise.reject(error) }) export const addResponseInterceptor =axios.interceptors.response.use.bind(axios.interceptors.response)addResponseInterceptor( (response) => { // 在這里統(tǒng)一前置處理請求響應 if (Number(response.status) === 200) { // 全局notify有問題,還是自己處理吧 // return Promise.reject(response.data) // window.location.href = ’./’ // this.$router.push({ path: ’./’ }) } return Promise.resolve(response.data) }, (error) => { if (error.response) { const title = ’溫馨提示’; const content = ’<p>登錄過期請重新登錄</p>’ switch (error.response.status) { case 401: // 返回 401 跳轉到登錄頁面 Modal.error({ title: title, content: content, onOk: () => { localStorage.removeItem('lefthidden') localStorage.removeItem('leftlist') localStorage.removeItem('token') localStorage.removeItem('userInfo') localStorage.removeItem('headace') localStorage.removeItem('sideleft') utils.delCookie('user'); window.location.href = ’./’ } }) break } } return Promise.reject(error || ’出錯了’) })

4. time.js

// 常用的工具api const test = ’test’;const pre = ’pre’;const pro = ’pro’; export function judeType (param, typeString) { if (Object.prototype.toString.call(param) === typeString) return true; return false;}; export function isPrd () { return process.env.NODE_ENV === ’production’;}; export function getPrdType () { return ENV;}; export const ls = { put (key, value) { if (!key || !value) return; window.localStorage[key] = JSON.stringify(value); }, get (key) { if (!key) return null; const tem = window.localStorage[key]; if (!tem) return null; return JSON.parse(tem); }, // 設置cookie setCookie (key, value, time) { if (time) { let date = new Date(); date.setDate(date.getDate() + time); document.cookie = key + ’=’ + value + ’;expires=’ + date.toGMTString() + ’;path=/’; } else { document.cookie = key + ’=’ + value + ’;path=/’; } }, // 獲取cookie getCookie (key) { let array = document.cookie.split(’; ’); array.map(val => { let [valKey, value] = val.split(’=’); if (valKey === key) { return decodeURI(value); } }); return ’’; }}; /** * 判斷元素有沒有該class * @param {*} el * @param {*} className */ export function hasClass (el, className) { let reg = new RegExp(’(^|s)’ + className + ’(s|$)’); return reg.test(el.className);}/** * 為元素添加class * @param {*} el * @param {*} className */export function addClass (el, className) { if (hasClass(el, className)) return; let newClass = el.className.spilt(’ ’); newClass.push(className); el.className = newClass.join(’ ’);} export function removeClass (el, className) { if (!hasClass(el, className)) return; let reg = new RegExp(’(^|s)’ + className + ’(s|$)’, ’g’); el.className = el.className.replace(reg, ’ ’);} /** * 將數據存儲在標簽里 * @param {*} el * @param {*} name * @param {*} val */export function getData (el, name, val) { let prefix = ’data-’; if (val) { return el.setAttribute(prefix + name, val); } return el.getAttribute(prefix + name);} export function isIphone () { return window.navigator.appVersion.match(/iphone/gi);} /** * 計算元素和視窗的位置關系 * @param {*} el */export function getRect (el) { if (el instanceof window.SVGElement) { let rect = el.getBoundingClientRect(); return { top: rect.top, left: rect.left, width: rect.width, height: rect.height }; } else { return { top: el.offsetTop, left: el.offsetLeft, width: el.offsetWidth, height: el.offsetHeight }; }} /** * 獲取不確定數據的方法api * @param {Array} p 參數數組 * @param {Object} o 對象 */export function getIn (p, o) { return p.reduce(function (xs, x) { return (xs && xs[x]) ? xs[x] : null; }, o);} /** * 時間戳改為年月日格式時間 * @param {*} p 時間戳 */export function getTime (p) { let myDate = new Date(p); let year = myDate.getFullYear(); let month = myDate.getMonth() + 1; let date = myDate.getDate(); if (month >= 10) { month = ’’ + month; } else { month = ’0’ + month; } if (date >= 10) { date = ’’ + date; } else { date = ’0’ + date; } return year + ’-’ + month + ’-’ + date;} export function debounce (method, delay) { let timer = null; return function () { let context = this; let args = arguments; clearTimeout(timer); timer = setTimeout(function () { method.apply(context, args); }, delay); };}

5 utils.js

// 獲取cookie、export function getCookie (name) { if (document.cookie.length > 0){ let c_start = document.cookie.indexOf(name + ’=’) if (c_start != -1) { c_start = c_start + name.length + 1 let c_end = document.cookie.indexOf(’;’, c_start) if (c_end == -1) c_end = document.cookie.length return unescape(document.cookie.substring(c_start, c_end)) } } return ’’}// 設置cookie,增加到vue實例方便全局調用export function setCookie (cname, value, expiredays) { let exdate = new Date() exdate.setDate(exdate.getDate() + expiredays) document.cookie = cname + ’=’ + escape(value) + ((expiredays == null) ? ’’ : ’;expires=’ + exdate.toGMTString())}// 刪除cookieexport function delCookie (name) { let exp = new Date() exp.setTime(exp.getTime() - 1) let cval = getCookie(name) if (cval != null) { document.cookie = name + ’=’ + cval + ’;expires=’ + exp.toGMTString() }}// 設置localstorageexport function putlocal (key, value) { if (!key || !value) return window.localStorage[key] = JSON.stringify(value)}// 獲取localstorageexport function getlocal (key) { if (!key) return null const tem = window.localStorage[key] if (!tem) return null return JSON.parse(tem)}/** * use_iframe_download function - 通過 iframe 下載文件 * * @param {String} download_path 需下載文件的鏈接 * @return {Void} */export const use_iframe_download = download_path => { const $iframe = document.createElement(’iframe’) $iframe.style.height = ’0px’ $iframe.style.width = ’0px’ document.body.appendChild($iframe) $iframe.setAttribute(’src’, download_path) setTimeout(function () { $iframe.remove() }, 20000)} function requestTimeout (xhr) { const timer = setTimeout(() => { timer && clearTimeout(timer) xhr.abort() }, 5000) return timer}// 導出export function exporttable (httpUrl,token, formData, callback) {let i = formData.entries(); let param = '?Authentication='+token; do{ var v = i.next(); if(!v.done){ param+='&'+v.value[0]+'='+v.value[1]; } }while(!v.done);// console.log(param);window.open(httpUrl+param)// var xhr = new XMLHttpRequest()// if (xhr.withCredentials === undefined){ // return false// };// xhr.open('post', httpUrl)// // xhr.timeout=5000// xhr.setRequestHeader('Authentication', token)// xhr.responseType = 'blob'// let timer = requestTimeout(xhr)// xhr.onreadystatechange = function () {// timer && clearTimeout(timer)// if (xhr.readyState !== 4) {// timer = requestTimeout(xhr)// return// }// if (this.status === 200) {// var blob = this.response// var contentType = this.getResponseHeader(’content-type’)// var fileName = contentType.split(';')[1].split('=')[1]// fileName = decodeURI(fileName)// let aTag = document.createElement(’a’)// // 下載的文件名// aTag.download = fileName// aTag.href = URL.createObjectURL(blob)// aTag.click()// URL.revokeObjectURL(blob)callback && callback(true)// } else {// callback && callback(false)// } // }// xhr.send(formData);} // 獲取當前時間export function getNowFormatDate() { var date = new Date(); var seperator1 = '-'; var seperator2 = ':'; var month = date.getMonth() + 1; var strDate = date.getDate(); if (month >= 1 && month <= 9) { month = '0' + month; } if (strDate >= 0 && strDate <= 9) { strDate = '0' + strDate; } var currentdate = date.getFullYear() + seperator1 + month + seperator1 + strDate + ' ' + date.getHours() + seperator2 + date.getMinutes() + seperator2 + date.getSeconds(); return currentdate;} // 時間格式化export function formatDate(date, fmt) { if (/(y+)/.test(fmt)) { fmt = fmt.replace(RegExp.$1, (date.getFullYear() + ’’).substr(4 - RegExp.$1.length)); } let o = { ’M+’: date.getMonth() + 1, ’d+’: date.getDate(), ’h+’: date.getHours(), ’m+’: date.getMinutes(), ’s+’: date.getSeconds() }; for (let k in o) { if (new RegExp(`(${k})`).test(fmt)) { let str = o[k] + ’’; fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? str : padLeftZero(str)); } } return fmt;}; function padLeftZero(str) { return (’00’ + str).substr(str.length);}export default { getCookie, setCookie, delCookie, putlocal, getlocal, exporttable, getNowFormatDate, formatDate}

4.配置main.js

import Vue from ’vue’import App from ’./App’import router from ’./router’import VueRouter from ’vue-router’;import iView from ’iview’;import ’iview/dist/styles/iview.css’import http from ’./utils/http’import Api from ’./utils/api’import utils from ’./utils/utils’import ’./utils/filters’ Vue.config.productionTip = falseVue.use(VueRouter);Vue.use(iView); Vue.use(http)Vue.use(Api)Vue.use(utils)/* eslint-disable no-new */ global.BASE_URL = process.env.API_HOST new Vue({ el: ’#app’, router, components: { App }, template: ’<App/>’})

5.找到config文件夾下的dev.env.js

module.exports = merge(prodEnv, { NODE_ENV: ’'development'’, API_HOST: ’'開發(fā)環(huán)境接口地址'’})

6.頁面中具體使用方法

<template> <div class='hello'> <Select v-model='model8' clearable style='width:200px'> <Option v-for='item in cityList' :value='item.productCode' :key='item.productCode'>{{item.productName }}</Option> </Select> </div></template> <script>export default { name: ’HelloWorld’, data () { return { cityList:[], model8:'code' } }, mounted(){ this.http .post(BASE_URL + '請求路徑',{}) .then(data => { if (data.code == 'success') { this.cityList = data.data; this.cityList.splice(0,0,{ productCode: 'code', productName: '所有產品' }) } }) .catch(err => { console.log(err); }); }}</script><style scoped></style>

以上這篇vue接口請求加密實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本蜜桃在线观看视频| 久久久久观看| 麻豆mv在线观看| 丝袜美腿一区| 国产成人免费| 少妇精品导航| 久久国产高清| 国产探花一区在线观看| 欧美精品不卡| 亚洲欧洲高清| 亚洲欧洲另类| 国产乱码精品一区二区三区四区| 欧美aⅴ一区二区三区视频| 美女视频网站久久| 久久久精品久久久久久96 | 亚洲成人va| 色综合www| 日韩视频中文| 日韩不卡手机在线v区| 国产精品**亚洲精品| 成人午夜国产| 日本va欧美va瓶| yellow在线观看网址| 欧洲激情综合| 国产精品啊v在线| 日韩免费福利视频| 日韩制服丝袜av| 你懂的国产精品永久在线| 婷婷亚洲综合| 日韩av中文字幕一区| 日韩国产专区| 日本大胆欧美人术艺术动态| 久久香蕉精品香蕉| 狠狠色综合网| 精品日韩一区| 中文在线日韩| 欧美日韩精品一区二区视频| 欧美日韩一区二区高清| 久久精品高清| 国产精品亚洲二区| 日韩视频中文| 成人在线丰满少妇av| 最新国产精品| 四虎4545www国产精品| 国产欧美日韩| 午夜国产精品视频免费体验区| 国产麻豆一区二区三区| 国产精品日本| 日韩电影二区| 欧美91在线|欧美| 亚洲精品精选| 精品在线播放| 国产伦久视频在线观看| 日韩精品五月天| 亚洲一级二级| 精品一二三区| 日韩高清不卡一区| 美女少妇全过程你懂的久久| 久久久久久亚洲精品美女| 丝袜美腿亚洲色图| 久久精品五月| 97精品资源在线观看| 好看的亚洲午夜视频在线| 91亚洲一区| 国产精品v一区二区三区| 亚洲精品麻豆| 国产模特精品视频久久久久| 日韩一区二区三区在线免费观看| 国产精品久久久久久妇女| 热久久久久久久| 91精品国产91久久久久久黑人| 欧美精品97| 欧美在线黄色| 日本在线视频一区二区| 久久三级视频| 欧美激情国产在线| 国产欧美一区二区色老头| 亚洲精品黄色| 麻豆9191精品国产| 欧美午夜不卡| 欧美日韩视频一区二区三区| 久久久久国产一区二区| 国产欧洲在线| 成人午夜网址| 成人日韩av| 成人国产精选| 日韩电影在线视频| 久久久精品日韩| 神马日本精品| 久久五月天小说| 国产高清久久| 午夜国产欧美理论在线播放| 国产一区二区三区自拍| 亚洲欧美伊人| 亚洲欧洲一区二区天堂久久| 99国产精品久久久久久久成人热| 国产高清一区| 久久午夜视频| 日韩一区二区三免费高清在线观看 | 丝袜a∨在线一区二区三区不卡 | 国产精品久一| 欧美国产先锋| 91免费精品| 日韩欧美1区| 蜜桃成人av| 免费欧美在线视频| 91精品国产自产观看在线| 国产精品久久久久久久免费软件 | 亚洲91在线| 欧美精品国产| 国产一区二区三区四区五区 | 亚洲精品少妇| 国产一级成人av| 美女av一区| 成人羞羞在线观看网站| 尹人成人综合网| 日韩一区二区三区精品| 久久成人福利| 欧产日产国产精品视频| 夜夜嗨一区二区三区| 日韩免费精品| 特黄毛片在线观看| 亚洲一区不卡| 捆绑调教美女网站视频一区| 国产aa精品| 免费日本视频一区| 国产日本精品| 欧美日韩一二三四| 日韩精品91亚洲二区在线观看| 精品久久国产一区| 在线 亚洲欧美在线综合一区| 日韩手机在线| 国产91在线播放精品| 国产精品美女| 精品国产亚洲一区二区三区大结局| 久久久久美女| 911亚洲精品| 999国产精品永久免费视频app| 亚洲精品一区二区在线播放∴| 国产精品2区| 亚洲一区二区网站| 美女高潮久久久| 亚洲国产不卡| 久久不卡日韩美女| 中文一区二区| 免费一级欧美片在线观看网站| 日韩午夜电影| 国产一区精品福利| 亚洲一二三区视频| 久久久久午夜电影| 国产欧美日韩在线一区二区| 欧美不卡在线| 欧美xxxx中国| 久久国产乱子精品免费女| 日韩欧美一区二区三区在线视频 | 日韩欧美精品综合| 日韩精品福利一区二区三区| 999国产精品| 精品久久精品| 欧美一区在线观看视频| 婷婷色综合网| 吉吉日韩欧美| 国产精品videosex极品| 免费美女久久99| 九一国产精品| 狠狠久久伊人| 欧美日韩中文| 美女精品在线| 99精品一区| 成人污污视频| 国产精品亲子伦av一区二区三区| 亚洲网址在线观看| 亚洲深夜av| 91精品国产91久久久久久黑人| 久久爱www成人| 久久精品xxxxx| 亚洲精品极品| 欧美专区一区二区三区| 久久一区二区中文字幕| 中文在线а√在线8| 国产精品一区二区三区美女| 亚州精品视频| 快she精品国产999| 在线成人直播| 欧美日韩国产免费观看视频| 中文在线а√在线8| 精品72久久久久中文字幕| 国产欧美另类| 国产日韩欧美一区二区三区| 日韩精品1区2区3区| 亚洲精品女人| 一区二区高清| 视频一区视频二区在线观看| 亚洲大全视频| 黄色在线一区| 偷拍欧美精品| 欧美日韩视频| 国产一级久久| 久久国产高清| 免费人成在线不卡|