aba98280f4 | ||
---|---|---|
others | ||
src | ||
.gitignore | ||
LICENSE | ||
README.md | ||
pom.xml |
README.md
#spring-oauth-server
Spring与Oauth2的整合示例
项目用Maven管理
使用的技术与版本号
- Spring (3.1.1.RELEASE)
- Spring Security (3.1.0.RELEASE)
- MyBatis (3.2.1)
- spring-security-oauth2 (1.0.5.RELEASE)
- Log4j (1.2.14)
Oauth客户端项目请访问 spring-oauth-client
如何使用?
- 项目是Maven管理的, 需要本地安装maven(开发用的maven版本号为3.1.0), 还有MySql(开发用的mysql版本号为5.5)
- 下载(或clone)项目到本地
-
创建MySQL数据库(如数据库名oauth2), 并运行相应的SQL脚本(脚本文件位于others/database目录),
运行脚本的顺序: initial_db.ddl -> oauth.ddl -> initial_data.ddl - 修改spring-oauth-server.properties(位于src/main/resources目录)中的数据库连接信息(包括username, password等)
-
将本地项目导入到IDE(如Intellij IDEA)中,配置Tomcat(或类似的servlet运行服务器), 并启动Tomcat(默认端口为8080);
注意将项目的 contextPath(根路径) 设置为 'spring-oauth-server'.
另: 也可通过maven package命令将项目编译为war文件(spring-oauth-server.war), 将war放在Tomcat中并启动(注意: 这种方式需要将spring-oauth-server.properties加入到classpath中并正确配置数据库连接信息). - 参考oauth_test.txt(位于others目录)的内容并测试之(也可在浏览器中访问相应的地址,如: http://localhost:8080/spring-oauth-server).
grant_type
说明Oauth支持的grant_type(授权方式)与功能
authorization_code
-- 授权码模式(即先登录获取code,再获取token)password
-- 密码模式(将用户名,密码传过去,直接获取token)refresh_token
-- 刷新access_tokenimplicit
-- 简化模式(在redirect_uri 的Hash传递token; Auth客户端运行在浏览器中,如JS,Flash)client_credentials
-- 客户端模式(无用户,用户向客户端注册,然后客户端以自己的名义向'服务端'获取资源)
帮助与改进
-
与该项目相关的博客请访问 http://blog.csdn.net/monkeyking1987/article/details/16828059
-
如果在使用过程中遇到特殊的问题(如:如何将oauth_code存入数据库),请访问项目的 Wiki 与 附件.
我会把大家反馈的问题解决办法添加在这里.
若在这两个地方没有找到解决办法的, 欢迎发邮件到shengzhao@shengzhaoli.com一起讨论. -
如果在使用项目的过程中发现任何的BUG或者更好的提议, 建议将其提交到项目的 Issues 中, 我会一直关注并不断改进项目.
功能扩展
-
oauth_code存入数据库的配置
, 请下载文件 oauth_code存入数据库的配置.jpg -
改变token过期的时间的配置
, 请下载文件改变token过期的时间的配置.jpg -
自定义 grant_type
, 默认情况支持的grant_type包括 [password,authorization_code,refresh_token,implicit], 若不需要其中的某些grant_type, 则可以修改 oauth_client_details 表中的 authorized_grant_types 字段的值;
若想把整个Oauth服务修改来只支持某些grant_type, 请修改 security.xml文件中的 中的内容,将对应的 grant_type 注释或删掉即可 -
如何刷新access_token(refresh_token)
, 在通过客户端(如移动设备)登录成功后返回的数据如下
{"access_token":"3420d0e0-ed77-45e1-8370-2b55af0a62e8","token_type":"bearer","refresh_token":"b36f4978-a172-4aa8-af89-60f58abe3ba1","expires_in":43199,"scope":"read write"}
若需要刷新获取新的token(一般在 expires_in 有效期时间快到时), 请求的URL类似如下
http://localhost:8080/oauth/token?client_id=mobile-client&client_secret=mobile&grant_type=refresh_token&refresh_token=b36f4978-a172-4aa8-af89-60f58abe3ba1
注意: refresh_token 参数值必须与登录成功后获取的 refresh_token 一致, 且grant_type = refresh_token
另: 刷新token 需要 ClientDetails 支持 refresh_token 类型的 grant_type (默认是支持的)
开发计划
从 0.3版本开始将项目的所有计划的开发内容列出来, 方便大家跟进, 也欢迎你加入.
项目的开发管理使用开源项目 andaily-developer.
-
Version: 0.3 [developing]
Date: 2015-05-14#73 - Upgrade 'spring-security-oauth2' version to '2.0.6.RELEASE' (current: 1.0.5.RELEASE) [CREATED]
#74 - oauth mysql ddl add create_time, default is now()#75 - Add user information API, forspring-oauth-client
project useURL: /unity/user_info Login: Yes (ROLE_UNITY) Data Format: JSON
URL: /m/user_info Login: Yes (ROLE_MOBILE) Data Format: JSON </pre> </del></p> </li> <li><p><del>#77 - User add Privilege domain. Addition initial two user: unityuser(ROLE_UNITY),mobileuser("ROLE_MOBILE). If default user, return all privilegs, otherwise return specify privilege(s) </del></p></li> <li><p><del>#78 - Initial 'sprint-oauth-client' project(maven), add sub-modules</del></p></li> <li><p><del>#91 - User log4j replace logback dependency </del></p></li> <li><p>#92 - Add database table column description. (添加数据库表的字段说明) </p></li> <li><p><del>#93 - 将默认的 oauth_code存入数据库(当前是存入内存) </del></p></li> <li><p><del> spring-oauth-server project add Bootstrap CSS </del></p></li> <li><p>#95 - Add 'client-details' management; create/delete, show testing links</p></li> </ol> </li> <li> <p> Version: <strong>0.4</strong> [scheduled] <br/> Date: ------ </p> </li>
数据库表字段说明
在0.3版本中添加了db_table_description.html
文件(位于/others目录), 用来说明数据库脚本文件oauth.ddl
中各表,各字段的用途及使用场合.
更多资源
以下是在学习工作中收集的更多关于Oauth的资源,对深入理解与运用Oauth有帮助
-
OAUTH2核心参数说明, 重点介绍了grant_type 与 response_type 以及示例
-
OAuth2 flows, 详细介绍Oauth2的流程,各类错误发生时的响应
-
OAuth 2 开发人员指南(Spring security oauth2), 翻译OAuth 2 Developers Guide(spring security oauth2)
-
理解OAuth 2.0, 介绍Oauth2各类grant_type的使用
-
OAuth2:隐式授权(Implicit Grant)类型的开放授权, 介绍grant_type='implicit'模式
-
Apache Oltu, Java版的 Oauth参考实现, 建议去了解了解
关注更多我的开源项目请访问 http://andaily.com/my_projects.html
若需更多的技术支持请联系 monkeyk@shengzhaoli.com