“前言”
通过实践而发现真理,又通过实践而证实真理和发展真理。从感性认识而能动地发展到理性认识,又从理性认识而能动地指导革命实践,改造主观世界和客观世界。实践、认识、再实践、再认识,这种形式,循环往复以至无穷,而实践和认识之每一循环的内容,都比较地进到了高一级的程度
“温故”
确认了以该内容为新目标的全新实践
“知新”
“正片”
哈!作者始终秉承着除了实践为重的理念,还有一个就是怎么简单怎么来,所以我又读了一次,桀桀桀,发现了什么!
JDBC是什么?经常接触CRUD的小伙伴一定知道,java语言连接数据库
既然没办法实现第一阶段的自定义账号密码登录,那就直接实现第二阶段的数据库自定义登录!
然后再回过头来实现第一阶段
这个是对应Service实例,文件目录
DataApplication.java —— 启动类
User.java —— 实体类
MessageController.java —— 控制类
MessageRepository.java —— 数据库映射类
Message.java —— 统一响应类
其余两个Null.java、AuthorizeRead.java这两个不知道是什么!
看到security的配置
在前几期中,我们知道了如何自定义(理论)
@Bean
public UserDetailsService userDetailsService() {
return new InMemoryUserDetailsManager(
User.withDefaultPasswordEncoder()
.username("rob")
.password("password")
.authorities("message:read", "user:read")
.build(),
User.withDefaultPasswordEncoder()
.username("luke")
.password("password")
.authorities("message:read")
.build());
}
结合代码来看,这个自定义可能就是单纯的
@Bean
public UserDetailsService userDetailsService() {
//自定义
}
因为是JDBC认证,所以必须连接数据库
来,这个我们天天做,上模板(作者使用mysql数据库,使用MyBatis框架)!!!!
第一步:确保项目带有对应数据库driver(驱动)和JDBC
添加完,点击运行
结果:报错即成功!
第二步:进行配置数据库连接yaml文件
application.yaml !!!配置文件名不要打错
第三步:启动
完成一个最简单的查询
这个是表设计
上CRUD模板
创建实体类
@Data
@NoArgsConstructor
public class user{
public String username;
public String password;
}
创建mapper
@Mapper
public interface userMapper {
@Select("select username,password from user_test where username = ${username}")
user getUsername(String username);
}
利用mapper查!