解決spring security中遇到的問(wèn)題
spring security中遇到的問(wèn)題
1.An Authentication object was not found in the Security Context
在security上下文中沒(méi)有找到一個(gè)認(rèn)證對(duì)象,我這邊的問(wèn)題在于controller中方法添加了認(rèn)證注解,但是配置類(lèi)中

源自于一片我為了解決攔截靜態(tài)文件的博客,上面說(shuō)這個(gè)忽視目錄會(huì)以classpath中的static文件夾,實(shí)際上這樣寫(xiě)有著很大問(wèn)題,這邊會(huì)讓所有的文件不攔截,雖然你的http認(rèn)證添加了攔截,但是web這個(gè)會(huì)影響到效果,所以一邊允許所有文件不攔截,一邊controller中添加了需要認(rèn)證的注解,所以你一訪問(wèn)就會(huì)進(jìn)去這個(gè)頁(yè)面,但是進(jìn)去之后發(fā)現(xiàn)在security context并沒(méi)有這個(gè)角色值,所以就會(huì)出現(xiàn)這個(gè)異常
最后對(duì)這個(gè)異常說(shuō)明一句話:這個(gè)普通來(lái)看就是越過(guò)了普通的往上下文中添加了角色但是進(jìn)去了這個(gè)頁(yè)面就會(huì)出現(xiàn)這個(gè)錯(cuò)誤
2.攔截登錄之后總是會(huì)進(jìn)login?error,而且沒(méi)有提示
這個(gè)情況還是有錯(cuò)誤提示才會(huì)好解決問(wèn)題,在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ò)誤打印出來(lái),然后我們?cè)俑鶕?jù)實(shí)際問(wèn)題進(jìn)行處理
3.Spring Security BadCredentialsException
這個(gè)具體原因還不是很清楚,但是有個(gè)很簡(jiǎn)單的解決辦法,把所有的密碼加密方式改為相同的,還不可以的話
單獨(dú)寫(xiě)一個(gè)配置類(lèi):
@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類(lèi)是我自己寫(xiě)個(gè)一個(gè)密碼加密類(lèi),不想使用的話也可以使用官方推薦的:BCryptPasswordEncoder
springboot用security遇到的問(wèn)題
如果項(xiàng)目中用了 security ,而不用 security 自帶的登入的話 ,會(huì)自動(dòng)跳轉(zhuǎn)其自帶的登入界面(前提是已攔截 放開(kāi)的可以直接訪問(wè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() // 此開(kāi)始
.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類(lèi)toString)
下面小編就為大家?guī)?lái)一篇淺談javaSE 面向?qū)ο?Object類(lèi)toString)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-06-06
打開(kāi).properties中文顯示unicode編碼問(wèn)題以及解決
這篇文章主要介紹了打開(kāi).properties中文顯示unicode編碼問(wèn)題以及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
使用BigDecimal去掉小數(shù)點(diǎn)后無(wú)用的0
這篇文章主要介紹了使用BigDecimal去掉小數(shù)點(diǎn)后無(wú)用的0操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
Springboot 使用具體化類(lèi)和配置來(lái)縮短單元測(cè)試時(shí)間
這篇文章主要介紹了Springboot 使用具體化類(lèi)和配置來(lái)縮短單元測(cè)試時(shí)間,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11
SpringBoot2 參數(shù)管理實(shí)踐之入?yún)⒊鰠⑴c校驗(yàn)的方式
這篇文章主要介紹了SpringBoot2 參數(shù)管理實(shí)踐,入?yún)⒊鰠⑴c校驗(yàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-06-06
springboot 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-04
Spark?集群執(zhí)行任務(wù)失敗的故障處理方法
這篇文章主要為大家介紹了Spark?集群執(zhí)行任務(wù)失敗的故障處理方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
struts2如何使用攔截器進(jìn)行用戶權(quán)限控制實(shí)例
本篇文章主要介紹了struts2如何使用攔截器進(jìn)行用戶權(quán)限控制實(shí)例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-05-05

