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
1902年泰州学堂创立,它的创办者是当时的泰州知州侯绍瀛。
空气净化器要被时代淘汰了?
4月6日晚间,中原银行发布公告称,该行董事长、执行董事徐诺金由于工作调动,于2023年4月6日向董事会提交辞呈,辞去该行
2023年4月2日,德州市消防救援支队指挥中心接到报警称,位于临邑县恒源街道山东金志碳素有限公司附近一儿童坠入农田机井,情况十分危急。接警
1、常规体检项目内科:血压、心率、心律、心杂音、心界、肺、肝、脾、肾、腹部压痛、肠鸣音、神经系统检查2、外科:身
利物浦今日训练:蒂亚戈&范迪克回归,萨拉赫&若塔等人缺席,若塔,萨拉赫,戈麦斯,利物浦,德国足球,法国足球,足球竞赛,足球运动员,维吉尔·范迪克
如今三亚天涯区的西岛,游客可以在整个岛参观,既可欣赏美丽的海滨景色,又可参观百年的珊瑚老屋、旧渔船改造的的海上书房,品尝虾饼等特
你退税了吗?2023年3月1日起2022年度个税汇算正式开始不少网友纷纷晒出了自己的退税金额几十元到上万元不等这时候大家
4月6日,据中国足球协会报道,中国足球协会关于调整2023赛季中超、中甲和中乙俱乐部球员国内转会注册办理时间的通知各有关
为了让家长更好地了解孩子在园的生活和学习情况,了解幼儿园“活教育,乐成长”办园理念,拉近“家”“园”的距离,更好地实现家园共育。近日
FIFA最新一期世界排名出炉!世界杯冠亚军阿根廷、法国分列一二,巴西、比利时排名三四位,日本挤进前二十。具体排名1-阿根廷2-法国3-巴西4-比
原标题:批量购买未成年人信息,绑定、出租游戏账号,还远程提供“过脸”服务,帮助破解人脸识别验证——(引题) 孩子游戏无忧背后,竟暗藏
为倡导厉行节约,防止餐饮浪费。近期,宝鸡市市场监督管理局根据国家市场监管总局和省局的统一安排部署,制定印发了《宝鸡市市场监督管理局制
4月20日至5月3日,济南千佛山将举办三月三民俗文化庙会
观点网讯:4月5日,郑州高新技术产业开发区挂牌一宗国有建设用地使用权,将于5月11日出让。据了解,该地块编号为郑政高出〔2023〕2号(网),
1、现代工业产品有数控设备,绝缘材料,机械设计加工 仪器、仪表,照明与灯具,工业设备合作,家电制造设备 节
记者从中国科学院大连化学物理研究所获悉,该所科研人员通过机械化学方法研发出首例室温条件下可以超快传输的氢负离子导体。未来氢负离子导体
1、司马微安于贫穷。2、以坚持自己的信念为乐。本文就为大家分享到这里,希望小伙伴们会喜欢。
洛南县气象台发布大风蓝色预警【Ⅳ级 一般】