日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

SpringSecurity自定义UsernamePasswordAuthenticationFilter

發布時間:2025/3/16 javascript 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SpringSecurity自定义UsernamePasswordAuthenticationFilter 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

UsernamePasswordAuthenticationFilter介紹

UsernamePasswordAuthenticationFilter是AbstractAuthenticationProcessingFilter針對使用用戶名和密碼進行身份驗證而定制化的一個過濾器。其添加是在調用http.formLogin()時作用,默認的登錄請求pattern為"/login",并且為POST請求。當我們登錄的時候,也就是匹配到loginProcessingUrl,這個過濾器就會委托認證管理器authenticationManager來驗證登錄。

自定義UsernamePasswordAuthenticationFilter

這里我的需求是通過自定義UsernamePasswordAuthenticationFilter實現對前端傳過來的密碼進行RSA私鑰解密,并且因為登錄地址不是"/login",所以繼承的是AbstractAuthenticationProcessingFilter,如果登錄地址為默認,那么可直接繼承UsernamePasswordAuthenticationFilter重寫attemptAuthentication方法即可。

public class MyUsernamePasswordAuthenticationFilter extends AbstractAuthenticationProcessingFilter {public static final String SPRING_SECURITY_FORM_USERNAME_KEY = "username";public static final String SPRING_SECURITY_FORM_PASSWORD_KEY = "password";private String usernameParameter = SPRING_SECURITY_FORM_USERNAME_KEY;private String passwordParameter = SPRING_SECURITY_FORM_PASSWORD_KEY;private boolean postOnly = true;private String privateKey = "xxxxxxxxxxxxxxxxxxx";public MyUsernamePasswordAuthenticationFilter() {super(new AntPathRequestMatcher("/oauth/token", "POST"));}public Authentication attemptAuthentication(HttpServletRequest request, HttpServletResponse response)throws AuthenticationException {if (postOnly && !request.getMethod().equals("POST")) {throw new AuthenticationServiceException("Authentication method not supported: " + request.getMethod());}String username = obtainUsername(request);String password = obtainPassword(request);try {password = RSAUtil.decrypt(password, privateKey);} catch (Exception e) {e.printStackTrace();}if (username == null) {username = "";}if (password == null) {password = "";}username = username.trim();UsernamePasswordAuthenticationToken authRequest = new UsernamePasswordAuthenticationToken(username, password);// Allow subclasses to set the "details" property setDetails(request, authRequest);return super.getAuthenticationManager().authenticate(authRequest);}public void setAuthenticationManager(AuthenticationManager authenticationManager) {super.setAuthenticationManager(authenticationManager);}protected String obtainPassword(HttpServletRequest request) {return request.getParameter(passwordParameter).replaceAll(" ", "+");}protected String obtainUsername(HttpServletRequest request) {return request.getParameter(usernameParameter);}protected void setDetails(HttpServletRequest request,UsernamePasswordAuthenticationToken authRequest) {authRequest.setDetails(authenticationDetailsSource.buildDetails(request));}public void setUsernameParameter(String usernameParameter) {Assert.hasText(usernameParameter, "Username parameter must not be empty or null");this.usernameParameter = usernameParameter;}public void setPasswordParameter(String passwordParameter) {Assert.hasText(passwordParameter, "Password parameter must not be empty or null");this.passwordParameter = passwordParameter;}public void setPostOnly(boolean postOnly) {this.postOnly = postOnly;}public final String getUsernameParameter() {return usernameParameter;}public final String getPasswordParameter() {return passwordParameter;}}

把自定義 MyUsernamePasswordAuthenticationFilter 添加到 Filter Chain 過濾器鏈中

在 SpringSecurity 的配置類中使用 http.addFilterAt(myAuthenticationFilter(), UsernamePasswordAuthenticationFilter.class) 把自定義的過濾器放在UsernamePasswordAuthenticationFilter 的位置,并為其設置認證成功和失敗的處理方法以及認證管理器AuthenticationManager

@Configuration @EnableWebSecurity @EnableGlobalMethodSecurity(prePostEnabled = true) public class SecurityConfig extends WebSecurityConfigurerAdapter {@Autowiredprivate AuthenticationSuccessHandler appLoginInSuccessHandler;@Bean@Overridepublic AuthenticationManager authenticationManagerBean() throws Exception {AuthenticationManager manager = super.authenticationManagerBean();return manager;}@Overrideprotected void configure(HttpSecurity http) throws Exception {http.authorizeRequests().anyRequest().authenticated().and().httpBasic().and().cors().disable().headers().frameOptions().sameOrigin();// 解決iframe無法訪問http.addFilterAt(myAuthenticationFilter(), UsernamePasswordAuthenticationFilter.class);}@Bean MyUsernamePasswordAuthenticationFilter myAuthenticationFilter() throws Exception {MyUsernamePasswordAuthenticationFilter filter = new MyUsernamePasswordAuthenticationFilter();filter.setAuthenticationManager(authenticationManagerBean());filter.setAuthenticationSuccessHandler(appLoginInSuccessHandler);filter.setAuthenticationFailureHandler(new AuthenticationFailureHandler() {@Overridepublic void onAuthenticationFailure(HttpServletRequest request, HttpServletResponse response, AuthenticationException e) throws IOException, ServletException {response.setContentType("application/json;charset=utf-8");response.getWriter().write(JSON.toJSONString(Respon.failed("登錄失敗!")));}});return filter;} }

自定義UsernamePasswordAuthenticationFilter的運用

除了上面的例子,還常用于修改表單登錄變為使用Json格式登錄,登錄驗證碼等等,需要注意的地方是UsernamePasswordAuthenticationFilter的默認登錄地址為

?

轉載于:https://www.cnblogs.com/dang-/p/11535940.html

總結

以上是生活随笔為你收集整理的SpringSecurity自定义UsernamePasswordAuthenticationFilter的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产少妇一区二区 | 成人做受视频试看60秒 | 久久国产经典 | 国产一区二区久久精品 | 国产在线视频自拍 | 欧美特级黄 | 性视频欧美 | 香蕉视频在线观看www | 伦理片一区二区 | 无遮挡在线观看 | 欧美性生交片4 | 欧美一区二区三区在线观看 | 成人黄色在线播放 | 在线激情| 亚洲欧美精品久久 | 成年人毛片 | 亚洲精品福利在线 | 都市豪门艳霸淫美妇 | 欧美孕交视频 | 久久久久亚洲日日精品 | 久久久久久国产精品视频 | 疯狂做受xxxx国产 | 欧美精品免费在线 | 日本美女全裸 | 精品国产999 | 麻豆国产精品 | 亚洲免费网站在线观看 | av无码av天天av天天爽 | 五月激情小说 | 丝袜老师扒开让我了一夜漫画 | 91视频啪啪| 国产精品久久视频 | 亚洲欧美一区二区三区四区五区 | 婷婷中文网 | 精品日本一区二区三区在线观看 | 成人无码一区二区三区 | 人人舔 | 成人黄色片在线观看 | av免费资源| 国产又粗又大又爽 | 日本黄色大片视频 | 亚洲精品97久久中文字幕无码 | 亚洲av无码一区二区乱子仑 | 久草免费在线观看视频 | 91麻豆成人精品国产 | 久艹av| 国产精品麻豆一区二区三区 | 丰满人妻一区二区三区性色 | 精品国产鲁一鲁一区二区三区 | 椎名由奈在线观看 | 国产精品一区二区三区久久 | 免费黄色入口 | 国产不卡在线观看视频 | 国产精品丝袜在线观看 | 东方av正在进入 | 天天干夜夜嗨 | 国产91精品高潮白浆喷水 | 在线a免费 | 久久精品国产99久久不卡 | 色婷婷久久一区二区三区麻豆 | www.色人阁.com | 熟妇人妻一区二区三区四区 | 成人人伦一区二区三区 | 中文字幕啪啪 | 黄页网站视频 | 玖草在线| 久久久久久国产精品免费 | 五月天天| 99只有精品| 日韩欧美三级 | www.成人av | 粗大的内捧猛烈进出在线视频 | 中文字幕久久久久久久 | 99ri精品 | 国产一区二区 | 毛片aa| www.国产在线视频 | 玖玖在线 | 欧美日韩加勒比 | 久久艹这里只有精品 | 精品人妻一区二区三区麻豆91 | 欧美色88| 国产在线免费视频 | 毛片一级免费 | 毛片在线免费观看视频 | 欧美人妖乱大交 | 日韩一区电影 | 精品视频一二三 | 国内精品嫩模av私拍在线观看 | 午夜性刺激免费视频 | 少妇被躁爽到高潮 | 午夜a级片| 欧美干| 日韩高清一级片 | 毛片一区二区三区 | av私库在线观看 | 人人干天天操 | 白俄罗斯毛片 | 97免费在线观看 |