• 由一个异常开始思考springmvc参数解析


    首先记录一下异常,以及异常出现的原因和解决方案

      异常主要信息:

    2016-10-12 12:40:46,808 ERROR [500.jsp] - Name for argument type [java.lang.String] not available, and parameter name information not found in class file either.
    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.web.method.annotation.AbstractNamedValueMethodArgumentResolver.updateNamedValueInfo(AbstractNamedValueMethodArgumentResolver.java:141)
        at org.springframework.web.method.annotation.AbstractNamedValueMethodArgumentResolver.getNamedValueInfo(AbstractNamedValueMethodArgumentResolver.java:119)
        at org.springframework.web.method.annotation.AbstractNamedValueMethodArgumentResolver.resolveArgument(AbstractNamedValueMethodArgumentResolver.java:86)
        at org.springframework.web.method.support.HandlerMethodArgumentResolverComposite.resolveArgument(HandlerMethodArgumentResolverComposite.java:78)
        at org.springframework.web.method.support.InvocableHandlerMethod.getMethodArgumentValues(InvocableHandlerMethod.java:162)
        at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:129)
        at org.springframework.web.method.annotation.ModelFactory.invokeModelAttributeMethods(ModelFactory.java:136)

    我说一下我的解决过程 我根据这个异常的提示,跟踪到AbstractNamedValueMethodArgumentResolver的resolveArgument方法,然后从接口中看到了它的作用,就是将

    处理器中的映射方法的参数进行处理

    从这张继承图也可以看出来,对于参数中的任何注解都会调用处理器,包括:@RequetParam,@PathVaiable,@Value,@RequestHeader@Value @CookieValue @MatrixVariable  至于每个注解的使用 都可以执行百度。

    搜嘎!我大概知道了 应该是我的项目中这些注解中出的问题  然后在debug看

    org.springframework.web.method.annotation.AbstractNamedValueMethodArgumentResolver.resolveArgument(MethodParameter, ModelAndViewContainer, NativeWebRequest, WebDataBinderFactory)

    这个方法中的各个参数  猜得没错的话  第一的就是代表处理器的方法了,继续往下看,有这样一段代码:

    	private NamedValueInfo updateNamedValueInfo(MethodParameter parameter, NamedValueInfo info) {
    		String name = info.name;
    		if (info.name.length() == 0) {
    			name = parameter.getParameterName();
    			if (name == null) {
    				throw new IllegalArgumentException("Name for argument type [" + parameter.getParameterType().getName() +
    						"] not available, and parameter name information not found in class file either.");
    			}
    		}
    		String defaultValue = (ValueConstants.DEFAULT_NONE.equals(info.defaultValue) ? null : info.defaultValue);
    		return new NamedValueInfo(name, info.required, defaultValue);
    	}
    

      没错 异常就是这个来的  我发现name竟然是null ,联想到我的RequestParam注解的name属性没有的,是不是这个原因呢?但是不对啊  虽然没有name属性  但是不是会迷人的根据后面的字段来生成的吗?以前教程都是这样说的。我把这个疑问Google了一下  网上一致说的是ant设置了debug级别,需要改成on 但是我根本没有用ant。我是使用eclipse的tomcat。最后的猜想是eclipse有这样的一个设置 最后果然没错还真有:

    。重启就ok了!!!

    问题是解决了,但是很不解啊  因为如果是这样的话  那么不确定性很高啊  万一别人没有设置怎么办呢?

    google了一波 其实这是因为大家都被大部分的springmvc视频或者教程误导了,官方的解释是只有在debug模式编译时,参数名才会保留在class文件中,spring由此可以反射绑定......

    所以说  最后是一定要加name属性啊!!!

  • 相关阅读:
    Mybatis学习--spring和Mybatis整合
    MyBatis学习--查询缓存
    MyBatis学习--延迟加载
    MyBatis学习--高级映射
    Mybatis学习--Mapper.xml映射文件
    java文件上传和下载
    【计算机视觉】Object Proposal之BING理解
    【计算机视觉】Object Proposal之BING++
    【计算机视觉】Object Proposal之BING++
    【计算机视觉】Objectness算法(一)---总体理解,整理及总结
  • 原文地址:https://www.cnblogs.com/zr520/p/5952874.html
Copyright © 2020-2023  润新知