首页 > 其他分享 >浙里办通用请求的封装

浙里办通用请求的封装

时间:2023-03-05 18:48:22浏览次数:53  
标签:封装 浙里 err res token const noload data 请求

开发浙里办应用都知道,我们发布到线上的接口需要按这样的方式去请求:

但是往往本地开发的时候是连得公司测试环境,而且接口调用方式也不长这样。我第一次开发浙里办项目的时候并没有注意到这个问题,本地调完了,才看到线上的请求方式不一样,当时着急上线,就来回修改,浪费了很多时间。。。

后来我整理下,如果本地联调的时候接口传参和线上传参一样,发布线上只需切换下判断参数,那不是就不用来回调整了。于是现在的请求是这样的:

request.js

import Vue from 'vue';
import axios from "axios";
import router from "../router/index";
import errorMsg from "./error"; // 错误提示
import envUrls from '@/core/envChange' // 定义一些基础变量的文件
import urls from '@/core/interfaceUrls' // 本地接口和浙里办注册接口的对应关系
import { mgop } from "@aligov/jssdk-mgop"; // 加载浙里办 mgop依赖
import { Toast, Notify } from 'vant';
Vue.use(Toast, Notify);

let httpServer = null

// create an axios instance
const service = axios.create({
  baseURL: envUrls.BASE_URL,
  timeout: 50000,
  headers: {
    "Content-Type": "application/json"
  }
});

// request interceptor
service.interceptors.request.use(
  config => {
    // 获取设置接口token  根据自己场景添加
    const token = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
    config.headers["X-Gisq-Token"] = `Bearer ${token}`;
    return config;
  },
  error => {
    // do something with request error
    console.log(error);
    return Promise.reject(error);
  }
);
// response interceptor
service.interceptors.response.use(
  response => {
    const res = response.data;
    if (res.code && res.code !== 200 || response.status !== 200) {
      Notify({
        type: 'danger',
        duration: 5 * 1000,
        message: res.message || "Error"
      });
      return Promise.reject(new Error(res.message || "Error"));
    } else {
      return res;
    }
  },
  error => {
    if (error && error.response) {
      const msg = errorMsg(error.response);
      Notify({
        type: 'danger',
        duration: 5 * 1000,
        message: msg
      });
      if (error.response.status === 401) {
        router.replace("/Login");
        sessionStorage.clear();
      }
    }
    if (error && error.message === "Network Error") {
      router.replace("/Login");
      sessionStorage.clear();
    }
    return Promise.reject(error);
  }
);

// 接口报错处理
const checkMgopFail = function (err) {
  if (err.code === 1) {
    Toast(err.message)
  } else if (err.errorMessage) {
    Toast(err.errorMessage)
  } else if (err.data && !Object.keys(err.data).length) {
    console.log('报错接口--------', err.api);
    err.ret.length && Toast(err.ret[0]) || Toast('请求失败,请稍后重试')
  }
}

// 获取浙里办接口地址处理
const setUrl = function (url) {
  if (url.indexOf('?') !== -1) {
    return url.split('?')[0]
  } else {
    return url
  }
}
// 处理拼接参数
const _paramify = function (obj) {
  var str = "";
  for (var key in obj) {
    if (str !== "") {
      str += "&";
    }
    str += key + "=" + obj[key];
  }
  return str;
};

