gpt4 book ai didi

java.lang.NumberFormatException : for input string {Date}. Spring MVC 我无法识别错误

转载 作者:行者123 更新时间:2023-11-29 15:34:53 25 4
gpt4 key购买 nike

在处理个人项目时,我收到 NumberFormatException。当表单尝试将日期变量显示为字符串时,会发生此错误。问题是该设置与项目的其他部分相同,并且运行良好。

我使用两个 Controller ,一个用于不同的页面子集,它们显示并允许操作不同但相关的信息。就像病人和他们的医生一样。

这是表格:

CREATE TABLE bmi(
bmi_id INT(14) NOT NULL AUTO_INCREMENT,
date_weight DATE,
height DECIMAL(5,2),
weight DECIMAL(5,2),
bmi DECIMAL(5,2),
patient_id INT(11),
PRIMARY KEY(bmi_id),
CONSTRAINT wei_pat_fk FOREIGN KEY(patient_id) REFERENCES patient(patient_id)
)ENGINE=InnoDB auto_increment=1 default charset=latin1;

这是 BMI 对象:

@Entity
@Table(name="table")
public class BMI {

@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="bmi_id")
private int bmiId;

@CreationTimestamp
@Temporal(TemporalType.DATE)
@Column(name="date_weight")
@DateTimeFormat(pattern = "dd/MM/yyyy")
private Date createdW;

@Column(name="weight")
private BigDecimal weight;

@Column(name="height")
private BigDecimal height;

@Column(name="bmi")
private BigDecimal bmi;

//Getter Setters
}

病人对象:

@Entity
@Table(name = "patient")
public class Patient {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "patient_id")
private int patientId;

@NotBlank
@Column(name = "first_name")
private String firstName;

@NotEmpty
@Column(name = "last_name")
private String lastName;

@NotNull(message = "enter a date")
@Temporal(TemporalType.DATE)
@Column(name = "birth_date")
@DateTimeFormat(pattern = "dd/MM/yyyy")
private Date birthDate;

@CreationTimestamp
@Temporal(TemporalType.DATE)
@Column(name = "first_assesment")
@DateTimeFormat(pattern = "dd/MM/yyyy")
private Date createdP;

@Column(name = "sex")
private String sex;

@NotNull
@Email
@Column(name = "email")
private String email;

@OneToMany(fetch = FetchType.LAZY, cascade = { CascadeType.MERGE, CascadeType.PERSIST, CascadeType.REFRESH,
CascadeType.DETACH })
@JoinColumn(name="patient_id")
private List<BMI> bmis;

//Getters Setters
}

这是 DAO 对象(mySQL 中的表有一个 Patient_id 列):

@Repository
public class BMIImpl implements BMIDAO {

@Autowired
private SessionFactory sf;

...

@SuppressWarnings("unchecked")
@Transactional
public List<BMI> listBMIpat(int patId){
Session s = this.sf.getCurrentSession();
List<BMI> bmis = (List<BMI>) s.createSQLQuery("Select * from BMI B where B.patient_id = "+patId).list();
return bmis;
}
...
}

服务对象:

@Service
@Transactional
public class BMIServiceImpl implements BMIService {

@Autowired
private BMIDAO bdao;

@Override
@Transactional
public List<BMI> getBMIbyPatient(int patId) {
return bdao.listBMIpat(patId);
}
...
}

这是 Controller :

@Controller
@RequestMapping("/bmi/{patId}")
public class BMIController {

@SuppressWarnings("unused")
private static final Logger logger = Logger.getLogger(BMIController.class);

public BMIController() {
System.out.println("BMIController()");
}

@Autowired
private BMIService bs;

@RequestMapping(method = RequestMethod.GET)
public ModelAndView listBMIs(@PathVariable("patId") Integer patId, ModelAndView model) throws IOException {
List<BMI> bmis = bs.getBMIbyPatient(patId);
model.addObject("listBMIs", bmis);
model.setViewName("viewBMIs");
return model;
}
...
}

