小程序开发使用Fly.js拦截器设置验签以后,参数传不进去

问题描述

最近在开发小程序,用到了fly.js,我们项目在网络请求的时候需要进行验签,需要把验签需要的结果像参数那样传到后台,废话不多说,上代码

//config.js

fly.interceptors.request.use((config,promise)=>{
  console.log(config)
  wx.showLoading({
    title: '加载中',
    mask:true
  })
  // Add custom headers
  // 验签 start
  let timestamp = (new Date()).valueOf();
  let AppId = 'axgyApi';
  let Sign_AES_KEY = 'zWNjxzko2h2GbmFaRHxs';
  let language = 'ZH_SIMP';
  let ak = md5(AppId + Sign_AES_KEY + timestamp);
  
  let authParams = {
    //公共参数
    // "categoryType": "SaleGoodsType@sim",
    // "streamNo": "wxapp153570682909641893",
    // "reqSource": "MALL_H5",
    // "appid": "string",
    // "timestamp": new Date().getTime(),
    "sign": "string"
  };

  config.body = {
    ...authParams
  }
  
  return config;
})

封装的方法

//index.js
let queryDonateProjectDetail = function (seq_uuid){
  return fly.get("xxx", { seq_uuid});
  }
let api = {
  queryDonateProjectDetail
}
export default api;

调用的地方

test:function(){
    var that = this;
    Api.queryDonateProjectDetail("6588f561-6321-470a-ad28-af00062a2b6d").then(res => {
      console.log(res.data)
    })
}

调用结果
在这里插入图片描述
发现我想要的参数并没有拼接到地址后面(get请求)
也是尝试啦各种办法,最哦吼得出结论是因为config.js里面设置config.body 的时候造成了覆盖,导致了参数传不进去,最后进行了修改

let body = { ...authParams,...config.body};
  config.body = body;
  //这里是把之前的body和现在想要穿进去的整合而不是覆盖掉

然后就愉快的解决啦

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值