Spring REST实践之安全
Securing REST Services
一般有六种方式实现的REST服务的安全:
Session-based security
HTTP Basic Authentication
Digest Authentication
Certificate based security
XAuth
OAuth
Session-based Security
Session-based Security方式需要server端会话保存用户的身份信息,以便在多个请求中使用。它的流程图如下所示:
Spring Security支持此种安全模型,此种方式对于开发者非常有吸引力。但是这种方式违背了REST无状态的约束,而且因为server需要保存client的状态,所以这种方式不是可扩展的。理想情况下,client应该保存自己的状态,而server应该是无状态的。
HTTP Basic Authentication
当有用户交互时,提供一个login窗口获取username和password是可行的,但是服务之间的交互就不可行了。HTTP Basic Authentication可同时支持交互与非交互模式。在这种方法中,当client发出一个针对保护资源的请求,server会返回一个401(Unauthorized)状态码和“WWW-Authenticate” header。
GET /protected_resource
401 Unauthorized
WWW-Authenticate: Basic realm="Example Realm"
Basic部分表明使用Basic认证,realm指示服务器上一个保护的空间。
客户端收到上面的响应后,用Base64编码"user:password"字符串,并将其放到Authorization header后发送给服务器,如:
GET /protected_resource
Authorization: Basic bHxpY26U5lkjfdk
服务器解码提交的信息、验证提交的证书。如果认证成功,server结束此请求。
因为client包含了认证的信息,所以server是无状态的。但是client指示简单的对用户名和密码进行加密,因此在not-SSL/TLS链接中,此种方式有可能遭受中间人攻击,窃取密码。
Digest Authentication
Digest Authentication和HTTP Basic Authentication非常相似,除了用户的证书是加密传送的。client提交一个针对包含资源的请求,然后server回复一个401(Unauthorized)状态码和一个WWW-Authenticate header,如下所示:
GET /protected_resource
401 Unauthorized
WWW-Authenticate: Digest realm="Example Realm", nonce="P35kl89sdfghERT10Asdfnbvc", qop="auth"
WWWW-Authenticate指定了认证模式、server产生的特殊词语、qop(quality of protection)。nonce是一个任意的token,用于加密。qop指示语可包含"auth"和"auth-int"两个值:
A qop value "auth" indicates that the digest is used for authentication purposes
A value "auth-int" indicates that digest will be used for authentication and request integrity
client接收到响应后,如果qop是auth,client会用下面公式产生digest(摘要):
hash_value_1 = MD5(username:realm:password)
has_value_2 = MD5(request_method:request_uri)
digest = MD5(hash_value_1:nonce:hash_value_2)
如果qop是auth-int,client在产生digest时会包含request body:
hash_value_1 = MD5(username:realm:password)
has_value_2 = MD5(request_method:request_uri:MD5(request_body))
digest = MD5(hash_value_1:nonce:hash_value_2)
server接收到上面经过计算的digest后,会进行认证操作。如果认证成功,server会结束请求过程。
Digest authentication比HTTP Basic authentication更加安全。但是,在non-SSL/TLS通信中,它还是存在被snooper检索digest、回复请求的可能。解决这个问题的一个方法就是限制server产生的nonces只能使用一次。还有,由于server为了认证必须产生digest,它需要能够访问密码的明文格式。因此server不能使用不可逆的加密算法,而且server会成为系统安全的薄弱环节。
Certificte-Based Security
Certificated-based security模型需要证书验证参与者的身份。在SSL/TLS为基础的通信中,client通过证书验证server的身份。在这种方式中,当server接收到一个针对保护资源的请求后,会发送自己的证书给client。client确认此证书是可信证书机构颁发的证书后,发送它自己的证书给server。server验证client的证书,当成功验证后,server会将受保护资源的访问权限分给client。
Certificate-based security模型消除了发送共享密码的需求,使得它更加安全。但是,布置和维护证书是非常昂贵的,一般只能在大型系统中使用。
XAuth
随着REST API变得流行起来,使用API的第三方应用的数量也会显著增长。这些应用需要用户名和密码和REST服务交互,这样存在巨大的风险,因为第三方应用有访问用户名和密码的权限。一种简单的解决方案是第三方应用保存用户信息。如果用户更改了他的凭证,他需要更新所有的第三方应用。而且此种方式不允许用户撤销他对第三方的授权。在这种情况下,只有更改密码才能撤销授权。
XAuth和OAuth提供了用户不用保存密码就能访问受保护资源的方式。在这种方式中,客户端应用可通过login form请求用户名和密码,然后client发送用户名和密码到server,server接收到后,验证client的凭证。如果验证成功,一个token会返回给client。client可以放弃用户名和密码,在本地存储token。当再访问受保护资源时,token会被包含在请求中,可用X-Auth-Token完成此目的。token的有效期由实现决定,token可以一直保存直到server删除它或者token在给定的时间内过期。如果client和REST API都由一个组织开发,那么这种方式可以作为备选方案。
OAuth 2.0
OAuth(Open Authorization)是一个用户不用保存密码就可以访问受保护资源的框架。OAuth在2007年开发出来,于2010年被OAuth2.0取代。OAuth2.0定义了如下四个角色:
Resource Owner-A:可以给予访问账户或者资源的权限的用户,比如微博的用户。
Client A:需要获得访问用户资源权限的客户端应用。
Authorizatin Server:验证用户的身份,并发给client一个可以访问资源的token。
Resource Server:保存受保护资源的服务器。
OAuth 2.0需要在SSL上完成信息交互。
spring安全相关
可在POM文件中包含如下依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
Spring REST实践之安全的更多相关文章
- Spring+MyBatis实践—MyBatis数据库访问
关于spring整合mybatis的工程配置,已经在Spring+MyBatis实践—工程配置中全部详细列出.在此,记录一下几种通过MyBatis访问数据库的方式. 通过sqlSessionTempl ...
- Spring MVC 实践 - Component
Spring MVC 实践 标签 : Java与Web Converter Spring MVC的数据绑定并非没有任何限制, 有案例表明: Spring在如何正确绑定数据方面是杂乱无章的. 比如: S ...
- Spring MVC 实践 - Base
Spring MVC 实践 标签 : Java与Web Spring Web MVC Spring-Web-MVC是一种基于请求驱动的轻量级Web-MVC设计模式框架, Spring MVC使用MVC ...
- Spring Boot实践——Spring AOP实现之动态代理
Spring AOP 介绍 AOP的介绍可以查看 Spring Boot实践——AOP实现 与AspectJ的静态代理不同,Spring AOP使用的动态代理,所谓的动态代理就是说AOP框架不会去修改 ...
- Spring Boot实践——AOP实现
借鉴:http://www.cnblogs.com/xrq730/p/4919025.html https://blog.csdn.net/zhaokejin521/article/detai ...
- Spring Boot 实践 :Spring Boot + MyBatis
Spring Boot 实践系列,Spring Boot + MyBatis . 目的 将 MyBatis 与 Spring Boot 应用程序一起使用来访问数据库. 本次使用的Library spr ...
- Spring Batch实践
Spring Batch在大型企业中的最佳实践 在大型企业中,由于业务复杂.数据量大.数据格式不同.数据交互格式繁杂,并非所有的操作都能通过交互界面进行处理.而有一些操作需要定期读取大批量的数据,然后 ...
- Spring REST实践之Spring Boot
Spring Boot基本描述 可以利用http://start.spring.io网站的进行Spring Boot的初始化构建.这个初始化构建器允许你输入工程基本信息.挑选工程支持的功能,最后会生成 ...
- Spring+MyBatis实践—工程配置
初次实践:Spring+MyBatis技术搭建框架,采用Bootstrap前端开源框架. 简介: MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除 了几乎所 ...
- spring boot 实践
二.实践 一些说明: 项目IDE采用Intellij(主要原因在于Intellij颜值完爆Eclipse,谁叫这是一个看脸的时代) 工程依赖管理采用个人比较熟悉的Maven(事实上SpringBoot ...
随机推荐
- LeetCode Reverse Linked List II 反置链表2
题意:将指定的一段位置[m,n]的链表反置,返回链表头. 思路:主要麻烦在链表头,如果要从链表头就开始,比较特殊. 目前用DFS实现,先找到m-1的位置,再找到n+1的位置,中间这段就是否要反置的,交 ...
- hihoCoder hiho一下 第四十八周 题目1 : 拓扑排序·二
题意: 给定一个拓扑图,其中部分结点含有1个病毒,每个结点只要收到病毒就会立即往出边所能到达的点传播,病毒数可叠加,求所有结点的病毒数总和. 思路: 根据拓扑的特点,每个入度为0的点肯定不会再被传播病 ...
- django - 修改 自增长id,起始值
常常你会遇到这样的情况,需要自增长的起始值是 0,再次从 0开始. 两个选择: 1. drop table_name; django重新建表. 2. ALTER TABLE table_name AU ...
- (六)6.12 Neurons Networks from self-taught learning to deep network
self-taught learning 在特征提取方面完全是用的无监督的方法,对于有标记的数据,可以结合有监督学习来对上述方法得到的参数进行微调,从而得到一个更加准确的参数a. 在self-taug ...
- Android 一步步教你从ActionBar迁移到ToolBar
谷歌的材料设计也发布了有一段时间了,包括官方的support库 相信大家也熟悉了不少,今天就把actionbar 迁移到toolbar的 经验发出来. 这个地方要注意 我用的图标都是studio里的一 ...
- Nodejs学习之一 下载安装与部署nodejs
1,下载nodejs 访问nodejs官网 www.nodejs.org/download/ 下载与机器相匹配的版本 2,安装nodejs 下载下来的msi包一直点击下一步即可 3,部署环 ...
- JS面向对象组件(六) -- 拖拽功能以及组件的延展
HTML部分 <div id="div1"></div> <div id="div2"></div> CSS部分 ...
- GitHub入门:如何上传与下载工程?
由于经常要在家写代码,所以需要有个能够方便访问代码管理工具.最近尝试了一下GitHub.经过了一翻纠结之后,基本上掌握了他的使用方式. 要使用GitHub需要首先在其网站上进行注册.其官方网站是ht ...
- Chopsticks
题意: n个数3个相邻是一组,求选k组使得,各组组内较小的两个数的差之和最小. 分析: 对于每个数选或不选的问题,dp[i][j]表前i个数选了j组得到的最小和. dp[i][j]=min(dp[i- ...
- 关于COUNT STOPKEY的工作机制(转载)
SQL> select rownum rn ,a.* from cnmir.ew_auctions a where rownum<50000; Execution Plan-------- ...