如何跳过或跳转中间件? (节点)
How to skip or jump middleware? (node)
给定两个中间件,您如何添加会先被命中的东西,然后确定将请求传递到哪个中间件。请求只能被丢弃或转发到其中一个中间件,而不能两者都。
app.use( function *(next) {
if (isAuthenticated)
*private middleware*
else
*use public middleware*
});
更具体地说:
我有一个主页 /
,它应该有一个可变的响应,具体取决于用户是否登录(此处使用基于令牌的身份验证)。为简单起见,如果请求用户没有令牌,则 public.html
是响应,而 private.html
请求带有有效令牌。
现在这很容易在一个函数中实现,但我希望有单独的路由器,这样可以使代码更易于管理。
所以我需要以某种方式能够 选择 请求转到哪个中间件路由器?不知道该怎么做。
var publicR = new router();
publicR.get('/', function *(next) {
....public.html....
});
var privateR = new router();
privateR.get('/', function *(next) {
....private.html....
});
app.use(function(){
if(isAuthenticated)
...use privateR.routes();
else
...use publicR.routes();
});
万一其他人遇到这个问题,这对我有用:
var publicR = new router();
publicR.get('/', function *(next) {
....public.html....
});
var privateR = new router();
privateR.get('/', function *(next) {
....private.html....
});
app.use(mySwitcher);
function *mySwitcher(next){
if(isAuthenticated)
yield privateR.routes().call(this,next);
else
yield publicR.routes().call(this,next);
}
首先,在登录或未登录时为给定 URL 呈现完全不同的内容是不寻常的,而且确实不是一个好主意。因此,尝试让两个不同的路由器都提供相同的服务路由,但一个用于登录用户,另一个用于未登录用户可能不是一个好的设计理念。
更常见的情况是页面的一部分在登录时可能会有所不同。在这种情况下,您有一个创建页面的路由,用于处理与登录时的内容略有不同的内容或没有。
如果您真的想在登录时拥有完全不同的内容和行为,那么您应该在登录时重定向到不同的 URL。在这种情况下,您可以使用完全不同的路由器"logged in" URLs。这对于搜索引擎也将更好地工作,因为给定的 URL 将报告一致的内容,并且不会因用户的状态而有所不同。这也使得在 Express 中使用路由器变得非常容易。您的 "logged in" 路由器为登录的 URL 提供服务。您可以使用中间件检查登录 URL 以查看您是否实际登录,如果没有,则重定向回未登录页面,反之亦然。
给定两个中间件,您如何添加会先被命中的东西,然后确定将请求传递到哪个中间件。请求只能被丢弃或转发到其中一个中间件,而不能两者都。
app.use( function *(next) {
if (isAuthenticated)
*private middleware*
else
*use public middleware*
});
更具体地说:
我有一个主页 /
,它应该有一个可变的响应,具体取决于用户是否登录(此处使用基于令牌的身份验证)。为简单起见,如果请求用户没有令牌,则 public.html
是响应,而 private.html
请求带有有效令牌。
现在这很容易在一个函数中实现,但我希望有单独的路由器,这样可以使代码更易于管理。
所以我需要以某种方式能够 选择 请求转到哪个中间件路由器?不知道该怎么做。
var publicR = new router();
publicR.get('/', function *(next) {
....public.html....
});
var privateR = new router();
privateR.get('/', function *(next) {
....private.html....
});
app.use(function(){
if(isAuthenticated)
...use privateR.routes();
else
...use publicR.routes();
});
万一其他人遇到这个问题,这对我有用:
var publicR = new router();
publicR.get('/', function *(next) {
....public.html....
});
var privateR = new router();
privateR.get('/', function *(next) {
....private.html....
});
app.use(mySwitcher);
function *mySwitcher(next){
if(isAuthenticated)
yield privateR.routes().call(this,next);
else
yield publicR.routes().call(this,next);
}
首先,在登录或未登录时为给定 URL 呈现完全不同的内容是不寻常的,而且确实不是一个好主意。因此,尝试让两个不同的路由器都提供相同的服务路由,但一个用于登录用户,另一个用于未登录用户可能不是一个好的设计理念。
更常见的情况是页面的一部分在登录时可能会有所不同。在这种情况下,您有一个创建页面的路由,用于处理与登录时的内容略有不同的内容或没有。
如果您真的想在登录时拥有完全不同的内容和行为,那么您应该在登录时重定向到不同的 URL。在这种情况下,您可以使用完全不同的路由器"logged in" URLs。这对于搜索引擎也将更好地工作,因为给定的 URL 将报告一致的内容,并且不会因用户的状态而有所不同。这也使得在 Express 中使用路由器变得非常容易。您的 "logged in" 路由器为登录的 URL 提供服务。您可以使用中间件检查登录 URL 以查看您是否实际登录,如果没有,则重定向回未登录页面,反之亦然。