当前位置: 首页 > news >正文

中文简洁网站设计图上海网站建设公司

中文简洁网站设计图,上海网站建设公司,灵犀科技网站建设,专业网站设计师去哪找文章目录 SpringBoot整合SpringSecurity详解一、引言二、引入依赖三、配置 Spring Security四、自定义用户详细信息服务五、使用示例1. 创建用户实体类2. 测试登录功能 六、总结 SpringBoot整合SpringSecurity详解 一、引言 在当今的软件开发中,安全是一个至关重要…

文章目录

  • SpringBoot整合SpringSecurity详解
    • 一、引言
    • 二、引入依赖
    • 三、配置 Spring Security
    • 四、自定义用户详细信息服务
    • 五、使用示例
      • 1. 创建用户实体类
      • 2. 测试登录功能
    • 六、总结

SpringBoot整合SpringSecurity详解

在这里插入图片描述

一、引言

在当今的软件开发中,安全是一个至关重要的方面。Spring Security 是一个强大且可扩展的 Java 安全框架,用于保护基于 Spring 的应用程序。它提供了身份验证、授权和多种安全防护机制,如 CSRF 保护和防止会话劫持等。通过与 Spring Boot 的无缝集成,Spring Security 成为构建安全应用的理想选择。本文将详细介绍如何在 Spring Boot 应用程序中整合 Spring Security,包括配置、用户认证和授权等关键步骤。

二、引入依赖

在开始之前,我们需要在 Spring Boot 项目中引入 Spring Security 相关的依赖。在 pom.xml 文件中添加以下依赖:

xml复制

<!-- Spring Security Starter -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId><version>3.3.4</version>
</dependency><!-- JWT 依赖,用于生成和解析 JSON Web Tokens -->
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-api</artifactId><version>0.12.6</version>
</dependency>
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-impl</artifactId><version>0.12.6</version><scope>runtime</scope>
</dependency>
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-jackson</artifactId><version>0.12.6</version><scope>runtime</scope>
</dependency>

三、配置 Spring Security

接下来,我们需要创建一个配置类 SecurityConfig,用于管理所有与 Spring Security 相关的配置。这个类需要使用 @EnableWebSecurity 注解来启用 Spring Security 的 web 安全功能。

java复制

@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {@Autowiredprivate CustomUserDetailsService userDetailsService;@Overrideprotected void configure(HttpSecurity http) throws Exception {http.csrf().disable() // 关闭 CSRF 保护.authorizeRequests().antMatchers("/login", "/register").permitAll() // 允许匿名访问登录和注册页面.anyRequest().authenticated() // 其他所有请求都需要认证.and().formLogin().loginPage("/login").permitAll() // 自定义登录页面.defaultSuccessUrl("/home", true) // 登录成功后跳转到主页.and().logout().permitAll(); // 允许注销}@Autowiredpublic void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {auth.userDetailsService(userDetailsService).passwordEncoder(passwordEncoder());}@Beanpublic PasswordEncoder passwordEncoder() {return new BCryptPasswordEncoder();}
}

在上述配置中,我们禁用了 CSRF 保护,允许匿名访问登录和注册页面,并且所有其他请求都需要认证。我们还自定义了登录页面和登录成功后的跳转页面。此外,我们配置了用户详细信息服务和密码编码器。

四、自定义用户详细信息服务

为了加载用户的详细信息,我们需要实现 UserDetailsService 接口。这个接口提供了一个方法 loadUserByUsername,用于根据用户名加载用户信息。

java复制

@Service
public class CustomUserDetailsService implements UserDetailsService {@Autowiredprivate UserRepository userRepository;@Overridepublic UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {User user = userRepository.findByUsername(username);if (user == null) {throw new UsernameNotFoundException("User not found");}return new org.springframework.security.core.userdetails.User(user.getUsername(), user.getPassword(), true, true, true, true, user.getAuthorities());}
}

在这个实现中,我们从数据库中查找用户信息,并返回一个 UserDetails 对象。如果用户不存在,则抛出 UsernameNotFoundException 异常。

五、使用示例

1. 创建用户实体类

首先,我们需要创建用户、角色和权限的实体类。这些实体类将用于存储用户信息和权限信息。

java复制

package com.geli.domain;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
import java.util.Date;
import java.util.Set;@NoArgsConstructor
@AllArgsConstructor
@Data
public class User implements Serializable {private Integer id;private String username;private String password;private String addUser;private String editUser;private Date addDate;private Date updateDate;private Role role;
}@NoArgsConstructor
@Data
public class Role implements Serializable {private Integer id;private String name;private String keyWord;private String description;private Set<Permission> permissionList;
}@Data
@NoArgsConstructor
public class Permission implements Serializable {private Integer id;private String name;private String keyWord;private String description;
}

2. 测试登录功能

为了测试登录功能,我们可以在 UserServiceImpl 中添加一个用户账号,并尝试登录。

java复制

import com.geli.service.UserService;
import org.springframework.stereotype.Service;@Service
public class UserServiceImpl implements UserService {@Overridepublic User findUserByUserName(String username) {User user = new User();user.setId(1);user.setUsername("D46033");user.setPassword("$2a$10$Pgs46f8LzTjOvA5Sg6qDkOBbUoAtWQQdHFoEbbmWPak.34/NwJQrW");return user;}
}

登录成功后,用户将被重定向到自定义的主页。

六、总结

本文详细介绍了如何在 Spring Boot 应用程序中整合 Spring Security,包括引入依赖、配置安全策略、自定义用户详细信息服务和测试登录功能。通过这些步骤,您可以为您的应用程序提供强大的安全保护。希望本文对您有所帮助,如果您有任何问题或建议,请随时留言。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • spring security 超详细使用教程(接入springboot、前后端分离)
  • SpringBoot整合SpringSecurity详细教程(实战开发讲解)
http://www.mmbaike.com/news/51327.html

相关文章:

  • 福建 建设网站网站在线制作
  • 邯郸普通网站建设关键词优化是什么
  • 网站建设智能小程序怎么提升关键词的质量度
  • 网站建设首页图片插入广州seo网站推广
  • 合肥网站建设河南专业网站建设
  • 网站建设硬件预算山西seo优化
  • 如何在网站做宣传seo搜索引擎优化的内容
  • 医院做网站开发免费发布信息网
  • 做农业网站百度广告投放电话
  • 手机访问wordpress说说seo论坛
  • pc做网站深圳seo推广外包
  • 你做的网站会不会被人模仿网站制作企业
  • 网站建设推广 公司搜索引擎优化实训报告
  • 上海中艺建设集团网站软文是指什么
  • 织梦网站环境搭建黄金网站app视频播放画质选择
  • php律师网站源码百度app安装下载免费
  • 吴中区企业网站制作哪家靠谱今日新闻内容
  • 长沙房产集团网站建设百度软件安装
  • 自己做自己的私人网站小程序推广运营的公司
  • 网站改版做重定向公司网站推广技巧
  • 网站直播间怎么做网店代运营靠谱吗
  • 网页设计作品集展示su搜索引擎优化
  • 南通网站定制搭建服务之家网站推广
  • 营销型网站的建设规划杭州网站优化公司哪家好
  • 小学生网站制作手机系统优化软件哪个好
  • 网站的例子交换友情链接平台
  • 做网站一年百万没被屏蔽的国外新闻网站
  • 广东网站建设英铭科技做app找什么公司
  • 网站做淘宝推广收入推广公司有哪些
  • 做蛋糕哪个教程网站好软文网站