欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Security使用數據庫認證及用戶密碼加密和解密功能

 更新時間:2020年03月01日 15:53:58   作者:szhwwjava  
這篇文章主要介紹了Spring Security使用數據庫認證及用戶密碼加密和解密,本文通過代碼與截圖的形式給大家介紹的非常詳細,對大家的工作或學習具有一定的參考借鑒價值,需要的朋友可以參考下

流程圖:

1.接上一篇博客https://mp.csdn.net/console/editor/html/104576494,準備好環(huán)境。

2.spring-security.xml中的配置:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:security="http://www.springframework.org/schema/security"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://www.springframework.org/schema/beans     
  http://www.springframework.org/schema/beans/spring-beans.xsd     
  http://www.springframework.org/schema/security     
  http://www.springframework.org/schema/security/spring-security.xsd">
  
  <!-- 配置不攔截的資源 -->
  <security:http pattern="/login.jsp" security="none"/>
  <security:http pattern="/failer.jsp" security="none"/>
  <security:http pattern="/css/**" security="none"/>
  <security:http pattern="/img/**" security="none"/>
  <security:http pattern="/plugins/**" security="none"/>
  
  <!-- 
    配置具體的規(guī)則 
    auto-config="true"  不用自己編寫登錄的頁面,框架提供默認登錄頁面
    use-expressions="false"  是否使用SPEL表達式(沒學習過)
  -->
  <security:http auto-config="true" use-expressions="false">
    <!-- 配置具體的攔截的規(guī)則 pattern="請求路徑的規(guī)則" access="訪問系統(tǒng)的人,必須有ROLE_USER或者ROLE_ADMIN的角色" -->
    <security:intercept-url pattern="/**" access="ROLE_USER,ROLE_ADMIN"/>
    
    <!-- 定義跳轉的具體的頁面 -->
    <security:form-login 
      login-page="/login.jsp"
      login-processing-url="/login.do"http://請求路徑
      default-target-url="/index.jsp"
      authentication-failure-url="/failer.jsp"
      authentication-success-forward-url="/pages/main.jsp"
    />
    
    <!-- 關閉跨域請求 -->
    <security:csrf disabled="true"/>
    
    <!-- 只要訪問到/logout.do就退出,自動跳轉到/login.jsp頁面 -->
    <security:logout invalidate-session="true" logout-url="/logout.do" logout-success-url="/login.jsp" />
    
  </security:http>
  
  <!-- 切換成數據庫中的用戶名和密碼 -->
  <security:authentication-manager>
    <security:authentication-provider user-service-ref="userService">//userService是認證器需要定義出來
       <!-- 配置加密的方式,用戶登錄的時候可以知道 -->
      <security:password-encoder ref="passwordEncoder"/>
    </security:authentication-provider>
  </security:authentication-manager>
  
  <!-- 配置加密類,當添加用戶的時候,對用戶密碼進行加密 -->
  <bean id="passwordEncoder" class="org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder"/>
  
  <!-- 提供了入門的方式,在內存中存入用戶名和密碼 
  <security:authentication-manager>
    <security:authentication-provider>
      <security:user-service>
        <security:user name="admin" password="{noop}admin" authorities="ROLE_USER"/>
      </security:user-service>
    </security:authentication-provider>
  </security:authentication-manager>
  -->
  
 </beans>  

 3.定義一個IUserService繼承UserDetailsService接口:

在創(chuàng)建一個UserServiceImpl去實現(xiàn)IUserService接口,覆蓋loadUserByUsername方法:

 @Service("userService")//這個名字必須與spring-security.xml中配置的認證器名字一樣