// 本地联调时 
// noload 不要loading效果 为true 即不需要loading, false或者不存在(默认) 需要loading
class baseServer {
  mgopGET(url, params, options, noload) {
    params = params || {};
    params.ts = new Date().getTime();
    options = options || {};
    options.method = "GET";
    options.url = url;
    options.params = params;
    let toast = null
    if (!noload) {
      toast = Toast.loading({
        message: '加载中...',
        forbidClick: true,
        duration: 0
      });
    }
    return service.request(options).then(res => {
      if (res) {
        !noload && toast.clear() || ''
        return res
      }
    }).catch(err => {
      !noload && toast.clear() || ''
      console.log('err', err);
    })
  }
  mgopPOST(url, data, options, noload, isQuery) {
    // isQuery 是否是query方式传参
    // 如果不是Data包裹的 即通过地址栏传值
    if (isQuery) {
      const getParams = _paramify(data);
      url += `?${getParams}`;
    }
    options = options || {};
    options.method = "POST";
    options.url = url;
    options.data = data;
    let toast = null
    if (!noload) {
      toast = Toast.loading({
        message: '加载中...',
        forbidClick: true,
        duration: 0
      });
    }
    return service.request(options).then(res => {
      if (res) {
        !noload && toast.clear() || ''
        return res
      }
    }).catch(err => {
      !noload && toast.clear() || ''
      console.log('err', err);
    })
  }
}
// 线上联调时(浙里办环境 需要 mgop 方式调用)
class mgopServer {
  mgopGET = (url, data = {}, extra = {}, noload) => {
    let toast = null
    if (!noload) {
      toast = Toast.loading({
        message: '加载中...',
        forbidClick: true,
        duration: 0
      });
    }
    const promise = new Promise((resolve, reject) => {
      const params = {
        api: urls[setUrl(url)],
        host: "https://mapi.zjzwfw.gov.cn/",
        dataType: "JSON",
        type: "GET",
        appKey: envUrls.APPKEY,
        data: data,
        ...extra
      };
      if (extra.headers) params.header = extra.headers;
      else {
        const token = sessionStorage.getItem("access_token")
        params.header = {
          Authorization: token ? `bearer ${token}` : '',
          "token": token ? `Bearer ${token}` : '',
          "X-Gisq-Token-QYDM": "33"
        }
      }
      mgop({
        ...params,
        onSuccess: res => {
          console.log('------GET响应------', res);
          !noload && toast.clear() || ''
          if (res.data) {
            resolve(res.data);
          } else {
            reject();
          }
        },
        onFail: err => {
          !noload && toast.clear() || ''
          console.log(err, '错误返回');
          checkMgopFail(err)
          reject();
        }
      });
    });
    return promise;
  };
  mgopPOST(url, data = {}, extra = {}, noload) {
    let toast = null
    if (!noload) {
      toast = Toast.loading({
        message: '加载中...',
        forbidClick: true,
        duration: 0
      });
    }
    const promise = new Promise((resolve, reject) => {
      const params = {
        api: urls[setUrl(url)],
        host: "https://mapi.zjzwfw.gov.cn/",
        dataType: "JSON",
        type: "POST",
        appKey: envUrls.APPKEY,
        data: data,
        ...extra
      };
      if (extra.headers) {
        params.header = extra.headers;
      }
      else {
        const token = sessionStorage.getItem("access_token")
        params.header = {
          Authorization: token ? `bearer ${token}` : '',
          "token": token ? `Bearer ${token}` : '',
          "X-Gisq-Token-QYDM": "33"
        }
      }
      mgop({
        ...params,
        onSuccess: res => {
          console.log('------POST响应------', res);
          !noload && toast.clear() || ''
          if (res.data) {
            resolve(res.data);
          } else {
            reject();
          }
        },
        onFail: err => {
          !noload && toast.clear() || ''
          console.log(err, '错误返回');
          checkMgopFail(err)
          reject();
        }
      });
    });
    return promise;
  }
}
// 判断是否是浙里办环境 走不同类型的接口                                                                                                                                                                                                                                                                                                                                                
if (!envUrls.IS_ZLB) {
  httpServer = new baseServer()
} else {
  httpServer = new mgopServer()
}

export default httpServer;

main.js:

import http from '@/service/request'
Vue.prototype.$http = http

interfaceUrls.js:

const urls = {
  '本地接口地址': '浙里办对应接口地址'
}
export default urls

此文件放的接口的对应关系。“本地接口地址”即除了baseURL外后面的地址(不包含传参部分),“浙里办对应接口地址”对应如图“API名称”处的地址:

使用:

配置文件里的 IS_ZLB: true,如果本地联调,置为 false 即可,如果接口都在RIS已注册好了,也可以本地切换到线上地址进行联调,置为 true 即可。

const params = {}
this.$http.mgopPOST('/xxx/xxx/xxxx/xxxx', params).then().catch()

标签:封装,浙里,err,res,token,const,noload,data,请求
From: https://www.cnblogs.com/shiyi-iiii/p/17174872.html

相关文章

  • ES6-ES11 Promise封装读取文件
    原视频//1.引入fs模块constfs=require('fs');//2.调用方法读取文件//fs.readFile('./resources/为学.md',(err,data)=>{////如果失败,则抛出错误//......
  • ES6-ES11 Promise封装AJAX
    原视频<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><titl......
  • 百度、cnzz、piwik 统计ajax请求方法
    百度统计:<scripttype="text/javascript">$('area').click(function(){//目标urlvarbaiduStatUrl=$(this).attr('href').replace('http://','......
  • 已拦截跨源请求:同源策略禁止读取位于 http:// 的远程资源。(原因:CORS 头缺少 'Access-C
    这个报错提示是因为在同源策略下,JavaScript代码试图跨域访问另一个源(例如不同的域名、协议或端口)的资源,而服务器未设置CORS头部信息。同源策略是一个重要的安全特性,用于保......
  • tailwindcss_封装
    /admin-one-vue-tailwind-master/index.html<!DOCTYPEhtml><htmllang="zh"><head><metacharset="utf-8"><metahttp-equiv="X-UA-Compatible"content="IE=ed......
  • 异步请求、批量处理、持续写入
    importgrequestsimportpandasaspdimporttimeall_start=time.time()sentence_list=[]#存储相似句子对df=pd.read_csv("new_clean.csv")all_sentence_......
  • 【故障公告】攻击式巨量并发请求再次来袭,引发博客站点故障
    继周五18:40-18:55左右首次来袭,今天11:10-12:10左右,来路不明的攻击式巨量并发请求再次袭击园子,而且攻势更猛,单台负载均衡最高QPS超过4万。这种前所未遇的超日常百倍......
  • Flask请求上下文
    Flask请求上下文#说实话,当时看完视频知道怎么回事。就是容易忘.....#不过总不能一直看视频对吧,尽快理解和掌握吧....惭愧啊预备知识1.werkzeug当我们下载flask模......
  • php curl 批量请求
    实例:<?php$ch=array();$res=array();$conn=array();$urls=array('baidu'=>"http://www.baidu.com/",'cheyun'=>"http://auto.jrj.com.cn/",'w3c'=......
  • php curl 请求302跳转页面
    若请求url已改变且设置了自动跳转,可通过设置CURLOPT_FOLLOWLOCATION参数实现自动请求跳转链接。若要手动判断是否跳转,可通过curl_getinfo($ch)方法获取具体请求信息,其中......