【问题标题】:Compile classfile issue in Spring 3在 Spring 3 中编译类文件问题
【发布时间】:2011-02-06 23:58:20
【问题描述】:

我的应用程序使用了 spring framework 3。开发时一切正常 Netbeans 但我需要一个自定义构建并完成相同的构建创建没有任何 问题,但我收到以下错误调用以下方法时发生错误

@RequestMapping(value = "/security/login", method = RequestMethod.POST)
public ModelAndView login(@RequestParam String userName, @RequestParam String password, 
    HttpServletRequest request) {
    ......................

但是在与 netbeans 进行战争时没有问题 (我确定这是关于编译问题) 你有这方面的经验吗... 有任何额外的 javac 参数用于编译相同(netbeans 使用自定义任务进行编译)

输入异常报告

消息

描述服务器遇到了一个内部错误(),导致它无法完成这个请求。

异常

org.springframework.web.util.NestedServletException:请求处理失败;嵌套异常是 org.springframework.web.bind.annotation.support.HandlerMethodInvocationException: 无法调用处理程序方法 [public org.springframework.web.servlet.ModelAndView com.mypackage.security.controller.LoginController.login(java.lang.String ,java.lang.String,javax.servlet.http.HttpServletRequest)];嵌套异常是 java.lang.IllegalStateException:没有为类型 [java.lang.String] 的参数指定参数名称,并且在类文件中也找不到参数名称信息。
 org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:659)
 org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:563)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
 com.mypackage.security.controller.AuthFilter.doFilter(未知来源)
 org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:237)
 org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:167)

根本原因

org.springframework.web.bind.annotation.support.HandlerMethodInvocationException:调用处理程序方法失败 [public org.springframework.web.servlet.ModelAndView com.mypackage.security.controller.LoginController.login(java.lang.String ,java.lang.String,javax.servlet.http.HttpServletRequest)];嵌套异常是 java.lang.IllegalStateException:没有为类型 [java.lang.String] 的参数指定参数名称,并且在类文件中也找不到参数名称信息。
 org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:171)
 org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:414)
 org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:402)
 org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:771)
 org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:716)
 org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:647)
 org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:563)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
 javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
 com.mypackage.security.controller.AuthFilter.doFilter(未知来源)
 org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:237)
 org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:167)

根本原因

java.lang.IllegalStateException:没有为 [java.lang.String] 类型的参数指定参数名称,并且在类文件中也找不到参数名称信息。 org.springframework.web.bind.annotation.support.HandlerMethodInvoker.getRequiredParameterName(HandlerMethodInvoker.java:618) org.springframework.web.bind.annotation.support.HandlerMethodInvoker.resolveRequestParam(HandlerMethodInvoker.java:417) org.springframework.web.bind.annotation.support.HandlerMethodInvoker.resolveHandlerArguments(HandlerMethodInvoker.java:277) org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:163) org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:414) org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:402) org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:771) org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:716) org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:647) org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:563) javax.servlet.http.HttpServlet.service(HttpServlet.java:637) javax.servlet.http.HttpServlet.service(HttpServlet.java:717) com.mypackage.security.controller.AuthFilter.doFilter(未知来源) org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:237) org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:167)

注意 Apache Tomcat/6.0.18 日志中提供了根本原因的完整堆栈跟踪。

【问题讨论】:

    标签: spring ant javac


    【解决方案1】:

    只有在调试模式下编译时,参数名称才会存储在编译后的代码中,因此您应该在调试模式下编译它,或者为@RequestParam 提供明确的参数名称。后一种方法更可靠,因为它不依赖于环境:

    @RequestMapping(value = "/security/login", method = RequestMethod.POST) 
    public ModelAndView login(@RequestParam("userName") String userName, 
        @RequestParam("password") String password,  
        HttpServletRequest request) { 
        ......................
    

    【讨论】:

    • 太棒了 - 我正在抓狂,看着 JDK,也许我的 Hudson 服务器正在做一些古怪的事情......这就是这个愚蠢的小事。这甚至在任何地方都有记录吗?
    • 只是想说这为我节省了数小时的痛苦、愤怒和山露。
    猜你喜欢
    • 2012-10-13
    • 2019-03-05
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-04-04
    • 1970-01-01
    • 2013-08-17
    相关资源
    最近更新 更多