8.11字节跳动面试

本文主要讨论了JWT(Json Web Token)的原理、适用场景、优缺点,以及与Cookie和Session的机制对比。JWT适用于一次性校验、无状态API认证和单点登录。文章还深入讲解了Cookie的工作原理,包括其有效期、不可跨域名性和在实现永久登录中的应用,以及Session的存储方式、生命周期和与Cookie的关系。面试中还涉及TCP三次握手的原因、TCP与UDP的区别,以及如何基于UDP实现可靠传输。此外,文章提到了排序算法和哈希表的相关问题。
摘要由CSDN通过智能技术生成

8.11面试题

  • jwt是什么,应用场景有哪些
jwt介绍:
  • jwt全称json web token,由Header,Payload,Signature三部分组成。
  • Header主要存放令牌的类型和签名的生成算法(比如:HS256、RSA等等),payload存放token携带的信息(用户名,过期时间),signature是以header和payload加密生成的签名(过程不可逆,保证信息无法被篡改)。
  • 注意:只能保证信息不能被篡改,但是可以被解析出来,一般不要存放密码。
jwt适用场景:
  • 一次性校验:用户注册后邮件激活,邮件中有一个链接,用来标识用户,具有时效性,不可被篡改,非常适合使用jwt;
  • resuful api的无状态认证,token自身包含了身份验证所需要的所有信息,服务端不需要存储session信息,减轻服务器压力;
  • 单点登录,如果用session,就需要把用户的session信息在多台服务上面进行同步;
无状态和有状态:
  • 无状态:服务端没有保存客户端的状态信息,所以客户端的每个请求都必须带着自己的状态信息,所以可以被任意服务器应答(便于实现负载均衡。)
  • 有状态:服务端保存了客户端的状态信息,服务端会通过客户端传递的sessionID在server中的session作用域涨到之前交互的信息,并以此来实现应答,所以客户端只能由某一个服务器进行应答。
优缺点
  • 优点:
  • 无状态,单点登录
  • 避免csrf攻击,客户端把token放在local storage中间,
  • 缺点:
  • 注销登录等场景下token还有效,相关场景(退出登录,修改密码,修改了用户的权限或角色,账户被删除、被注销)࿰
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值