ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

SpringSecurity---基于内存的FormLogin

2021-03-06 22:35:12  阅读:169  来源: 互联网

标签:passwordEncoder SpringSecurity --- test 报错 默认 FormLogin public 页面


SpringSecurity已经内置了一个登陆页面,所以目前我们就采取默认的登陆页面

一. 引入依赖

这步略过不表

二. 默认实现

添加一个接口

@RestController
public class TestController {
    @GetMapping("/test")
    public String test(){
        return "this is test";
    }
}

访问接口

会出现如下页面

默认的用户名为user,密码为控制台打印的一串字符

当然,也可以在application.yml中配置

三. 基于内存的简单认证

继承WebSecurityConfigurerAdapter

@Configuration
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
}

配置密码加密方式

SpringSecurity5.x后必须指定一种加密方式
不然会报错

这里我们使用BCryptPasswordEncoder

@Bean
public PasswordEncoder passwordEncoder() {
    return new BCryptPasswordEncoder();
    }

配置用户名和密码和角色

//主要是重写configure方法
@Override
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {
        auth.inMemoryAuthentication()
                .withUser("user1")
                .password(passwordEncoder().encode("123456"))
                .roles("root")
                .and()
                .withUser("user2")
                .password(passwordEncoder().encode("123456"))
                .roles("user");
    }

虽然这里角色并没有实际的用处,但不加会报错

其实这两种,我感觉可以说是基本没什么用
暂时并不会涉及到授权,这会在后面用专门的文章去讲
完整代码会放在GitHub上,欢迎star

标签:passwordEncoder,SpringSecurity,---,test,报错,默认,FormLogin,public,页面
来源: https://www.cnblogs.com/GodTestLove/p/14492685.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有