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

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

正文


认证当前的操作用户是有很多种的方式的,比如可以利用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的功能。有兴趣的可以查询一下

相关文章
|
5月前
|
安全 算法 API
阿里云用户开启MFA多因素认证的倡议书
因保管不当导致控制台登录密码泄露,很可能会被黑灰产盯上,发生盗用账户资金创建大量资源挖矿、删除用户数据进行勒索等安全的事件,严重威胁用户和平台的安全。2024年8月20日开始RAM访问控制产品将陆续为所有用户开启登录时强制进行MFA多因素认证。
678 0
阿里云用户开启MFA多因素认证的倡议书
|
Java Maven 数据安全/隐私保护
基于Session方式深入了解认证授权 1
基于Session方式深入了解认证授权
91 0
|
安全 前端开发 Java
基于Session方式深入了解认证授权 2
基于Session方式深入了解认证授权
63 0
|
API
对企业用户信息进行认证的几种方式
企业认证的方式有很多种,根据业务类型和平台定位的不同,分为多种不同的形式,一般是通过人工审核和接入数据服务商的数据认证接口进行信息验证,具体常见的认证方式有以下几种。
256 0
对企业用户信息进行认证的几种方式
|
存储 运维 安全
用户身份验证真的很简单吗
你现在要建立一个系统。无论系统的功能如何,用户身份验证都是始终存在的一个功能。实现它看起来应该很简单——只需“拖动”一些现成的身份验证模块,或使用一些基本选项(例如 Spring Security)对其进行配置,就完成了。
124 0
用户身份验证真的很简单吗
|
缓存 前端开发 数据安全/隐私保护
【权限设计系列】「认证授权专题」史上最全的权限认证服务的权限模型大全
【权限设计系列】「认证授权专题」史上最全的权限认证服务的权限模型大全
357 0
【权限设计系列】「认证授权专题」史上最全的权限认证服务的权限模型大全
|
安全 Java 数据库
认证用户状态的判断|学习笔记
快速学习认证用户状态的判断
认证用户状态的判断|学习笔记
|
监控 安全
|
云安全 安全 语音技术
身份标识和认证技术|学习笔记
快速学习身份标识和认证技术
585 0
|
缓存 安全 JavaScript
极简权限认证必须掌握【代码+原理+建议收藏】
这个极简权限认证必须掌握,代码不过百,但是很关键
240 0
极简权限认证必须掌握【代码+原理+建议收藏】