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

标签 java mysql spring hibernate crud

在处理个人项目时,我收到 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/

相关文章:

java - 如何在 Android 中写入 SD 卡上的文件夹?

java - 在 Eclipse 编译期间在构建中嵌入 git-describe、日期和时间

java - Spring + 2 Hibernate 数据源 + 第二个 TransactionManager : NoSuchBeanDefinitionException

Java 代码执行难题——跳行而不抛出异常

javax.persistence.TransactionRequiredException : no transaction is in progress on @Lock annotation

java - 如何调用 onMeasure 方法? - 安卓

java - RabbitMQ:快速生产者和慢消费者

mysql - mySQL 数据库位于 WordPress 站点的目录树中的什么位置?

php - CodeIgniter 捕获 DB 错误消息(当前如果 dbdebug 为 false,则返回 0)

PHP HTTP_User_Agent,将访问者重定向到移动页面,网站性能下降