- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在构建一个使用 True Layer 开放式银行 API 的网络应用程序。该应用程序有一个使用 React 路由器的 React 前端和一个 Express 和 Nodejs 后端。目前我正在使用 react build
脚本来提供静态文件:
const app = express();
app.use(cors());
app.use(express.json());
app.use(express.static('../client/build'));
app.get('*', (req, res) => {
res.sendFile('index.html', {root: path.join(__dirname, '../client/build/')});
});
const PORT = process.env.PORT || 3001;
app.listen(PORT, () => {
console.log("Server listening on port: ", PORT);
});
// The API routes are imported below
此解决方案运行良好,但当用户被重定向到 True Layer 的身份验证页面时,会生成一个 OAuth 代码并将其作为 url 查询传递回客户端上的路由。问题是,当 True Layer 将用户重定向回我的应用程序时,url 由服务器解释,而不是 react 路由器/浏览器,因此它返回 cannot GET/myAccounts
。我研究过使用像 Next.js 这样的库为 React 客户端使用服务器端渲染,但我想知道是否有一种方法可以做到这一点而不必显着重构我的代码。
我的 React 路由器设置:
class App extends Component {
render() {
return (
<Router>
<Route name="Landing" path="/" exact component={Login} />
<Route name="Login" path="/login" exact component={Login} />
<Route name="MyAccounts" path="/myAccounts" exact component={Home} />
</Router>
);
}
}
/myAccounts
路由呈现 Home
组件/页面,其中提取了 code
参数:qs.parse(props. location.search)['?code']
,并发送到我的服务器以完成 OAuth 过程。
如有任何帮助,我们将不胜感激。
最佳答案
The issue is that when True Layer redirect the user back to my app the url is interpreted by the server and not the react router/browser so it returns cannot GET /myAccounts
发生的事情是:
路径 /myAccounts
是 React SPA 的内部路径,它显示由 MyAccounts
组件呈现的内部 SPA 页面。网络服务器不知道此页面并返回“无法获取/myAccounts”。此网络服务器行为不正确不是因为网络服务器不支持 True Layer/OAuth,而是因为网络服务器没有正确支持 SPA。
应该发生什么:
网络服务器应该通过实现回退行为来支持 SPA,这只是意味着服务器将对未知页面的请求重定向到 SPA 登录页面。例如,使用 historyApiFallback
在 webpack-dev-server 中启用此行为它专门用于支持 SPA。
任何 SPA 都需要回退行为,因为用户可以在导航栏中看到任何内部页面的路径,并且可以手动重新键入并按 Enter 或刷新浏览器。在这两种情况下,网络服务器都收到了对它不知道的内部 SPA 页面的请求,并且以 404 错误响应对用户来说看起来不太好。
在 Express 中实现后备后,您可以将一段数据添加到被重定向到着陆页的请求中。这样您的 Landing
组件就会看到这个可选部分并在内部(网络服务器不知道)重定向到 MyAccounts
组件。
关于javascript - 如何处理客户端 React 应用程序的外部重定向?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58701717/
我正在尝试使用谷歌浏览器的 Trace Event Profiling Tool分析我正在运行的 Node.js 应用程序。选择点样本后,我可以在三种 View 之间进行选择: 自上而下(树) 自上而
对于一个可能是菜鸟的问题,我们深表歉意,但尽管在 SO 上研究了大量教程和其他问题,但仍找不到答案。 我想做的很简单:显示一个包含大量数据库存储字符串的 Android ListView。我所说的“很
我已经开始了一个新元素的工作,并决定给 Foundation 5 一个 bash,看看它是什么样的。在创建带有水平字段的表单时,我在文档中注意到的第一件事是它们使用大量 div 来设置样式。所以我在下
我有一个 Windows 窗体用户控件,其中包含一个使用 BeginInvoke 委托(delegate)调用从单独线程更新的第 3 方图像显示控件。 在繁重的 CPU 负载下,UI 会锁定。当我附加
我有一堆严重依赖dom元素的JS代码。我目前使用的测试解决方案依赖于 Selenium ,但 AFAIK 无法正确评估 js 错误(addScript 错误不会导致您的测试失败,而 getEval 会
我正在制作一款基于滚动 2D map /图 block 的游戏。每个图 block (存储为图 block [21][11] - 每个 map 总共 231 个图 block )最多可以包含 21 个
考虑到以下情况,我是前端初学者: 某个 HTML 页面应该包含一个沉重的图像(例如 - 动画 gif),但我不想强制客户缓慢地等待它完全下载才能享受一个漂亮的页面,而是我更愿意给他看一个轻量级图像(例
我正在设计一个小软件,其中包括: 在互联网上获取资源, 一些用户交互(资源的快速编辑), 一些处理。 我想使用许多资源(它们都列在列表中)来这样做。每个都独立于其他。由于编辑部分很累,我想让用户(可能
我想比较两个理论场景。为了问题的目的,我简化了案例。但基本上它是您典型的生产者消费者场景。 (我关注的是消费者)。 我有一个很大的Queue dataQueue我必须将其传输给多个客户端。 那么让我们
我有一个二元分类问题,标签 0 和 1(少数)存在巨大不平衡。由于测试集带有标签 1 的行太少,因此我将训练测试设置为至少 70-30 或 60-40,因此仍然有重要的观察结果。由于我没有过多地衡量准
我是一名优秀的程序员,十分优秀!