SpringMVC 入门

[b]一.静态资源的处理[/b]

jsp页面中引用如下js文件:


<script type="text/javascript" src="js/bookstore.js"></script>

服务器启动时会出现如下警告:即提示:/js/bookstore.js 没有对应的controller处理。


org.springframework.web.servlet.DispatcherServlet noHandlerFound
警告: No mapping found for HTTP request with URI [/01/js/bookstore.js] in DispatcherServlet with name 'Spring MVC Servlet'


原因:在web.xml中 我们配置了DispatcherServlet拦截所有的请求,所以此处请求js文件(静态资源)也由DispatcherServlet来分发,这显然是不正确的。springMVC提供了<mvc:resources>标签来处理静态资源:


<mvc:resources mapping="/js/**" location="/js/"/>

通过这个配置,服务器就会到js目录下去寻找js文件。 一般js、css、image这些静态资源都需要进行配置。

静态资源的另一种处理方式是在web.xml中配置,如下所示:


<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.js</url-pattern>
</servlet-mapping>


将静态资源的访问交给Tomcat的DefaultServlet进行处理,注意配置要写DispatcherServlet之前。


[b]二.Controller返回json数据[/b]

SpringMVC 3.X 提供了@ResponseBody注解,可以方便的返回json数据。@ResponseBody:将后台方法的返回值作为响应体(通过HttpmessageConverter进行转换)

后台demo:

@RequestMapping(value = "/bankCardInfo/{userId}", method = RequestMethod.POST)
@ResponseBody
public Map<String,Object> findBankCardInfo(final @PathVariable String userId){
Map<String,Object> bankCardInfo = new HashMap<String,Object>();
bankCardInfo.put("id", "你的用户Id:"+userId);
bankCardInfo.put("money", "1");
bankCardInfo.put("bank", "xx银行");
return bankCardInfo;
}


spring-mvc-config.xml 文件:

<context:component-scan base-package="com.lijiejava.*.action" />

<mvc:annotation-driven/>

<mvc:resources mapping="/css/**" location="/css/"/>
<mvc:resources mapping="/image/**" location="/image/"/>
<mvc:resources mapping="/js/**" location="/js/"/>

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
</bean>

<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="100000000"/>
</bean>


[i]<mvc:annotation-driven /> 是一种简写形式,完全可以手动配置替代这种简写形式。
<mvc:annotation-driven /> 自动注册了DefaultAnnotationHandlerMapping与AnnotationMethodHandlerAdapter 两个bean,是spring MVC为@Controllers分发请求所必须的,并提供了:数据绑定支持,@NumberFormatannotation支持,@DateTimeFormat支持,@Valid支持,读写XML的支持(JAXB),读写JSON的支持(Jackson)[/i]


spring-mvc 3之前的版本中json数据的处理,如果不采用<mvc:annotation-driven /> 注释,那么可以自己手动配置AnnotationMethodHandlerAdapter,并且配置相关的messageConverters(消息转换器)属性。如果要读取json数据,那么就需要配置MappingJacksonHttpMessageConverter。代码如下:


<context:component-scan base-package="com.lijiejava.*.action" />

<!-- 不使用 <mvc:annotation-driven/> -->

<bean class="org.springframework.web.servlet.mvc.annotation.
DefaultAnnotationHandlerMapping"/>

<bean class="org.springframework.web.servlet.mvc.annotation.
AnnotationMethodHandlerAdapter">
<property name="messageConverters">
<list>
<ref bean="stringHttpMessageConverter" />
<ref bean="jsonHttpMessageConverter" />
</list>
</property>
</bean>

<bean id="stringHttpMessageConverter"
class="org.springframework.http.converter.StringHttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>text/plain;charset=UTF-8</value>
<value>application/json;charset=UTF-8</value>
</list>
</property>
</bean>

<bean id="jsonHttpMessageConverter"
class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter" />

<mvc:resources mapping="/css/**" location="/css/"/>
<mvc:resources mapping="/image/**" location="/image/"/>
<mvc:resources mapping="/js/**" location="/js/"/>

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
</bean>

<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="100000000"/>
</bean>


springMVC使用消息转换器实现请求报文和对象、对象和响应报文之间的自动转换。
在SpringMVC中,可以使用@RequestBody和@ResponseBody两个注解,分别完成请求报文到对象和对象到响应报文的转换,底层这种灵活的消息转换机制,就是Spring3.x中新引入的HttpMessageConverter,即消息转换器机制。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值