亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

spring中基于內存數據庫的身份認證和角色授權示例分析

發布時間:2021-11-17 10:46:23 來源:億速云 閱讀:141 作者:小新 欄目:大數據

這篇文章主要介紹spring中基于內存數據庫的身份認證和角色授權示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

一、引入依賴

<!--
https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-jpa
 使用jpa進行持久化-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
    <version>2.1.7.RELEASE</version>
</dependency>
<!--
https://mvnrepository.com/artifact/org.hsqldb/hsqldb
 使用內存數據庫-->
<dependency>
    <groupId>org.hsqldb</groupId>
    <artifactId>hsqldb</artifactId>
    <version>2.5.0</version>
</dependency>

二、新建相關文件

spring中基于內存數據庫的身份認證和角色授權示例分析

@Component
public class CustomUserDetailService implements UserDetailsService {

    @Autowired
    private UserInfoService userInfoService;

    @Autowired
    private PasswordEncoder passwordEncoder;


    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
        /*
          1 通過username獲取到userInfo信息
          2 通過User(username,password,authorities)返回UserDetails
         */
        UserInfo userInfo = userInfoService.findByusername(username);
        if(userInfo == null ) {
            throw new UsernameNotFoundException("NOT FOUND");
        }
        List<GrantedAuthority> authorities = new ArrayList<GrantedAuthority>();
        authorities.add(new SimpleGrantedAuthority("ROLE_"+userInfo.getRole().name()));
        User userDetails = new User(userInfo.getUsername(),passwordEncoder.encode(userInfo.getPassword()),authorities);
        return  userDetails;
    }
}
/**
 * 用戶實體類,主要存儲用戶的登錄名和密碼
 */
@Entity //持久化配置
public class UserInfo {
    @Id @GeneratedValue
    private long uid; //主鍵
    private String username; //用戶名
    private String password;  //密碼
    @Enumerated(EnumType.STRING)
    private Role role;

    public Role getRole() {
        return role;
    }

    public void setRole(Role role) {
        this.role = role;
    }

    public enum Role {
        admin,normal
    }
    public long getUid() {
        return uid;
    }

    public void setUid(long uid) {
        this.uid = uid;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}
@Service
public class DataInit {
    @Autowired
    private UserInfoRepository userInfoRepository;

@PostConstruct
    public void dataInit(){
        UserInfo admin = new UserInfo();
        admin.setUsername("admin");
        admin.setPassword("000000");
        admin.setRole(UserInfo.Role.admin);
        userInfoRepository.save(admin);
    }
}
public interface UserInfoRepository extends JpaRepository<UserInfo,Long> {
    public UserInfo findByusername(String username);
}
@Service
public class UserInfoServiceImpl implements UserInfoService {

    @Autowired
    private UserInfoRepository userInfoRepository;

    @Override
    public UserInfo findByusername(String username) {
        return userInfoRepository.findByusername(username);
    }
}
public interface UserInfoService {
    public UserInfo findByusername(String username);
}

以上是“spring中基于內存數據庫的身份認證和角色授權示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

多伦县| 茶陵县| 永宁县| 麻江县| 新丰县| 逊克县| 汤原县| 双鸭山市| 皮山县| 五指山市| 东兰县| 长白| 桓仁| 曲阳县| 麻城市| 廉江市| 百色市| 栾川县| 文昌市| 松溪县| 黑山县| 大城县| 永平县| 凌云县| 敖汉旗| 乌兰县| 高州市| 河北区| 志丹县| 太湖县| 同德县| 凤山县| 台东县| 滁州市| 丰顺县| 宜川县| 呼和浩特市| 鹰潭市| 石首市| 正安县| 定结县|