angular中使用token来保存登录状态

JWT :是 JSON Web Tokens 的简称。该Token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源,也可以增加一些额外的其它业务逻辑所必须的声明信息,该token也可直接被用于认证,也可被加密。

 

要先引入一个库,然后路由守卫,然后在请求方法中、或者拦截器中配置添加token到请求头。

截屏2020-06-22下午1.19.44.png

image.png

客户端收到 Token 以后可以把它存储起来,比如放在 Cookie 里或者 Local Storage 里。

提交给后台时,浏览器会自动把cookie里的token带给后台,或者浏览器Head的Authorization字段里面放置Token。

在后端如何来接受token令牌呢,从当前请求的cookie上取,如果没有再从header中取。

 

Angular添加Token到Header中的方法:自定义Http方法,全局使用自动添加Token到Header中,或者使用拦截器。

步骤:

① 写一个常量function 将token放在http header的authorization 中

② 依赖注入

③ 引入 angular 的http 服务

④ 封装各类动词的方法在每种请求中都加入 token

之后的所有请求后端都只需要使用自己封装号的这个MyHttp 服务就可以了。

当然登录时需要将token放在localStorage中,注销的时候需要将token移除。

const httpOptions = {
  headers: new HttpHeaders({
    'Content-Type':  'application/json',
    'Authorization': 'my-auth-token'
  })
};

image.png

一次典型的访问场景是:

1.前端输入用户名、密码后台登录

2.后端根据用户ID生成Token、返回给前端

3.前端ajax请求、通过header头部设置 Authorization :token

4.后端通过Filter、拦截所有请求、处理请求是否合法(token失效、token为空、token过期)

单点登录

将含有jwt的cookie的domain设置为顶级域名

  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值