求:有没有会 ant design pro v6 的

253 天前
 qingjiang

后端使用的 satoken ,每个请求都需要拿到 token 才能查询到数据

我在 app.ts 中配置了请求前拦截,但是返回的 token ,其他请求头部 Authorization 并没有拿到浏览器本地存的 token

/**
 * requestInterceptors 接收一个数组,数组的每一项为一个 request 拦截器。等同于 umi-request 的 request.interceptors.request.use() 。
 */
const authHeaderInterceptor = (url: string, options: RequestOptionsInit) => {
  console.log('authHeaderInterceptor url, options: ', url, options  );
  // 如果是登录页面,不需要添加 token
  if (url.indexOf('/login/') !== -1 || url.indexOf('/logout') !== -1) {
    return {
      url: `${url}`,
      options: { ...options, interceptors: true },
    };
  } else {
    const token = getToken();
    console.log('url, token: ', url, token);
    let authHeader = {};
    // 如果 token 存在,就添加到请求头
    if (localStorage.getItem('ADMIN_TOKEN')) {
      authHeader = { Authorization: `Bearer ${localStorage.getItem('ADMIN_TOKEN')}` };
    }

    return {
      url: `${url}`,
      options: { ...options, interceptors: true, headers: authHeader },
    };
  }
};


/**
 * requestInterceptors 接收一个数组,数组的每一项为一个 request 拦截器。等同于 umi-request 的 request.interceptors.request.use() 。
 */
const authHeaderInterceptor = (url: string, options: RequestConfig) => {
  console.log('authHeaderInterceptor url, options: ', url, options  );
  // 如果是登录页面,不需要添加 token
  if (url.indexOf('/login/') !== -1 || url.indexOf('/logout') !== -1) {
    return {
      url: `${url}`,
      options: { ...options, interceptors: true },
    };
  } else {
    const token = getToken();
    console.log('url, token: ', url, token);
    let authHeader = {};
    // 如果 token 存在,就添加到请求头
    if (localStorage.getItem('ADMIN_TOKEN')) {
      authHeader = { Authorization: `Bearer ${localStorage.getItem('ADMIN_TOKEN')}` };
    }

    return {
      url: `${url}`,
      options: { ...options, interceptors: true, headers: authHeader },
    };
  }
};

求解

885 次点击
所在节点    程序员
1 条回复
qingjiang
253 天前
我自己打自己脸了,接口请求路径是 /login/account ,之前是 /login
服了啥也不懂,突然悟了

const authHeaderInterceptor = (url: string, options: RequestConfig) => {
console.log('authHeaderInterceptor url, options: ', url, options );
console.log('url.indexOf: ',url.indexOf('/login/') +",", url.indexOf('/login/account'));
// 如果是登录页面,不需要添加 token

if (url.indexOf('/login/account') !== -1 || url.indexOf('/login/logout') !== -1) {
return {
url: `${url}`,
options: { ...options, interceptors: true },
};
} else {
const token = getToken();
console.log('url, token: ', url, token);
let authHeader = {};
// 如果 token 存在,就添加到请求头
if (token) {
authHeader = { Authorization: `Bearer ${token}` };
}

return {
url: `${url}`,
options: { ...options, interceptors: true, headers: authHeader },
};
}
};

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1023423

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX