request.js 5.01 KB
/*
 * @Date: 2022-09-19 14:11:06
 * @LastEditors: hookehuyr hookehuyr@gmail.com
 * @LastEditTime: 2025-09-01 13:47:06
 * @FilePath: /lls_program/src/utils/request.js
 * @Description: 简单axios封装,后续按实际处理
 */
// import axios from 'axios'
import axios from 'axios-miniprogram';
import Taro from '@tarojs/taro'
// import { strExist } from './tools'
// import qs from 'Qs'
import { routerStore } from '@/stores/router'

// import { ProgressStart, ProgressEnd } from '@/components/axios-progress/progress';
// import store from '@/store'
// import { getToken } from '@/utils/auth'
import BASE_URL from './config';

/**
 * 获取sessionid的工具函数
 * @returns {string|null} sessionid或null
 */
const getSessionId = () => {
  try {
    return wx.getStorageSync("sessionid") || null;
  } catch (error) {
    console.error('获取sessionid失败:', error);
    return null;
  }
};

/**
 * 设置sessionid的工具函数
 * @param {string} sessionid - 要设置的sessionid
 */
const setSessionId = (sessionid) => {
  try {
    wx.setStorageSync("sessionid", sessionid);
  } catch (error) {
    console.error('设置sessionid失败:', error);
  }
};

/**
 * 清除sessionid的工具函数
 */
const clearSessionId = () => {
  try {
    wx.removeStorageSync("sessionid");
  } catch (error) {
    console.error('清除sessionid失败:', error);
  }
};
// create an axios instance
const service = axios.create({
  baseURL: BASE_URL, // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000, // request timeout
})

service.defaults.params = {
  f: 'walk',
};

// request interceptor
service.interceptors.request.use(
  config => {
    // console.warn(config)
    // console.warn(store)

    /**
     * 动态获取sessionid并设置到请求头
     * 确保每个请求都带上最新的sessionid
     */
    const sessionid = getSessionId();
    if (sessionid) {
      config.headers.cookie = sessionid;
    }

    /**
     * POST PHP需要修改数据格式
     * 序列化POST请求时需要屏蔽上传相关接口,上传相关接口序列化后报错
     */
    // config.data = config.method === 'post' && !strExist(['a=upload', 'upload.qiniup.com'], config.url) ? qs.stringify(config.data) : config.data;
    return config
  },
  error => {
    // do something with request error
    console.error(error, 'err') // for debug
    return Promise.reject(error)
  }
)

// response interceptor
service.interceptors.response.use(
  /**
   * If you want to get http information such as headers or status
   * Please return  response => response
   */

  /**
   * Determine the request status by custom code
   * Here is just an example
   * You can also judge the status by HTTP Status Code
   */
  response => {
    /**
     * 检查响应头中是否有新的sessionid
     * 如果有,则更新本地存储
     */
    const setCookieHeader = response.headers['set-cookie'];
    if (setCookieHeader) {
      // 解析set-cookie头,提取sessionid
      const sessionidMatch = setCookieHeader.match(/sessionid=([^;]+)/);
      if (sessionidMatch && sessionidMatch[1]) {
        setSessionId(sessionidMatch[1]);
      }
    }

    // wx.hideLoading();
    // const res = response.data
    // // Toast.clear();
    // // if the custom code is not 20000, it is judged as an error.
    // if (res.code !== 100000) {
    //   // 50008: Illegal token; 50012: Other clients logged in; 50014: Token expired;
    //   if (res.code === 50008 || res.code === 50012 || res.code === 50014) {
    //     // to re-login
    //     // Toast.confirm('You have been logged out, you can cancel to stay on this page, or log in again', 'Confirm logout', {
    //     //     confirmButtonText: 'Re-Login',
    //     //     cancelButtonText: 'Cancel',
    //     //     type: 'warning'
    //     // }).then(() => {
    //     //     // store.dispatch('user/resetToken').then(() => {
    //     //     //     location.reload()
    //     //     // })
    //     // })
    //   } else {
    //     // Toast.fail({
    //     //   message: res.message,
    //     //   duration: 1.5 * 1000
    //     // })
    //     // Tips.error(res.message, false)
    //   }
    //   return Promise.reject(new Error(res.message || 'Error'))
    // } else {
    //   return res
    // }

    /**
     * 处理401未授权状态
     * 清除本地sessionid并跳转到登录页
     */
    if (response.data.code === 401) {
      // 清除无效的sessionid
      clearSessionId();
      /**
       * 未授权跳转登录页
       * 授权完成后 返回当前页面
       */
      setTimeout(() => {
        Taro.navigateTo({
          url: '/pages/auth/index?url=' + routerStore().url
        });
      }, 1000);
    }
    return response
  },
  error => {
    // Toast.clear();
    console.error('err' + error) // for debug
    // Toast.fail({
    //   message: error.message,
    //   duration: 1.5 * 1000
    // })
    return Promise.reject(error)
  }
)

// 导出sessionid管理工具函数
export { getSessionId, setSessionId, clearSessionId };

export default service