日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Spring Security 密碼驗證動態加鹽的驗證處理方法

瀏覽:77日期:2023-07-11 10:47:35

本文個人博客地址:https://www.leafage.top/posts/detail/21697I2R

最近幾天在改造項目,需要將gateway整合security在一起進行認證和鑒權,之前gateway和auth是兩個服務,auth是shiro寫的一個,一個filter和一個配置,內容很簡單,生成token,驗證token,沒有其他的安全檢查,然后讓對項目進行重構。

先是要整合gateway和shiro,然而因為gateway是webflux,而shiro-spring是webmvc,所以沒搞成功,如果有做過并成功的,請告訴我如何進行整合,非常感謝。

那整合security呢,因為spring cloud gateway基于webflux,所以網上很多教程是用不了的,webflux的配置會有一些變化,具體看如下代碼示例:

import io.leafage.gateway.api.HypervisorApi;import io.leafage.gateway.handler.ServerFailureHandler;import io.leafage.gateway.handler.ServerSuccessHandler;import io.leafage.gateway.service.JdbcReactiveUserDetailsService;import org.springframework.context.annotation.Bean;import org.springframework.http.HttpMethod;import org.springframework.http.HttpStatus;import org.springframework.security.config.annotation.web.reactive.EnableWebFluxSecurity;import org.springframework.security.config.web.server.ServerHttpSecurity;import org.springframework.security.core.userdetails.ReactiveUserDetailsService;import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;import org.springframework.security.crypto.password.PasswordEncoder;import org.springframework.security.web.server.SecurityWebFilterChain;import org.springframework.security.web.server.authentication.HttpStatusServerEntryPoint;import org.springframework.security.web.server.authentication.ServerAuthenticationFailureHandler;import org.springframework.security.web.server.authentication.ServerAuthenticationSuccessHandler;import org.springframework.security.web.server.authentication.logout.HttpStatusReturningServerLogoutSuccessHandler;import org.springframework.security.web.server.csrf.CookieServerCsrfTokenRepository;/** * spring security config . * * @author liwenqiang 2019/7/12 17:51 */@EnableWebFluxSecuritypublic class ServerSecurityConfiguration { // 用于獲取遠程數據 private final HypervisorApi hypervisorApi; public ServerSecurityConfiguration(HypervisorApi hypervisorApi) {this.hypervisorApi = hypervisorApi; } /** * 密碼配置,使用BCryptPasswordEncoder * * @return BCryptPasswordEncoder 加密方式 */ @Bean protected PasswordEncoder passwordEncoder() {return new BCryptPasswordEncoder(); } /** * 用戶數據加載 * * @return JdbcReactiveUserDetailsService 接口 */ @Bean public ReactiveUserDetailsService userDetailsService() {// 自定義的ReactiveUserDetails 實現return new JdbcReactiveUserDetailsService(hypervisorApi); } /** * 安全配置 */ @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) {http.formLogin(f -> f.authenticationSuccessHandler(authenticationSuccessHandler()).authenticationFailureHandler(authenticationFailureHandler())).logout(l -> l.logoutSuccessHandler(new HttpStatusReturningServerLogoutSuccessHandler())).csrf(c -> c.csrfTokenRepository(CookieServerCsrfTokenRepository.withHttpOnlyFalse())).authorizeExchange(a -> a.pathMatchers(HttpMethod.OPTIONS).permitAll().anyExchange().authenticated()).exceptionHandling(e -> e.authenticationEntryPoint(new HttpStatusServerEntryPoint(HttpStatus.UNAUTHORIZED)));return http.build(); } /** * 登陸成功后執行的處理器 */ private ServerAuthenticationSuccessHandler authenticationSuccessHandler() {return new ServerSuccessHandler(); } /** * 登陸失敗后執行的處理器 */ private ServerAuthenticationFailureHandler authenticationFailureHandler() {return new ServerFailureHandler(); }}

上面的示例代碼,是我開源項目中的一段,一般的配置就如上面寫的,就可以使用了,但是由于我們之前的項目中的是shiro,然后有一個自定義的加密解密的邏輯。

首先說明一下情況,之前那一套加密(前端MD5,不加鹽,然后數據庫存儲的是加鹽后的數據和對應的鹽(每個賬號一個),要登錄比較之前對密碼要獲取動態的鹽,然后加鹽進行MD5,再進行對比,但是在配置的時候是沒法獲取某一用戶的鹽值)

所以上面的一版配置是沒法通過驗證的,必須在驗證之前,給請求的密碼混合該賬號對應的鹽進行二次加密后在對比,但是這里就有問題了:

security 框架提供的幾個加密解密工具沒有MD5的方式; security 配置加密解密方式的時候,無法填入動態的賬號的加密鹽;

對于第一個問題還好處理,解決方式是:自定義加密解密方式,然后注入到配置類中,示例如下:

import cn.hutool.crypto.SecureUtil;import com.ichinae.imis.gateway.utils.SaltUtil;import org.springframework.security.crypto.codec.Utf8;import org.springframework.security.crypto.password.PasswordEncoder;import java.security.MessageDigest;/** * 自定義加密解密 */public class MD5PasswordEncoder implements PasswordEncoder { @Override public String encode(CharSequence charSequence) {String salt = SaltUtil.generateSalt();return SecureUtil.md5(SecureUtil.md5(charSequence.toString()) + salt); } @Override public boolean matches(CharSequence charSequence, String encodedPassword) {byte[] expectedBytes = bytesUtf8(charSequence.toString());byte[] actualBytes = bytesUtf8(charSequence.toString());return MessageDigest.isEqual(expectedBytes, actualBytes); } private static byte[] bytesUtf8(String s) {// need to check if Utf8.encode() runs in constant time (probably not).// This may leak length of string.return (s != null) ? Utf8.encode(s) : null; }}

第二個問題的解決辦法,找了很多資料,也沒有找到,后來查看security的源碼發現,可以在UserDetailsService接口的findByUsername()方法中,在返回UserDetails實現的時候,使用默認實現User的UserBuilder內部類來解決這個問題,因為UserBuilder類中有一個屬性,passwordEncoder屬性,它是Fucntion<String, String>類型的,默認實現是 password -> password,即對密碼不做任何處理,先看下它的源碼:

Spring Security 密碼驗證動態加鹽的驗證處理方法

再看下解決問題之前的findByUsername()方法:

@Servicepublic class UserDetailsServiceImpl implements ReactiveUserDetailsService { @Resource private RemoteService remoteService; @Override public Mono<UserDetails> findByUsername(String username) {return remoteService.getUser(username).map(userBO -> User.builder().username(username).password(userBO.getPassword()).authorities(grantedAuthorities(userBO.getAuthorities())).build()); } private Set<GrantedAuthority> grantedAuthorities(Set<String> authorities) {return authorities.stream().map(SimpleGrantedAuthority::new).collect(Collectors.toSet()); }}

那找到了問題的解決方法,就來改代碼了,如下所示:

新增一個代碼處理方法

private Function<String, String> passwordEncoder(String salt) { return rawPassword -> SecureUtil.md5(rawPassword + salt);}

然后添加builder鏈

@Servicepublic class UserDetailsServiceImpl implements ReactiveUserDetailsService { @Resource private RemoteService remoteService; @Override public Mono<UserDetails> findByUsername(String username) {return remoteService.getUser(username).map(userBO -> User.builder().passwordEncoder(passwordEncoder(userBO.getSalt())) //在這里設置動態的鹽.username(username).password(userBO.getPassword()).authorities(grantedAuthorities(userBO.getAuthorities())).build()); } private Set<GrantedAuthority> grantedAuthorities(Set<String> authorities) {return authorities.stream().map(SimpleGrantedAuthority::new).collect(Collectors.toSet()); } private Function<String, String> passwordEncoder(String salt) {return rawPassword -> SecureUtil.md5(rawPassword + salt); }}

然后跑一下代碼,請求登錄接口,就登陸成功了。

Spring Security 密碼驗證動態加鹽的驗證處理方法

以上就是Spring Security 密碼驗證動態加鹽的驗證處理的詳細內容,更多關于Spring Security密碼驗證的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产毛片久久久| 免费国产亚洲视频| 欧美一区精品| 日本综合视频| 欧美一级二区| 久久狠狠亚洲综合| 欧美日韩一区二区三区在线电影| 在线精品视频一区| 日韩在线网址| 国产日产精品_国产精品毛片 | 免费日韩一区二区三区| 91成人在线精品视频| 欧美一级网址| 欧美1区二区| 国产激情在线播放| 久久精品在线| 免费在线观看视频一区| 日韩高清不卡在线| 美女视频黄 久久| 91精品韩国| 免播放器亚洲| 欧美视频一区| 欧美国产免费| 久久精品观看| 少妇精品久久久一区二区| 国产精品九九| 久久免费高清| 中文字幕亚洲影视| 欧美激情亚洲| 1024精品一区二区三区| 性一交一乱一区二区洋洋av| 青草综合视频| 色在线视频观看| 男人的天堂久久精品| 国产亚洲久久| 91tv亚洲精品香蕉国产一区| 国产精品日本| 欧美伊人影院| 国产欧洲在线| 蜜桃久久av一区| 精品99在线| 国产美女精品| 麻豆精品少妇| 欧美91精品| 国产精品亚洲四区在线观看| 日韩电影在线视频| 免费看日韩精品| 精品一级视频| 丝袜国产日韩另类美女| 国产精品毛片久久久| 日韩大片在线| 日韩欧美久久| 亚洲欧洲高清| 亚洲日本国产| 波多野结衣久久精品| 中文一区一区三区免费在线观| 国产精品一区2区3区| 欧美91精品| 久久精品国产久精国产爱| 亚洲免费高清| 高清av一区| 日韩精品第二页| 欧美不卡高清| 精品日韩在线| 四虎在线精品| 亚洲二区视频| 久久亚州av| 免费久久久久久久久| 欧美/亚洲一区| 免播放器亚洲一区| 婷婷精品久久久久久久久久不卡| 欧美日韩精品一区二区三区视频| 美女视频黄久久| 亚洲午夜在线| 久热精品在线| 亚洲精品自拍| 亚洲成人一区在线观看| 国产精品扒开腿做爽爽爽软件| 视频一区欧美精品| 日韩和欧美的一区| 欧美一区二区三区激情视频| 国产精品手机在线播放| 丝袜av一区| 国产一区二区三区四区| 日本色综合中文字幕| 一区三区视频| 久久国产日本精品| 亚洲黄色免费av| 国产精品115| 日韩国产精品久久久久久亚洲| 久久婷婷激情| а√在线中文在线新版| 久久免费精品| 国产精品一线天粉嫩av| 综合国产精品| 午夜精品婷婷| 在线精品亚洲欧美日韩国产| 国产日韩一区二区三区在线 | 视频一区日韩精品| 免费av一区二区三区四区| 国产美女高潮在线| 日韩88av| 日韩1区在线| 国产不卡一区| 国产中文字幕一区二区三区| 久久99青青| 欧美成人aaa| 国产九九精品| 91精品国产自产在线丝袜啪| 亚洲ww精品| 最新国产精品视频| 亚洲乱码视频| 日韩欧美美女在线观看| 日本不卡不码高清免费观看 | 新版的欧美在线视频| 日韩精品不卡一区二区| 一区二区精品伦理...| 国产中文字幕一区二区三区| 国产中文字幕一区二区三区| 精品视频91| 91亚洲国产| 青青久久av| 蜜臀av免费一区二区三区| 亚洲成人日韩| 在线观看一区| 日韩不卡手机在线v区| 欧美一区自拍| 麻豆国产91在线播放| 精品国产18久久久久久二百| 亚洲女同av| 亚洲激精日韩激精欧美精品| 久久国产成人| 亚洲日本欧美| 国产精品xxx在线观看| 久久久免费人体| 国产不卡av一区二区| 欧美日韩视频免费观看| 一区在线免费观看| 亚洲精品日韩久久| 国产精品欧美三级在线观看| 精品国产乱码久久久久久樱花| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 久久99视频| 中文字幕在线视频久| 国产91精品对白在线播放| 亚洲欧美日韩国产一区| 日韩精品成人在线观看| 麻豆91精品91久久久的内涵| 日韩欧美午夜| 欧美天堂亚洲电影院在线观看| 免费视频久久| 久久国内精品| 免费高潮视频95在线观看网站| 日韩视频一区二区三区在线播放免费观看| 蜜臀久久99精品久久久久宅男| 日韩二区三区在线观看| 精品一区二区三区在线观看视频| 日韩精品中文字幕第1页| 欧美1级日本1级| 日韩在线网址| 激情国产在线| 欧美专区18| 欧美成人aaa| 欧美日韩国产在线一区| 日韩高清在线不卡| 91视频一区| 免费观看在线综合| 久久免费精品| av不卡在线| 欧美91在线| 国产精品女主播一区二区三区| 国产精品nxnn| 久久国产电影| 日韩avvvv在线播放| 欧美sss在线视频| 97久久超碰| 91精品二区| 久久三级中文| 视频在线观看国产精品| 精品日韩一区| 亚洲人成毛片在线播放女女| 国产精品tv| 亚洲免费一区二区| 国产精品成人一区二区不卡| 三级欧美韩日大片在线看| 精品国产黄a∨片高清在线| 久久国产66| 国产成人在线中文字幕| 日韩精品一二三四| 日韩欧美二区| 国产精品最新| 亚洲一区二区三区四区电影| 日韩一区亚洲二区| 日本免费新一区视频| 亚洲国内欧美| 国产中文欧美日韩在线| 日韩专区视频网站| 午夜精品影院| 成人美女视频| 国产精品22p|