public class UserServiceImpl implements IUserService {
  @Autowired
  private IUserDao userDao;
  @Autowired//當執(zhí)行保存用戶的時候對用戶的密碼進行加密
  private BCryptPasswordEncoder bCryptPasswordEncoder;
  @Override
  public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
    UserInfo userInfo = null;
    try {
      userInfo = userDao.findByUsername(username);//調用到層根據用戶查找用戶信息,返回值為UserInfo對象
    } catch (Exception e) {
      e.printStackTrace();
    }
    //處理自己的用戶對象封裝成UserDetails
    // User user=new User(userInfo.getUsername(),"{noop}"+userInfo.getPassword(),getAuthority(userInfo.getRoles()));//下面這個三元表達式代表該賬戶是否激活可用
    User user = new User(userInfo.getUsername(), userInfo.getPassword(), userInfo.getStatus() == 0 ? false : true, true, true, true, getAuthority(userInfo.getRoles()));
    return user;
  }
  //作用就是返回一個List集合,集合中裝入的是角色描述
  public List<SimpleGrantedAuthority> getAuthority(List<Role> roles) {
    List<SimpleGrantedAuthority> list = new ArrayList<>();
    for (Role role : roles) {
      list.add(new SimpleGrantedAuthority("ROLE_" + role.getRoleName()));
    }
    return list;
  }
  /**
   * 用戶的添加
   * @param userInfo
   */
  @Override
  public void save(UserInfo userInfo) throws Exception {
    //對密碼進行加密處理
    userInfo.setPassword(bCryptPasswordEncoder.encode(userInfo.getPassword()));
    userDao.save(userInfo);
  }
}

  4.啟動項目進行測試添加用戶,新添加的用戶是否可以登錄成功。

總結

到此這篇關于Spring Security使用數據庫認證及用戶密碼加密和解密功能的文章就介紹到這了,更多相關Spring Security數據庫認證內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java多線程局域網聊天室的實現(xiàn)

    Java多線程局域網聊天室的實現(xiàn)

    在學習了一個學期的java以后,搞了一個多線程的聊天室,熟悉了一下服務器和客戶機的操作。感興趣的小伙伴們可以參考一下
    2021-06-06
  • idea兩側的maven-project-structure圖標不見了如何解決

    idea兩側的maven-project-structure圖標不見了如何解決

    這篇文章主要介紹了如何解決idea兩側的maven-project-structure圖標不見了問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 基于hibernate框架在eclipse下的配置方法(必看篇)

    基于hibernate框架在eclipse下的配置方法(必看篇)

    下面小編就為大家?guī)硪黄趆ibernate框架在eclipse下的配置方法(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • Spring RestTemplate基本使用介紹

    Spring RestTemplate基本使用介紹

    這篇文章主要介紹了Spring RestTemplate基本使用介紹,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • 基于Java中throw和throws的區(qū)別(詳解)

    基于Java中throw和throws的區(qū)別(詳解)

    下面小編就為大家?guī)硪黄贘ava中throw和throws的區(qū)別(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Mybatis實現(xiàn)分包定義數據庫的原理與過程

    Mybatis實現(xiàn)分包定義數據庫的原理與過程

    這篇文章主要給大家介紹了關于Mybatis實現(xiàn)分包定義數據庫的原理與過程,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2022-01-01
  • eclipse中maven插件安裝教程

    eclipse中maven插件安裝教程

    這篇文章主要為大家詳細介紹了eclipse中maven插件安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • java數據結構和算法學習之漢諾塔示例

    java數據結構和算法學習之漢諾塔示例

    這篇文章主要介紹了java數據結構和算法中的漢諾塔示例,需要的朋友可以參考下
    2014-02-02
  • Java Runtime用法實戰(zhàn)案例

    Java Runtime用法實戰(zhàn)案例

    這篇文章主要介紹了Java Runtime用法,結合實例形式分析了Runtime針對系統(tǒng)內存、處理器信息的獲取相關操作技巧,需要的朋友可以參考下
    2019-07-07
  • Java分析講解序列化與字典功能的序列化

    Java分析講解序列化與字典功能的序列化

    在項目開發(fā)地過程中經常會用到字典存儲某些可配置的值,但相應的也會給開發(fā)帶來復雜度,比如數據庫存儲的值為字典值:0,1,2,3這種類型的值,但是前端頁面卻需要展示為 啟動、禁用、刪除 等中文狀態(tài),下面我們來看兩種解決方案
    2022-06-06

最新評論