SpringBootSecurity学习(24)前后端分离版之OAu…
2019-10-16 08:14:12来源:博客园 阅读 ()
SpringBootSecurity学习(24)前后端分离版之OAuth2.0 应用登记
应用登记
一个应用要求 OAuth 授权,必须先到对方网站登记,让对方知道是谁在请求。举个例子,下面是github的登记页面:
- https://github.com/settings/applications/new
下面我们来自己做一个简单的应用登记,根据表 oauth_client_details 的结构,我们登记的时候只填写应用名称和回调地址即可,其它的字段如下:
client_id:使用UUID生成
client_secret:使用UUID生成,并使用 BCryptPasswordEncoder 加密
scope:默认all
authorized_grant_types :默认 authorization_code,password,refresh_token 三个
下面是sql语句:
Service中的方法:
接口定义:
下面来测试接口:
返回了预期中的客户端id和秘钥。来看一下数据库:
现在我们就可以使用新登记的应用来请求令牌了:
- http://localhost:8029/oauth/authorize?client_id=52f301a86511406ba5b4fbb4809614b0&response_type=code&redirect_uri=http://localhost:8029/
令牌请求结果:
状态state字段
为了防止CSRF攻击,在申请授权码这一步时,可以在参数中增加一个state状态参数,这个参数是由客户端生成的随机字符串,授权服务会原封不动的返回这个参数和参数值,用户进行授权客户端的请求时也会携带此字符串用于比较。如下:
- http://localhost:8029/oauth/authorize?client_id=52f301a86511406ba5b4fbb4809614b0&response_type=code&redirect_uri=http://localhost:8029/&state=123456789
返回结果如下:
如果传递过去的和回来的不一样,可以认为不合法。
代码地址:https://gitee.com/blueses/spring-boot-security 29
本文由博客一文多发平台 OpenWrite 发布!
原文链接:https://www.cnblogs.com/guos/p/11679616.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 学习Java 8 Stream Api (4) - Stream 终端操作之 collect 2020-06-11
- java学习之第一天 2020-06-11
- Java学习之第二天 2020-06-11
- Spring WebFlux 学习笔记 - (一) 前传:学习Java 8 Stream Ap 2020-06-11
- Linux简单命令的学习 2020-06-10
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash