- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个简单的 React 应用程序,它使用第三个 API 来获取数据。在发出任何请求之前,必须检索 token 以便在 header 中使用它。此 token 是通过传递客户端 ID 和 secret ID 使用相同的 API 创建的 - API 是 Artsy API。此 token 有一个到期日期,因此如果 token 不存在,则必须请求此 API。拿到token之后,我就可以毫无问题的调用其他请求了。
我已经在单独的文件中设置了 API 请求,如下所示:API.js
import Axios from 'axios';
const baseURL = 'https://api.artsy.net/api';
// set up xap-token and set tot default headers
const instance = Axios.create({
baseURL: baseURL + '/tokens/xapp_token',
params: {
'client_id': process.env.CLIENTID,
'client_secret': process.env.CLIENTSECRET
}
});
instance.interceptors.request.use(undefined, err => {
const status = err.response ? err.response.status : null;
console.log("auth",err.response)
if(status === 401){
console.log("auth",err.response)
return 'hello'
// this.getAuthToken();
}
});
export default{
getArtworks: function(){
return new Promise((resolve, reject) => {
instance.get(baseURL + '/artworks')
.then(res => {
resolve(res)
})
.catch(err => {
reject(err);
});
});
},
getArtists: function(){
return new Promise((resolve, reject) => {
instance.get(baseURL + '/artists')
.then(res => {
resolve(res)
})
.catch(err => {
reject(err);
});
});
},
getTest: function(){
return 'hello';
}
};
不太确定如何使用 create
和 interceptors
,但我创建了一个 Axios 实例。因此,我们的想法是创建某种中间件,创建一个实例,然后在有针对该错误的请求时将其用作拦截器。如果存在,则将 token 应用于该实例并继续请求,重试
。也不确定如何在实例中设置 token 。
到目前为止,我在 getArtists
方法中遇到了一个 401 错误,这个 api 在页面加载时被调用,它在 componentDidMount
下。
应用程序.jsx
import React, { Component } from 'react';
import Apis from './utils/Api';
import Gallery from './components/Gallery';
class App extends Component{
constructor(props){
super(props);
this.state = {
artWorks: []
}
}
componentDidMount = () => {
// Apis.getArtists();
Apis.getArtists().then(res => {
console.log(res)
// this.setState({
// artWorks: res.data
// })
});
}
render(){
return(
<div>
<Gallery artists={this.state.artWorks}/>
</div>
)
}
}
export default App;
这是 api用于身份验证的文档链接。
有人可以帮忙吗?不确定如何将实例用作“中间件”? Axios 的新手。我想避免使用 3rd 库中间件,我更喜欢手动学习而不是使用 3rd 库。非常感谢您的帮助
更新:
我能够让这个有点工作,我修改了 instance.interceptor
:
instance.interceptors.response.use(undefined, err => {
const status = err.response ? err.response.status : null;
if(status === 401){
console.log("auth",err.response)
instance.post(err.config.authURL, err.config.auth).then(res => {
let token = res.data.token;
err.config.headers['X-XAPP-Token'] = token;
console.log('calling',err.response)
return instance.request(err.config)
});
}
// return Promise.reject(err);
});
但是我在 getArtists
响应中变得不确定。不确定这里发生了什么。这是控制台的屏幕截图:
最佳答案
您应该使用 instance.interceptors.response
而不是 instance.interceptors.request
。
因为请求拦截器在 Ajax 请求发送之前被调用。我认为响应拦截器实际上是您想要的。
const instance = Axios.create({
baseURL: 'https://api.artsy.net/api'
})
// because you set the baseURL of the instance
// this will request url https://api.artsy.net/api/artworks
instance.get('/artworks')
instance.post('tokens/xapp_token').then(res => {
/* here is the response
{
"type" : "xapp_token",
"token" : "...",
"expires_at" : "2014-09-05T12:39:09.200Z"
}
*/
// you can set common request headers like this
// or use request interceptors here to set headers
// then every request you sent by instance after will have X-XAPP-Token header
instance.defaults.headers.common['X-XAPP-Token'] = res.token
})
其实err.config.headers['X-XAPP-Token'] = token;
这段代码不会影响请求头。
关于reactjs - Axios - 拦截器无法处理请求错误 - 401 代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56333196/
我尝试理解[c代码 -> 汇编]代码 void node::Check( data & _data1, vector& _data2) { -> push ebp -> mov ebp,esp ->
我需要在当前表单(代码)的上下文中运行文本文件中的代码。其中一项要求是让代码创建新控件并将其添加到当前窗体。 例如,在Form1.cs中: using System.Windows.Forms; ..
我有此 C++ 代码并将其转换为 C# (.net Framework 4) 代码。有没有人给我一些关于 malloc、free 和 sprintf 方法的提示? int monate = ee; d
我的网络服务器代码有问题 #include #include #include #include #include #include #include int
给定以下 html 代码,将列表中的第三个元素(即“美丽”一词)以斜体显示的 CSS 代码是什么?当然,我可以给这个元素一个 id 或一个 class,但 html 代码必须保持不变。谢谢
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
我试图制作一个宏来避免重复代码和注释。 我试过这个: #define GrowOnPage(any Page, any Component) Component.Width := Page.Surfa
我正在尝试将我的旧 C++ 代码“翻译”成头条新闻所暗示的 C# 代码。问题是我是 C# 中的新手,并不是所有的东西都像 C++ 中那样。在 C++ 中这些解决方案运行良好,但在 C# 中只是不能。我
在 Windows 10 上工作,R 语言的格式化程序似乎没有在 Visual Studio Code 中完成它的工作。我试过R support for Visual Studio Code和 R-T
我正在处理一些报告(计数),我必须获取不同参数的计数。非常简单但乏味。 一个参数的示例查询: qCountsEmployee = ( "select count(*) from %s wher
最近几天我尝试从 d00m 调试网络错误。我开始用尽想法/线索,我希望其他 SO 用户拥有可能有用的宝贵经验。我希望能够提供所有相关信息,但我个人无法控制服务器环境。 整个事情始于用户注意到我们应用程
我有一个 app.js 文件,其中包含如下 dojo amd 模式代码: require(["dojo/dom", ..], function(dom){ dom.byId('someId').i
我对“-gencode”语句中的“code=sm_X”选项有点困惑。 一个例子:NVCC 编译器选项有什么作用 -gencode arch=compute_13,code=sm_13 嵌入库中? 只有
我为我的表格使用 X-editable 框架。 但是我有一些问题。 $(document).ready(function() { $('.access').editable({
我一直在通过本教程学习 flask/python http://blog.miguelgrinberg.com/post/the-flask-mega-tutorial-part-i-hello-wo
我想将 Vim 和 EMACS 用于 CNC、G 代码和 M 代码。 Vim 或 EMACS 是否有任何语法或模式来处理这种类型的代码? 最佳答案 一些快速搜索使我找到了 this vim 和 thi
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve this
这个问题在这里已经有了答案: Enabling markdown highlighting in Vim (5 个回答) 6年前关闭。 当我在 Vim 中编辑包含 Markdown 代码的 READM
我正在 Swift3 iOS 中开发视频应用程序。基本上我必须将视频 Assets 和音频与淡入淡出效果合并为一个并将其保存到 iPhone 画廊。为此,我使用以下方法: private func d
pipeline { agent any stages { stage('Build') { steps { e
我是一名优秀的程序员,十分优秀!