这是我现在选择的解决方案(使用Coffeescript语法):
$ -> $("a").bind "ajax:error", (event, jqXHR, ajaxSettings, thrownError) -> if jqXHR.status == 401 # thrownError is 'Unauthorized' window.location.replace('/users/sign_in')但是,这(本身)只会忘记用户最初要访问的页面,从而限制了可用性。
需要其他(控制器)逻辑以进行更优雅的处理。
更新:正确的重定向
在函数中,
this保留用户打算访问的初始URL。
通过调用
window.location.replace(this)( 而不是显式重定向到登录页面 ),应用程序将尝试将用户重定向到最初预期的目标。
尽管仍然是不可能的(未经授权),但这现在将是GET调用(而不是JS / AJAX)。因此, Devise 可以介入并将用户重定向到登录页面。
从那里开始,Devise照常运行,在成功登录后将用户转发到最初预期的URL。



