旧项目是SpringMVC+FreeMarker+Shiro
搭建的,后来在改造过程中实施前后端分离,把FreeMarker
移除掉了,后端现在就只是提供Restful
接口并以JSON
格式返回数据。
问题:由于后端是采用Shiro
管理权限的,原有的登录方式是将sessionId
和数据库的userId
进行绑定认证,但现在前后端分离之后登录这一块就不知道应该怎么做比较好,希望能提供一个最佳实践(或较为广泛应用)的方法。
谢谢。
居然用token的被采纳了, 难道每一个url都加上token吗? 呵呵
说说我的:
其实还是用cookie的啊, 跟原来没啥区别:
client发送username和password到server
server验证成功后, 写cookie到client,然后返回ok的json, 其中cookie的key要存储在redis中,value就是用户信息, 并且要设置key的超时时间,如:60分钟
client收到ok后, 进行相应的业务操作, 以后每次请求server都会自动带上cookie, 不用你写代码
server端的filter(你肯定用filter来实现)中会每次验证传过来的cookie的key在redis中是否存在, 有就代表登录成功过可以操作, 没有就返回错误标识
注意: 在登录成功后, 每次调用服务器接口时候, 都要为redis的key进行续期,如60分钟
当redis的key超过60分钟, 自己会删除这个key, 那么再次请求server时, 就会收到需要登录的返回值
当用户主动退出系统的时候, 也要在server中删除redis的key
再来说说token:
token一般用来做显示的身份验证, 比如手机验证码之类的, 这些都需要手动传递token到后台
在client点击验证码
server发送验证码,返回给client一个token
在client对验证码进行验证,传递token + 验证码到server
server对token+验证码进行验证