【发布时间】:2020-11-28 06:32:43
【问题描述】:
我正在为我的应用程序构建身份验证,并且正在使用访问和刷新令牌。
用户登录后,API 发出 3 件事
- 刷新令牌
- 访问带有标头和有效负载的令牌字符串
- 访问带有签名的令牌字符串
这些令牌都是jwt 令牌。
This 文章讨论了为什么应该拆分访问令牌。
使用 express,我将令牌发送回控制器中的浏览器,如下所示:
res.cookie(
ACCESS_TOKEN_COOKIE_HEADER_PAYLOAD,
headerAndPayload,
COOKIE_OPTIONS,
)
res.cookie(
ACCESS_TOKEN_COOKIE_SIGNATURE,
signature,
COOKIE_OPTIONS_HTTP_ONLY,
)
res.cookie(REFRESH_TOKEN_COOKIE, refreshToken, COOKIE_OPTIONS)
return res.json({ username, uid })
auth.constants.ts
export const COOKIE_OPTIONS: CookieOptions = {
secure: true,
sameSite: 'lax',
}
export const COOKIE_OPTIONS_HTTP_ONLY: CookieOptions = {
httpOnly: true,
secure: true,
sameSite: 'lax',
}
export const ACCESS_TOKEN_COOKIE_HEADER_PAYLOAD = 'access_token_header_payload'
export const ACCESS_TOKEN_COOKIE_SIGNATURE = 'access_token_signature'
export const REFRESH_TOKEN_COOKIE = 'refresh_token'
在 ui (react) 中,我进入 Chrome devtools -> application -> storage -> cookeis,我可以看到每次登录时它们都会更新。这是我想要的行为,所以到目前为止还不错。
现在,当我想向我的 API 发送请求以创建某些内容时(假设我正在创建一篇新的博客文章),我想获取这些 cookie 并将它们作为 Authorization Header 传递。
我遵循this 人的建议,但我注意到他正在使用store,我猜这是某种形式的状态。由于我没有这样做,并且多个来源(source 1、source 2)指出将令牌发送到 API 以进行身份验证的标准是使用 Authorization 标头,我想遵循这一点。
目前,当我使用 axios 发出 API 请求时,我会在控制台记录 express request 对象,并且可以在 cookie 中看到我的令牌,如下所示:
headers: {
host: 'localhost:3001',
connection: 'keep-alive',
'content-length': '0',
accept: 'application/json, text/plain, */*',
'user-agent': 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.105 Safari/537.36',
origin: 'http://localhost:3000',
'sec-fetch-site': 'same-site',
'sec-fetch-mode': 'cors',
'sec-fetch-dest': 'empty',
referer: 'http://localhost:3000/',
'accept-encoding': 'gzip, deflate, br',
'accept-language': 'en-US,en;q=0.9',
cookie: 'access_token_header_payload=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6InJvc3R5cG9vIiwiaWF0IjoxNTk2ODM0MDIwLCJleHAiOjE1OTY4MzQwODB9; access_token_signature=3pUbxjWgly9xmYSJObOvTgps9qwjOIrHWWE4LPYidmQ; refresh_token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6InJvc3R5cG9vIiwiaWF0IjoxNTk2ODM0MDIwLCJleHAiOjE1OTc0Mzg4MjB9.IKdRsaTTgAeUfwicLcBpRvw89WgYXy_rCRN5o2BJFqY'
},
但我想将这些 cookie 发送为 Authorization: Bearer <tokens>。我将如何在 axios 中做到这一点?或者我在做什么安全?
这是我的 axios 拦截器
import axios from 'axios'
const service = axios.create({
withCredentials: true,
baseURL: process.env.REACT_APP_API_BASE_URL,
timeout: 5000,
})
// Request interceptors
service.interceptors.request.use(
config => {
return config
},
error => {
return Promise.reject(error)
},
)
// Response interceptors
service.interceptors.response.use(
response => {
console.log('response', response)
return response.data
},
error => {
return Promise.reject({ ...error })
},
)
export default service
【问题讨论】:
标签: reactjs cookies axios jwt http-headers