发表于: 2019-11-28 23:34:18
1 1067
springmvc入门程序小结
前端控制器配置:
第一种:*.action,访问以.action结尾 由DispatcherServlet进行解析
第二种:/,所以访问的地址都由DispatcherServlet进行解析,对于静态文件的解析需要配置不让DispatcherServlet进行解析,使用此种方式可以实现RESTful风格的url
处理器映射器:
非注解处理器映射器(了解)
注解的处理器映射器(掌握)
对标记@Controller类中标识有@RequestMapping的方法进行映射。在@RequestMapping里边定义映射的url。使用注解的映射器不用在xml中配置url和Handler的映射关系。
处理器适配器:
非注解处理器适配器(了解) 注解的处理器适配器(掌握) 注解处理器适配器和注解的处理器映射器是配对使用。理解为不能使用非注解映射器进行映射。
<mvc:annotation-driven></mvc:annotation-driven>
可以代替下边的配置:
<!--注解映射器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/> <!--注解适配器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
非注解的完整的配置文件
src/main/resources/springmvc.xml
注解的完整配置文件
springmvc和struts2区别
springmvc面向方法开发的(更接近service接口的开发方式),struts2面向类开发。
springmvc可以单例开发,struts2只能是多例开发。
RESTful架构,就是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。
RESTful(即Representational State Transfer的缩写)其实是一个开发理念,是对http的很好的诠释。
1.对url进行规范,写RESTful格式的url
非REST的url:http://...../queryItems.action?id=001&type=T01
REST的url风格:http://..../items/001
特点:url简洁,将参数通过url传到服务端
2.http的方法规范
不管是删除、添加、更新,等等。使用url是一致的,如果进行删除,需要设置http的方法为delete,其他同理。
后台controller方法:判断http方法,如果是delete执行删除,如果是post执行添加。
3.对http的contentType规范
请求时指定contentType,要json数据,设置成json格式的type。
REST的例子
查询商品信息,返回json数据。
controller
定义方法,进行url映射使用REST风格的url,将查询商品信息的id传入controller .
输出json使用@ResponseBody将java对象输出json。
//查询商品信息,输出json
//itemsView/{id}里边的{id}表示占位符,通过@PathVariable获取占位符中的参数,
//@PathVariable中名称要和占位符一致,形参名无需和其一致
//如果占位符中的名称和形参名一致,在@PathVariable可以不指定名称
@RequestMapping("/itemsView/{id}")
public @ResponseBody ItemsCustom itemsView(@PathVariable("id") Integer items_id)throws Exception{
//调用service查询商品信息
ItemsCustom itemsCustom = itemsService.findItemsById(items_id);
return itemsCustom;
}
@RequestMapping(value="/ itemsView/{id}"):{×××}占位符,请求的URL可以是/viewItems/1或/viewItems/2,通过在方法中使用@PathVariable获取{×××}中的×××变量。@PathVariable用于将请求URL中的模板变量映射到功能处理方法的参数上。
如果@RequestMapping中表示为/itemsView/{id},id和形参名称一致,@PathVariable不用指定名称。
REST方法的前端控制器配置
<!-- springmvc前端控制器,rest配置 -->
<servlet>
<servlet-name>springmvc_rest</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- contextConfigLocation配置springmvc加载的配置文件(配置处理器映射器、适配器等等) 如果不配置contextConfigLocation,默认加载的是/WEB-INF/servlet名称-serlvet.xml(springmvc-servlet.xml) -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/springmvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>springmvc_rest</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
注解开发中参数绑定
将request请求过来的key/value的数据(理解一个串),通过转换(参数绑定的一部分),将key/value串转成形参,将转换后的结果传给形参(整个参数绑定过程)。
springmvc所支持参数绑定:
- 1、默认支持很多类型:
HttpServletRequest
、response
、session
、model/modelMap
(将模型数据填充到request域) - 2、支持简单数据类型,整型、字符串、日期..等
- 只要保证request请求的参数名和形参名称一致,自动绑定成功
- 如果request请求的参数名和形参名称不一致,可以使用
@RequestParam
(指定request请求的参数名),@RequestParam
加在形参的前边。
- 3、支持pojo类型
- 只要保证request请求的参数名称和pojo中的属性名一致,自动将request请求的参数设置到pojo的属性中。
- 4、包装类型pojo参数绑定
- 第一种方法:在形参中添加
HttpServletRequest request
参数,通过request接收查询条件参数。 - 第二种方法:在形参中让包装类型的pojo接收查询条件参数。
- 第一种方法:在形参中添加
- 5、集合类型参数绑定
- 数组绑定:方法形参使用数组接收页面请求的多个参数
- list绑定:使用List接收页面提交的批量数据,通过包装pojo接收,在包装pojo中定义list属性
- map绑定:在包装类中定义Map对象,并添加
get/set
方法,action使用包装对象接收
注意:形参中即有pojo类型又有简单类型,参数绑定互不影响。
自定义参数绑定
- 日期类型绑定自定义:
定义的Converter<源类型,目标类型>
接口实现类,比如:Converter<String,Date>
,表示:将请求的日期数据串转成java中的日期类型。
注意:要转换的目标类型一定和接收的pojo中的属性类型一致。
将定义的Converter实现类注入到处理器适配器中。
配置web.xml bug:server should have a maping
解决:
明天计划 springmvc
评论