- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我收到一个错误
org.springframework.dao.EmptyResultDataAccessException: Incorrect result size: expected 1, actual 0
at org.springframework.dao.support.DataAccessUtils.nullableSingleResult(DataAccessUtils.java:97)
at org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate.queryForObject(NamedParameterJdbcTemplate.java:236)
at org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate.queryForObject(NamedParameterJdbcTemplate.java:244)
at com.regularbbs.bbs.dao.UserDao.findUserByIdAndPw(UserDao.java:38)
at com.regularbbs.bbs.service.impl.UserServiceImpl.login(UserServiceImpl.java:20)
我认为它没有将我的参数传递给 MySQL 数据库。当我测试时,我发现我的参数被传递到DAO文件中。但它正好陷入困境。当我在DAO文件中的findUserByIdAndPw方法中打印 map 时,它很好地打印了 map 中的参数。
我认为 jdbc.queryForObject(GET_USER, map, rowMapper);
是错误的,但我不知道,请帮助我。
package com.regularbbs.bbs.dao;
public class UserSqls {
public static final String GET_USER = "SELECT * from user WHERE userId=':userId' AND password=':password'";
}
'''
Jsp 文件:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<link rel="stylesheet" type="text/css" href="<c:url value='/css/main.css' />" >
<script
src="https://code.jquery.com/jquery-3.4.1.js"
integrity="sha256-WpOohJOqMqqyKL9FccASB9O0KwACQJpFTUBLTYOVvVU="
crossorigin="anonymous"></script>
</head>
<body>
<jsp:include page="header.jsp" flush="false"></jsp:include>
<c:if test="${sessionScope.login ==null }">
<form name="login">
<section id="loginSection">
아이디 : <input type="text" id="userId" placeholder="아이디">
패스워드 : <input type="password" id="userPwd" placeholder="패스워드">
<button type="button" id="btnLogin">로그인</button>
<button type="button" onclick="getSignUpPage()">회원가입</button>
</section>
</form>
</c:if>
</body>
<script type="text/javascript">
function getSignUpPage() {
location.href="signUp";
}
$(document).ready(function() {
$("#btnLogin").click(function() {
var userId = $("#userId").val();
var userPwd = $("#userPwd").val();
var allData = JSON.stringify({"userId": userId, "password": userPwd});
if(userId == "") {
$("#userId").focus();
return;
}
if(userPwd == "") {
$("#userPwd").focus();
return;
}
$.ajax({
type: "POST",
url: "member/login",
data: allData,
processData: false,
contentType: "application/json;charset=UTF-8",
error: function (e) {
console.log("error : ", e);
}
})
})
});
</script>
</html>
UserDao 类:
package com.regularbbs.bbs.dao;
import static com.regularbbs.bbs.dao.UserSqls.GET_USER;
import java.util.HashMap;
import java.util.Map;
import javax.sql.DataSource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate;
import org.springframework.stereotype.Repository;
import com.regularbbs.bbs.dto.User;
@Repository
public class UserDao {
private NamedParameterJdbcTemplate jdbc;
private RowMapper<User> rowMapper = BeanPropertyRowMapper.newInstance(User.class);
@Autowired
public void setDataSource(DataSource dataSource) {
jdbc = new NamedParameterJdbcTemplate(dataSource);
}
public User findUserByIdAndPw(String id, String pw) {
try {
System.out.println(id +":"+ pw);
Map<String, String> map = new HashMap<>();
map.put("userId", id);
map.put("password", pw);
System.out.println(map);
return jdbc.queryForObject(GET_USER, map, rowMapper);
}catch(Exception e) {
e.printStackTrace();
return null;
}
}
}
服务:
package com.regularbbs.bbs.service;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.regularbbs.bbs.dto.User;
public interface UserService {
public User login(String userId, String password) throws Exception;
}
package com.regularbbs.bbs.service.impl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.regularbbs.bbs.dao.UserDao;
import com.regularbbs.bbs.dto.User;
import com.regularbbs.bbs.service.UserService;
@Service
public class UserServiceImpl implements UserService{
@Autowired
UserDao userDao;
@Override
@Transactional
public User login(String userId, String password) throws Exception{
return userDao.findUserByIdAndPw(userId, password);
}
}
Controller :
package com.regularbbs.bbs.controller;
import java.util.Map;
import javax.servlet.http.HttpSession;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import com.regularbbs.bbs.dto.User;
import com.regularbbs.bbs.service.UserService;
@Controller
public class LoginController {
@Autowired
UserService userService;
@RequestMapping(value="/member/login", method=RequestMethod.POST)
public String loginPost(@RequestBody Map<String, String> data
, Model model, HttpSession session) throws Exception {
System.out.println(data.get("userId") + ": " + data.get("password"));
User loginUser = userService.login(data.get("userId"), data.get("password"));
if(loginUser!=null) {
session.setAttribute("login", loginUser);
return "redirect:/";
}else {
return "redirect:/";
}
}
}
最佳答案
JDBCTemplate
的 queryForObject
应该返回单个唯一记录。否则,它将抛出:
In CorrectResultSizeDataAccessException
如果 SQL 返回大于 1记录EmptyResultDataAccessException
如果 SQL 返回无记录通常您可以捕获此异常并将其转换为对您的应用程序有意义的异常消息。将异常重新抛出回 Controller ,以便 Spring MVC 可以处理此异常。例如:
public User findUserByIdAndPw(String id, String pw) {
try {
System.out.println(id +":"+ pw);
Map<String, String> map = new HashMap<>();
map.put("userId", id);
map.put("password", pw);
System.out.println(map);
return jdbc.queryForObject(GET_USER, map, rowMapper);
}catch(EmptyResultDataAccessException e) {
throw new RuntimeException("User ID does not exist");
}catch(IncorrectResultSizeDataAccessException e) {
throw new RuntimeException("More than one users with the same Id .......");
}
}
关于java - 如何修复 'org.springframework.dao.EmptyResultDataAccessException: Incorrect result size: expected 1, actual 0'错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57541459/
我经常发现自己想要编写以下形式的通用类定义 public class Foo> 例如在这样的设置中: public interface ChangeHandler { public void
我有一些对象被放入队列中。队列中的所有对象都实现相同的基接口(interface),这也要求它们实现 IEquatable<>。 我想验证是否以正确的顺序将正确的对象放入队列中。 当我编写一个断言 C
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
我有一串数字和字符 c2 = "list of 2nd C2 H2O 1 12 123" 我需要删除所有实际数字,即 1、12、123,而不是那些属于字符集的数字,即 2nd、C2、H2O。 到目前为
git repo : django tutorial 我一直在关注上述 django 项目,该项目着眼于创建人与人之间的聊天。我遇到过这部分: def message_list(request, se
gitpod GitHub 页面说 Gitpod is an open-source Kubernetes application providing prebuilt,collaborative d
这是一个示例代码,我在这里抛出一个异常,由于某种原因,它在没有 try/catch 代码块的情况下工作得很好。 我是否必须在这个方法“EntryDelete”中处理这个问题或者我必须在调用该方法的地方
我的数据集中有以下列: id |用户 ID |开始日期 |结束日期 |检查日期 我想从第一列获取check_date,找到check_date在start_date和end_date。然后计算每个 u
简而言之: 在 pytorch 中使用 adadelta 优化器时,我无法绘制 lr/epoch 曲线,因为 optimizer.param_groups[0]['lr'] 总是返回相同的值。 详细说
假设我有以下 C 代码: int* vector = (int*)malloc(5 * sizeof(int)); malloc 返回一个空指针,因为不知道要求为什么分配空间。 因此,我们将 void
在 Java 中将形状渲染为其“实际大小”的简单方法是什么?例如,我有一个直径为 1"的 pipe ,我想在屏幕上将其描绘为 1"圆的轮廓。 Graphics2D 方法 drawOval(int x,
我阅读了很多关于 Node js 的文章,试图理解事件循环及其模式/反模式。许多作者没有提到的一件事是 Node 实际上处理线程。然而,应用程序程序员当然无法访问它们,但很高兴知道它们存在以及它们何时
什么mode:shim做? 我在这个网站上搜索了一种强制闪光的方法。代码开发人员针对遇到我所面临的确切问题的某个人的问题写了这个答案: MediaElement.js - force Chrome t
已关闭。这个问题是 off-topic 。目前不接受答案。 想要改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 已关闭11 年前。 Improve th
在 C++03 中,我们有模板显式实例化定义 ( template class Foo ),它强制模板类的实例化。 在 C++11 中,我们有模板显式实例化声明 ( extern template c
我有一个相当复杂的联接的执行计划,它显示在表上执行索引查找,“实际行数”读数约为 70,000,而实际上表中总共只有约 600 行(估计行数仅为 127)。 请注意,所有统计信息都是最新的,并且查询的
我的学校作业涉及编写一个简单的网络爬虫来爬行维基百科。该作业规定我不能使用任何外部库,因此我一直在使用 java.net.URL 类。基于official tutorial以及我的教授给出的一些代码:
您好,我是集成测试新手。我的断言状态面临一些困难。 这是错误 java.lang.AssertionError: Status Expected :204 Actual :404 这是测试代码
我刚刚习惯 Subversion,并且有一个关于版本控制的基本问题。 我已在我的网络中托管的服务器“S”上创建了 SVN 存储库。假设我从网络中的另一台计算机“A”“导入”代码、文件、目录等,它会添加
我没能弄清楚 Spark SQL 连接操作实际上是如何工作的。我已阅读pretty massive explanation ,但它并没有阐明一些问题。 示例 例如,您有两个数据库表保存在 Spark
我是一名优秀的程序员,十分优秀!