如何认证当前的操作用户?

简介: 如何认证当前的操作用户?

正文


认证当前的操作用户是有很多种的方式的,比如可以利用Cookie、Session以及自定义的token的方式,来表示用户的登录状态。但是,这些技术,都会造成一些安全性的问题和用户登录状态的共享问题。无法判断是否是真的是这个用户请求操作。例如:假设我们使用的是token来操作数据接口,很有可能会出现CSRF的漏洞攻击。攻击者仅仅考虑你的token就可以完成和你一样的操作。那如何有效的保证用户是用户自己操作的呢?


产生这么多的问题主要的原因是我们的token管的太宽了,我们使用一个token做了所有的事情。在我们的项目里面会有不同的优先级的接口、也会有不同等级的接口。普通的接口可以直接使用token就完成了,但是比如:支付,或者更加高级的接口不能简单的用token来进行解决,此时我们需要二次的验证。例如可以输入密码等;但是不乏会有黑客会获取到你的密码,模拟你的转账业务,进行转账。这个时候如何解决?可以采用增加失效时间戳,以及签证信息,在有效的时间内,请求这个接口是有效的,不再这个时间内,请求这个接口是无效的。正常流程请求这个接口是有效的。直接请求这个接口是无效的。这样我们就可以在很大的程度上避免一些关键的接口存在CSRF的问题。


那如何设计我们的token呢?我们想在我们的token上增加一些必要的数据,可以供给前端以及后端的使用。解决的方案是可以采用JWT的方式进行解决。


JWT:Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC 7519).该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源,也可以增加一些额外的其它业务逻辑所必须的声明信息,该token也可直接被用于认证,也可被加密。


JWT包含了3个部分:第一部分我们称它为头部(header),第二部分我们称其为载荷(payload, 类似于飞机上承载的物品),第三部分是签证(signature)。JWT是服务端的生成下发给用户的。这样既可以传递信息,也可以作为用户的token进行操作。大大增加了token的功能。有兴趣的可以查询一下

相关文章
|
12月前
|
API
对企业用户信息进行认证的几种方式
企业认证的方式有很多种,根据业务类型和平台定位的不同,分为多种不同的形式,一般是通过人工审核和接入数据服务商的数据认证接口进行信息验证,具体常见的认证方式有以下几种。
140 0
对企业用户信息进行认证的几种方式
|
存储 运维 安全
用户身份验证真的很简单吗
你现在要建立一个系统。无论系统的功能如何,用户身份验证都是始终存在的一个功能。实现它看起来应该很简单——只需“拖动”一些现成的身份验证模块,或使用一些基本选项(例如 Spring Security)对其进行配置,就完成了。
75 0
用户身份验证真的很简单吗
|
云安全 安全 语音技术
身份标识和认证技术|学习笔记
快速学习身份标识和认证技术
414 0
|
数据采集 存储 搜索推荐
用户身份标识与账号体系实践
用户身份的全局统一标识至关重要,用户实体在不同业务线所产生的行为数据,通过唯一序列号进行识别,这样进行用户分析时看到的画像比较全面;
245 0
用户身份标识与账号体系实践
|
监控 安全
|
前端开发
小程序中用户信息授权常见问题汇总
用户信息授权的场景? 场景一:想实现免登,既然是使用支付宝钱包,必然操作用户是支付宝会员,希望用户操作小程序的时候,不再进行二次登录,让用户的体验更好,此时就需要免登功能,即是该用户进来就自动登录成为该小程序的会员。
1822 0
|
关系型数据库 MySQL 测试技术
菜鸟学习shiro之用数据库作为Realm的认证源实现登录,角色身份的判定和权限验证3
Maven的的依赖和第一篇是一样的副本直接用 上两篇讲的无论是内部类的封装领域还是配置文件的认证源,这篇开始讲最关心的数据库作为境界的认证源 这里使用的是四郎给我们提供的另一个内置的类JdbcRealm这个是连接数据库的一个内部类,话不多说了,具体的代码如下: import com.
1583 0
|
网络虚拟化 数据安全/隐私保护
|
网络虚拟化 数据安全/隐私保护