爬坑之JdbcTemplate

在学习Spring Security时遇到登录验证失败的问题,尽管数据库中存在用户数据,但JdbcTemplate未能正确提取信息。错误信息提示不能向构造函数传递空值。经过调试发现,从数据库读取的数据在封装到实体时,部分带有下划线的字段值为null。通过修改数据库字段和相关代码,解决了这个问题并实现了成功登录。
摘要由CSDN通过智能技术生成

问题背景:

  1. 学习spring security时,正在做数据库的登录验证,碰到了一个稀奇的问题;明明数据库中有用户数据,但是jdbcTemplate无法将关键信息带出来,记录下思考过程。

先贴代码

​
package com.atguigu.security.config;

import java.util.ArrayList;
import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.authority.SimpleGrantedAuthority;
import org.springframework.security.core.userdetails.User;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Component;

import com.atguigu.security.entity.Admin;

@Component
public class MyUserDetailsService implements UserDetailsService {
	@Autowired
	private JdbcTemplate jdbcTemplate;
	
	// 总目标:根据表单提奥的用户名查询User对象,并装配角色,权限等信息
	@Override
	public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
		
		// 1.从数据库查询Admin对象
		String sql = "SELECT id,login_acct,user_pswd,user_name,email FROM t_admin WHERE login_acct=?";
		
		List<Admin> list = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(Admin.class), username);
		
		Admin admin = list.get(0);
		//System.out.println(jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(Admin.class), username));
		// 2.给Admin设置角色权限信息
		List<GrantedAuthority> authorities = new Arra
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值