在 WEB 应用程序中重定向到不同 URL 的正确方法是啥?

Posted

技术标签:

【中文标题】在 WEB 应用程序中重定向到不同 URL 的正确方法是啥?【英文标题】:What is the right way to redirect to a different URL inside the WEB application?在 WEB 应用程序中重定向到不同 URL 的正确方法是什么? 【发布时间】:2015-03-14 12:59:59 【问题描述】:

我有一个非常小的“实验室”应用程序,我正在为学习建议编写它。 这包括一个登录页面,以及成功登录后的单页应用程序。 Node.js 的后端与 Express.js 和客户端是 Angular.js

最初请求页面时,我成功地使用 res.sendFile 提供登录页面,但是当我检测到成功登录时,我发送主 APP 页面,但没有任何反应。

这里是代码

当成功登录时,重定向到应用页面

var loginRequest = function( req, res, next ) 

var user = req.body.user;
var password = req.body.pass;

if ( user === '' || password === '' ) 

    //Some field is blank - insufficient information
    console.log('User login failure: Insufficient data');
    res.json(400, );

 else 
    models.account.loginRequest ( user, password, function ( result )    
    console.log ( result );
    if ( result != null ) 
        console.log('Login Succesful');
        userSession = req.session;
        userSession.user = user;
        res.redirect( 301,  '../app' );

     else 
        console.log('Login NOT Succesful');
        res.status(401).json();
    
    );



在上面的代码中,目的是当我成功登录时,我会重定向到已经创建会话的应用页面。

res.redirect( 301, '../app' );

那么,然后这个/app路径被请求,下面的代码服务器它

var serveApp = function( req, res, next ) 

console.log('--- sending app.html --- *hopefully');
var options = 
    root: publicPath,
    dotfiles: 'deny',
    headers: 
    'x-timestamp': Date.now(),
    'x-sent': true
    
;

res.sendFile( 'app.html', options);

;

您注意到有服务器 console.log() 只是为了尝试了解正在发生的事情。我在节点控制台上看到的是:

POST /users/loginRequest 301 9.266 ms - 40
--- sending app.html --- *hopefully
GET /app 200 41.145 ms - 140

在 Chrome 上的开发人员工具上,我可以看到该文件已提供,但在 Chrome 本身上,它永远不会从要求用户和密码凭据的页面移动。

您能否帮助我理解为什么这不起作用,或者,如果我做错了,那么正确的做法是什么?

谢谢

【问题讨论】:

【参考方案1】:

我对某人有用的情况,最后我所做的是回答来自节点的响应 200 并处理 Angular 上的重定向

angular.module('loginToApp', [])
.constant ( 'loginURL', '/users/loginRequest')
.controller ( 'loginCtrl', function( $scope, $http, $window, loginURL ) 

    $scope.data = [
     inEmail: '', inPass: '', loginError: false 
    ];

    $scope.loginRequest = function( user, pass ) 

    console.log('--- LoginRequest ---');
    console.log('User: ' + user);
    console.log('Pass: ' + pass);
    console.log('LoginRequest: ' + loginURL );

    $http.post ( loginURL,
             
             user: user,
             pass: pass
             ,
              withCredentials: true )

        .success ( function( data, status, headers, config ) 
        console.log('--- SUCCESS ---');
        console.log('Data');
        console.log(data);
        console.log('Status');
        console.log(status);
        console.log('Headers');
        console.log(headers);
        console.log('Config');
        console.log(config);

        var appWindow = 'http://' + $window.location.host + data.appPath;
        console.log('--- APP window ---');
        console.log(appWindow);
        console.log('--- APP window ends ---');
        $window.location.href = appWindow;

        )
        .error ( function( data, status, headers, config ) 
        console.log('--- ERROR ---');
        console.log('Data');
        console.log(data);
        console.log('Status');
        console.log(status);
        console.log('Headers');
        console.log(headers);
        console.log('Config');
        console.log(config);

        if ( status != 301 ) 
            loginError ( true );
        
    );
    ;

    var loginError = function( bool ) 
    $scope.data.loginError = bool;
    

);

当然,console.log 只是了解正在发生的事情的初学者(比如我自己),但不是必需的。

【讨论】:

以上是关于在 WEB 应用程序中重定向到不同 URL 的正确方法是啥?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 React 中重定向

如何在 vue-router beforeRouteEnter 钩子中重定向到不同的 url?

在laravel中重定向到外部url时如何保留会话数据

在 Spring MVC 中重定向到动态 URL

在 Spring MVC 中重定向到动态 URL

django 在 urls.py 中重定向