当前位置:首页 > 技术 > 正文内容

Spring Boot 中集成 Spring Security 实现安全控制

访客 技术 2026年6月12日 1

添加核心依赖

在使用 Spring Boot 2.7.6 版本时,通过 Maven 管理项目依赖。需引入 Spring Security 的启动器模块以启用安全功能。

<properties>
    <java.version>1.8</java.version>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <spring-boot.version>2.7.6</spring-boot.version>
</properties>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-dependencies</artifactId>
            <version>${spring-boot.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
</dependencies>

默认安全机制验证

一旦引入 spring-boot-starter-security,所有 HTTP 接口将自动受到保护。启动应用后访问任意路径(如 http://localhost:8080),浏览器会重定向至内置的登录页面,表明安全拦截已生效。

此时系统采用默认配置:用户名为 user,密码在服务启动时生成并打印在控制台中,例如:

Using generated security password: a1b2c3d4-e5f6-7890-g1h2-i3j4k5l6m7n8

基础配置方式

可通过配置文件快速设定静态用户凭证,适用于开发或测试环境。

spring:
  security:
    user:
      name: admin
      password: 123456

基于 Java 配置的安全策略

更灵活的方式是编写配置类来定义认证与授权规则。创建一个 SecurityConfiguration 类,通过 @Bean 注册安全过滤链。

@Configuration
@EnableWebSecurity
public class SecurityConfiguration {

    @Bean
    public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {
        http
            .authorizeHttpRequests(registry -> 
                registry.anyRequest().authenticated()
            )
            .formLogin(login -> 
                login.defaultSuccessUrl("/dashboard", true)
            )
            .csrf(csrf -> csrf.disable());

        return http.build();
    }
}

上述代码表示所有请求必须经过身份验证,启用表单登录,并在成功后跳转至 /dashboard 页面,同时禁用 CSRF 防护(仅用于演示)。

自定义登录界面

若希望使用前端自定义的登录页(如 login.html),可指定登录端点和参数名称。

.formLogin()
    .loginPage("/login")                 // 自定义登录页地址
    .usernameParameter("uid")            // 前端 input name 属性值
    .passwordParameter("pwd")
    .permitAll()

对应 HTML 表单应包含如下字段:

<form action="/login" method="post">
    <input type="text" name="uid" />
    <input type="password" name="pwd" />
    <button type="submit">登录</button>
</form>

内存用户管理

可在配置类中预设多个用户及其角色权限,适合原型开发阶段。

@Configuration
@EnableWebSecurity
public class InMemorySecurityConfig {

    @Bean
    public UserDetailsService userDetailsService() {
        UserDetails admin = User.withUsername("admin")
            .password("{noop}123456")
            .roles("ADMIN")
            .build();

        UserDetails usr = User.withUsername("user")
            .password("{noop}123456")
            .roles("USER")
            .build();

        return new InMemoryUserDetailsManager(admin, usr);
    }

    @Bean
    public SecurityFilterChain filter(HttpSecurity http) throws Exception {
        http
            .authorizeHttpRequests(auth -> auth.anyRequest().authenticated())
            .formLogin(Customizer.withDefaults())
            .logout(logout -> logout.permitAll());

        return http.build();
    }
}

注意:{noop} 表示明文存储密码,生产环境应使用加密器(如 BCryptPasswordEncoder)进行密码哈希处理。

登出功能配置

默认情况下,发送 POST 请求到 /logout 即可退出当前会话。可通过配置调整行为,如指定登出成功后的跳转页。

.logout(logout -> 
    logout.logoutSuccessUrl("/login?logout").permitAll()
)
标签: Spring Boot

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。