今天一个大意的疏忽导致公司中断服务俩个小时。只能说学spring太囫囵吞枣。横跨了俩个版本后的spring,充分给了你自由,于是就想当然的被不起眼的bug打败。现在回想起来。看网上资料学spring时,都在说
1.直接写@RequestParam就行了,会把请求中同名参数绑定到方法上。
2.如果参数名和变量名不一致,可以使用@RequestParam(name),告诉spring,使用指定名字入参。
这种讲法明明是错误的。只有在debug模式编译时,参数名才会保留在class文件中,spring由此可以反射绑定。我们的应用明显不可能在debug模式下打包。因此第一种误人子弟啊,老师告诉你很简单的默认值做法是错误的,第二种方式才是正确的写法。
看一个简单的方法。
通过http://localhost:8080/test/hello?name=a调用,本机一切OK。但到服务器,死活报错误。原因是本机eclipse有个编译开关,会把变量写入到class文件中。因此需要明确告诉Spring入参。
右击项目,选择“属性”,打开“属性对话框”,选择“Java Compiler”然后再打开的选项卡将“Add variable attributes to generated class files”取消勾选,意思是不将局部变量信息添加到类文件中
Request processing failed; nested exception is java.lang.IllegalArgumentException: Name for argument type [java.lang.String] not available, and parameter name information not found in class file either.
public String hello( @RequestParam("name") String name){ return name; }
参考资料:https://my.oschina.net/zhukp/blog/173042
参考资料:http://itindex.net/detail/50836-%E6%8E%A7%E5%88%B6%E5%99%A8-springmvc-%E6%95%B0%E6%8D%AE