解決spring security中遇到的問題
spring security中遇到的問題
1.An Authentication object was not found in the Security Context
在security上下文中沒有找到一個(gè)認(rèn)證對(duì)象,我這邊的問題在于controller中方法添加了認(rèn)證注解,但是配置類中
源自于一片我為了解決攔截靜態(tài)文件的博客,上面說這個(gè)忽視目錄會(huì)以classpath中的static文件夾,實(shí)際上這樣寫有著很大問題,這邊會(huì)讓所有的文件不攔截,雖然你的http認(rèn)證添加了攔截,但是web這個(gè)會(huì)影響到效果,所以一邊允許所有文件不攔截,一邊controller中添加了需要認(rèn)證的注解,所以你一訪問就會(huì)進(jìn)去這個(gè)頁(yè)面,但是進(jìn)去之后發(fā)現(xiàn)在security context并沒有這個(gè)角色值,所以就會(huì)出現(xiàn)這個(gè)異常
最后對(duì)這個(gè)異常說明一句話:這個(gè)普通來看就是越過了普通的往上下文中添加了角色但是進(jìn)去了這個(gè)頁(yè)面就會(huì)出現(xiàn)這個(gè)錯(cuò)誤
2.攔截登錄之后總是會(huì)進(jìn)login?error,而且沒有提示
這個(gè)情況還是有錯(cuò)誤提示才會(huì)好解決問題,在http認(rèn)證配置中的FormLoginConfigurer
添加一個(gè)failureUrl("/login/error")
,當(dāng)然這個(gè)地址是我們自己定義的,然后對(duì)應(yīng)的congtroller方法:
@RequestMapping(value = "/login/error") public void loginError(HttpServletRequest request, HttpServletResponse response) { response.setContentType("text/html;charset=utf-8"); AuthenticationException exception = (AuthenticationException) request.getSession().getAttribute("SPRING_SECURITY_LAST_EXCEPTION"); try { response.getWriter().write(exception.toString()); } catch (IOException e) { e.printStackTrace(); } }
這樣就可以把最基本的錯(cuò)誤打印出來,然后我們?cè)俑鶕?jù)實(shí)際問題進(jìn)行處理
3.Spring Security BadCredentialsException
這個(gè)具體原因還不是很清楚,但是有個(gè)很簡(jiǎn)單的解決辦法,把所有的密碼加密方式改為相同的,還不可以的話
單獨(dú)寫一個(gè)配置類:
@Configuration public class BeanConfiguration { /** * @return Return to the custom password encryptor. * The reason why it is extracted separately as a configuration class is because if you don't do this, * you cannot achieve unified password encryption, which leads to login failures. * Different password encryption results in different passwords. */ @Bean public PasswordEncoder passwordEncoder(){ return new CustomPasswordEncoder(); } }
這個(gè)CustomPasswordEncoder類是我自己寫個(gè)一個(gè)密碼加密類,不想使用的話也可以使用官方推薦的:BCryptPasswordEncoder
springboot用security遇到的問題
如果項(xiàng)目中用了 security ,而不用 security 自帶的登入的話 ,會(huì)自動(dòng)跳轉(zhuǎn)其自帶的登入界面(前提是已攔截 放開的可以直接訪問),/login 自帶登入接口路徑 ,/logout 自帶退出接口路勁。
自定義攔截
@Configuration @EnableWebSecurity public class WebSecurityConfig extends WebSecurityConfigurerAdapter { @Autowired MyUserDetailsService myUserDetailsService; @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers("/**/*.css","/**/*.js","/**/*.jpg","/**/*.gif","/**/*.ico","/**/*.ico","/**/*.woff","/**/*.ttf","/**/*.png").permitAll() // .antMatchers("/main").hasAnyRole("ANONYMOUS,USER") .anyRequest().authenticated() .and().csrf().disable() //指定支持基于表單的身份驗(yàn)證。如果未指定FormLoginConfigurer#loginPage(String),則將生成默認(rèn)登錄頁(yè)面 .formLogin() // 此開始 .loginPage("/login") //security 自帶登入接口 .permitAll() .and() //此結(jié)束 .headers().frameOptions().disable() .and() .rememberMe().tokenValiditySeconds(1209600) .and() .logout() .permitAll(); } }
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺談javaSE 面向?qū)ο?Object類toString)
下面小編就為大家?guī)硪黄獪\談javaSE 面向?qū)ο?Object類toString)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06打開.properties中文顯示unicode編碼問題以及解決
這篇文章主要介紹了打開.properties中文顯示unicode編碼問題以及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01使用BigDecimal去掉小數(shù)點(diǎn)后無用的0
這篇文章主要介紹了使用BigDecimal去掉小數(shù)點(diǎn)后無用的0操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Springboot 使用具體化類和配置來縮短單元測(cè)試時(shí)間
這篇文章主要介紹了Springboot 使用具體化類和配置來縮短單元測(cè)試時(shí)間,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11SpringBoot2 參數(shù)管理實(shí)踐之入?yún)⒊鰠⑴c校驗(yàn)的方式
這篇文章主要介紹了SpringBoot2 參數(shù)管理實(shí)踐,入?yún)⒊鰠⑴c校驗(yàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-06-06springboot starter自定義實(shí)現(xiàn)公共模塊方式
這篇文章主要介紹了springboot starter自定義實(shí)現(xiàn)公共模塊方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08【面試】Spring事務(wù)面試考點(diǎn)吐血整理(建議珍藏)
本文是小編給大家收藏整理的Spring事務(wù)面試考點(diǎn),非常不錯(cuò),值得收藏,感興趣的朋友參考下吧2019-04-04Spark?集群執(zhí)行任務(wù)失敗的故障處理方法
這篇文章主要為大家介紹了Spark?集群執(zhí)行任務(wù)失敗的故障處理方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02struts2如何使用攔截器進(jìn)行用戶權(quán)限控制實(shí)例
本篇文章主要介紹了struts2如何使用攔截器進(jìn)行用戶權(quán)限控制實(shí)例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-05-05