Spring Boot的安全配置(二) 全球播报
OAuth2 0是一种授权协议,允许用户授权第三方应用程序访问他们的资源。在SpringBoot中,可以使用spring-security-oauth2-a
(资料图片仅供参考)
OAuth 2.0是一种授权协议,允许用户授权第三方应用程序访问他们的资源。在Spring Boot中,可以使用spring-security-oauth2-autoconfigure
库来实现OAuth 2.0身份验证。该库提供了一些可用的OAuth 2.0身份验证客户端,包括Facebook、GitHub、Google和Twitter等。
以下是使用Java配置实现GitHub OAuth2.0身份验证的示例:
@Configuration@EnableOAuth2Ssopublic class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http.antMatcher("/**") .authorizeRequests() .antMatchers("/", "/login**") .permitAll() .anyRequest() .authenticated() .and() .logout() .logoutSuccessUrl("/") .permitAll() .and() .csrf().disable() .addFilterBefore(ssoFilter(), BasicAuthenticationFilter.class); } @Bean public FilterRegistrationBean oauth2ClientFilterRegistration(OAuth2ClientContextFilter filter) { FilterRegistrationBean registration = new FilterRegistrationBean(); registration.setFilter(filter); registration.setOrder(-100); return registration; } @Bean public Filter ssoFilter() { OAuth2ClientAuthenticationProcessingFilter githubFilter = new OAuth2ClientAuthenticationProcessingFilter("/login/github"); OAuth2RestTemplate githubTemplate = new OAuth2RestTemplate(github(), oauth2ClientContext); githubFilter.setRestTemplate(githubTemplate); UserInfoTokenServices tokenServices = new UserInfoTokenServices(githubResource().getUserInfoUri(), github().getClientId()); tokenServices.setRestTemplate(githubTemplate); githubFilter.setTokenServices(tokenServices); return githubFilter; } @Bean public OAuth2ProtectedResourceDetails github() { ClientCredentialsResourceDetails details = new ClientCredentialsResourceDetails(); details.setClientId(""); details.setClientSecret(""); details.setAccessTokenUri(""); details.setScope(Arrays.asList("", "")); return details; } @Bean public ResourceServerProperties githubResource() { ResourceServerProperties resource = new ResourceServerProperties(); resource.setUserInfoUri(""); return resource; } @Autowired private OAuth2ClientContext oauth2ClientContext;}
在上面的示例中,SecurityConfig
类使用@EnableOAuth2Sso
注解启用OAuth 2.0单点登录。configure()
方法使用HttpSecurity
对象来配置HTTP请求的安全性。.antMatcher("/**")
表示拦截所有请求。.authorizeRequests()
表示进行授权请求。.antMatchers("/", "/login**").permitAll()
表示允许访问主页和登录页面,而不需要进行身份验证。.anyRequest().authenticated()
表示所有其他请求都需要进行身份验证。.logout()
方法指定了注销的URL和成功注销后的跳转页面。.csrf().disable()
表示禁用跨站请求伪造保护。.addFilterBefore(ssoFilter(), BasicAuthenticationFilter.class)
表示在BasicAuthenticationFilter
之前添加OAuth2ClientAuthenticationProcessingFilter
过滤器。
oauth2ClientFilterRegistration()
方法使用FilterRegistrationBean
注册OAuth2ClientContextFilter
过滤器。
ssoFilter()
方法创建OAuth2ClientAuthenticationProcessingFilter
过滤器,它将处理"/login/github"路径的请求。OAuth2RestTemplate
对象提供了GitHub OAuth 2.0客户端的访问令牌。UserInfoTokenServices
对象使用OAuth2RestTemplate
对象来访问GitHub资源服务器,并验证访问令牌。github()
方法创建ClientCredentialsResourceDetails
对象,它包含GitHub OAuth 2.0客户端的详细信息,例如客户端ID和客户端秘钥。ResourceServerProperties
对象指定了GitHub资源服务器的用户信息URI。
3.0授权的示例:
@Configuration@EnableWebSecuritypublic class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http.authorizeRequests() .antMatchers("/admin/**").hasRole("ADMIN") .antMatchers("/user/**").hasAnyRole("ADMIN", "USER") .antMatchers("/**").permitAll() .and() .formLogin(); } @Autowired public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception { auth.inMemoryAuthentication() .withUser("user") .password("{noop}password") .roles("USER") .and() .withUser("admin") .password("{noop}password") .roles("ADMIN"); }}
在上面的示例中,SecurityConfig
类使用@EnableWebSecurity
注解启用Spring Security。configure()
方法使用HttpSecurity
对象来配置HTTP请求的安全性。.authorizeRequests()
表示进行授权请求。.antMatchers("/admin/**").hasRole("ADMIN")
表示要求管理员角色才能访问/admin
路径。.antMatchers("/user/**").hasAnyRole("ADMIN", "USER")
表示要求管理员或用户角色才能访问/user
路径。.antMatchers("/**").permitAll()
表示允许访问所有其他路径。.formLogin()
表示启用表单登录。
configureGlobal()
方法使用AuthenticationManagerBuilder
对象来配置身份验证。inMemoryAuthentication()
方法指定了在内存中存储用户凭据。.withUser("user").password("{noop}password").roles("USER")
指定了用户名、密码和角色,其中{noop}
前缀表示密码以明文形式存储在内存中。.withUser("admin").password("{noop}password").roles("ADMIN")
指定了管理员用户的用户名、密码和角色。
以上是Spring Boot中基于OAuth 2.0和基于授权的安全配置示例。在实际开发中,您可以根据需要进行更改和扩展。
关键词:
OAuth2 0是一种授权协议,允许用户授权第三方应用程序访问他们的资源。在SpringBoot中,可以使用spring-security-oauth2-a
4月6日晚间,中国金茂(00817 HK)披露3月份销售情况。公告显示,3月份中国金茂及其附属公司取得签约销售金额约201亿元,签约销售建筑面积约1136
截至4月7日,恒指最新的牛熊街货比例为60:40。
1、在选购的时候,首先要考虑个人爱好,钟表面光洁,电镀部位色泽均匀,完好的针盘记时是钟表选择时首先要考虑的,将挂钟后盖的调时旋钮转动,
阿森纳名宿帕洛尔接受了媒体的采访,被问及当下哪些利物浦球员能在阿森纳踢上主力,帕洛尔发表了他的见解。帕洛尔表示:“依现在的情形来看,
如今,在这批小城中年的推动下,朝鲜族大酱和泡菜、传统手工粉条、木耳、大米等汪清家乡农货成了拼多多的爆款,被全国消费者所看见。闫茂新等
4月6日,商务部公布数据显示,1-2月,我国服务贸易继续保持增长,知识密集型服务贸易占比提升,旅行服务恢复明显。整体看,服务进出口总额9695
黑科技加持!谷歌新款Pixel平板曝光:能秒变智能显示屏,谷歌,安卓,显示屏,黑科技,平板电脑,ipad,智能手机,pixel,GooglePixel
东营治疗男性早泄哪家医院好?东营东康医院怎么样。现如今男性疾病越发严重,让非常多的男性朋友十分苦恼,早泄是生活中非常容易碰到的一
美国不再是唯一选择!中国药企出海新目标:把创新药卖到东南亚
中新网沈阳4月6日电 (李晛)沈阳市“振兴新突破 我要当先锋”主题
一、吴忠最新疫情消息-数据概览:1、新增本土:0;2、新增无症状:0;3、现有确诊:0;4、累计确诊:50;5、累计治愈
天津市河东区委常委、副区长刘涛介绍说,今年以来,天津市河东区深入落实京津冀协同发展战略,重点围绕科技创新协同、产业发展协同、城市建设
1、你好!!亲资源已发楼主你果断的查看垃圾箱吧【包括收件!】采纳就是对我最大的支持了~加分更好~(*^__^*)…
周四(4月6日)中午,截止11:33,纸黄金价格最高触及447 19元 克,最低价444 01元 克,纸黄金实时报价444 67元 克。
大江网 大江新闻客户端安福讯(周幸)青山有幸埋忠骨,烈士墓前抚英魂。4月3日,清明节前夕,安福县平都镇浮山村村民肖树初带着家人来到伍中豪烈
中新网广西新闻4月6日电(东信萱)新疆农民工工资保证金电子保险保函平台(简称“电子保险保函平台”)近日正式上线启用。这
南昌·铜锣湾冰雪乐城项目正式落户江西南昌湾里管理局,该项目总占地面积约3900余亩,总投资约50亿元人民币。
来源:北国·辽宁日报对于被盗辽墓的抢救性发掘在2001年4月展开,同时细心的考古人员对周边坡地进行大范围考古调查,由于当地丘陵土层极薄,浅
我国IPv6流量首次突破50%