以前没有注意过,其实java编译成.class 有两种方式 用javac,默认使用的release方式,而我们经常使用的Eclipse工具,用的是debug模式。 web工程在windows环境eclipse下编译部署没有问题,系统升级时需要svn取源码并用ant编译部署到线上机器,部署启动正常没有错误,当访问业务的action时报错,如下。
java.lang.IllegalArgumentException: Name for argument type [java.lang.String] not available, and parameter name information not found in class file either. at org.springframework.util.Assert.notNull(Assert.java:112)
ant编译和 eclipse编译同样的源码,结果不同,原因如下: 1) ant采用javac编译(也指定了编译器=eclipse)时,默认的编译参数是 debug=false 2) 人工使用eclipse工具编译java代码,默认的编译参数是 debug=true 导致编译出来的class文件不一致,这是因为 编译参数debug的原因。 源码如下:
@RequestMapping(value = “/security/login”, method = RequestMethod.POST)
1)debug=true时,可以正常解析参数 userName,2)debug=false时,不能解析参数userName,此时报错如下java.lang.IllegalArgumentException: Name for argument type [java.lang.String]
public ModelAndView login(@RequestParam String userName, @RequestParam String password,
HttpServletRequest request) {
解决方法有2个: 1) 将ant中的javac 增加参数 debug=true
2)修改源码, 修改参数的写法,如下
@RequestMapping(value = “/security/login”, method = RequestMethod.POST)
转载地址: http://blog.youkuaiyun.com/liuguanghaoputin/article/details/8695600
public ModelAndView login(@RequestParam(“userName”) String userName,
@RequestParam(“password”) String password,
HttpServletRequest request) {