这是页面:

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<%@taglib prefix="form" uri="http://www.springframework.org/tags/form"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body>
<...>
<table border="1">
<tr>
<th>Created</th>
<th>Weight</th>
<th>Height</th>
<th>BMI</th>
<th>Action</th>
<tr>
<c:forEach var="bmi" items="${listBMIs}">
<tr>
<td><fmt:formatDate pattern="dd/MM/yyyy" value="${bmi.createdW}" /></td>
<td>${bmi.weight}</td>
<td>${bmi.height}</td>
<td>${bmi.bmi}</td>
<td><a href="editBMI?bmiId=${bmi.bmiId}">Edit</a> <a
href="deleteBMI?bmiId=${bmi.bmiId}">Delete</a></td>
</tr>
</c:forEach>
</table>
</div>
</body>
</html>

错误:

SEVERE: Servlet.service() for servlet [jsp] threw exception
java.lang.NumberFormatException: For input string: "createdW"
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
at java.lang.Integer.parseInt(Integer.java:580)
at java.lang.Integer.parseInt(Integer.java:615)
at javax.el.ArrayELResolver.coerce(ArrayELResolver.java:144)
at javax.el.ArrayELResolver.getValue(ArrayELResolver.java:61)
at org.apache.jasper.el.JasperELResolver.getValue(JasperELResolver.java:110)
at org.apache.el.parser.AstValue.getValue(AstValue.java:169)
at org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:190)
at org.apache.jasper.runtime.PageContextImpl.proprietaryEvaluate(PageContextImpl.java:944)
at org.apache.jsp.WEB_002dINF.pages.viewBMIs_jsp._jspx_meth_fmt_005fformatDate_005f0(viewBMIs_jsp.java:254)
at org.apache.jsp.WEB_002dINF.pages.viewBMIs_jsp._jspx_meth_c_005fforEach_005f0(viewBMIs_jsp.java:198)
at org.apache.jsp.WEB_002dINF.pages.viewBMIs_jsp._jspService(viewBMIs_jsp.java:150)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:476)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:728)
at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:470)
at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:395)
at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:316)
at org.springframework.web.servlet.view.InternalResourceView.renderMergedOutputModel(InternalResourceView.java:168)
at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:303)
at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1228)
at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1011)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:955)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:877)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:966)
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:857)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:842)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:660)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:798)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:808)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)

Oct 11, 2019 5:36:37 PM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet [spring] in context with path [/LymphodemaProjectMVC] threw exception [java.lang.NumberFormatException: For input string: "createdW"] with root cause
java.lang.NumberFormatException: For input string: "createdW"
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
at java.lang.Integer.parseInt(Integer.java:580)
at java.lang.Integer.parseInt(Integer.java:615)
at javax.el.ArrayELResolver.coerce(ArrayELResolver.java:144)
at javax.el.ArrayELResolver.getValue(ArrayELResolver.java:61)
at org.apache.jasper.el.JasperELResolver.getValue(JasperELResolver.java:110)
at org.apache.el.parser.AstValue.getValue(AstValue.java:169)
at org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:190)
at org.apache.jasper.runtime.PageContextImpl.proprietaryEvaluate(PageContextImpl.java:944)
at org.apache.jsp.WEB_002dINF.pages.viewBMIs_jsp._jspx_meth_fmt_005fformatDate_005f0(viewBMIs_jsp.java:254)
at org.apache.jsp.WEB_002dINF.pages.viewBMIs_jsp._jspx_meth_c_005fforEach_005f0(viewBMIs_jsp.java:198)
at org.apache.jsp.WEB_002dINF.pages.viewBMIs_jsp._jspService(viewBMIs_jsp.java:150)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:476)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:728)
at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:470)
at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:395)
at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:316)
at org.springframework.web.servlet.view.InternalResourceView.renderMergedOutputModel(InternalResourceView.java:168)
at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:303)
at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1228)
at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1011)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:955)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:877)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:966)
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:857)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:842)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:660)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:798)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:808)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)

我对患者表进行了完全相同的设置,但当我运行项目的该部分时,我没有收到任何异常消息。

编辑:我删除了 mySQL 中表内的信息,现在页面可以正确加载。我不知道为什么会这样。

编辑:我发现日期在数据库中的存储方式不同。然而,对于患者来说,它以一种格式存储,而对于bmi,则以不同的格式存储。这意味着当它尝试加载日期时,它不会将其视为日期并给出错误。我不知道为什么会发生这种情况。

最佳答案

检查您是否在页面顶部添加了此行。

<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>

关于java.lang.NumberFormatException : for input string {Date}. Spring MVC 我无法识别错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58349233/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com