1、非注解的处理器映射器和适配器
1.1 多个映射器可以并存
再定义一个simpleUrlHandlerMapping,而且配置了两个url映射到一个action,效果是都能通。
<!-- 配置Handler -->
<bean id="itemsController1" name="/queryItems.action" class="cn.iot.ssm.controller.ItemsController"></bean>
<!-- 处理器映射器 -->
<!-- 根据bean的name进行查找Handler 将action的url配置在bean的name中
返回Handler给前端控制器 -->
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping" />
<!-- 简单url映射 -->
<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<props>
<!-- 把itemsController1进行url映射,映射成/queryItems1.action -->
<prop key="/queryItems1.action">itemsController1</prop>
<prop key="/queryItems2.action">itemsController1</prop>
</props>
</property>
</bean>
1.2 非注解的适配器
适配器接受前端控制器的指令,去执行Handler。
1.2.1 SimpleControllerHandlerAdapter
org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter
这个适配器要求Handler实现controller接口
1.2.1 HttpRequestHandlerAdapter
org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter"
要求编写的Handler实现HttpRequestHandler接口
handler的编写
package cn.iot.ssm.controller;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.HttpRequestHandler;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
import com.iot.ssm.po.Items;
public class ItemsController2 implements HttpRequestHandler{
@Override
public void handleRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
List<Items> itemsList = new ArrayList<Items>();
//向list填充静态数据
Items items = new Items();
items.setName("联想笔记本");
items.setPrice(6000f);
items.setDetail("非常好用");
Items items2 = new Items();
items2.setName("苹果笔记本");
items2.setPrice(6002f);
items2.setDetail("mac book");
itemsList.add(items);
itemsList.add(items2);
request.setAttribute("itemsList", itemsList);
// 转发的视图
request.getRequestDispatcher("/WEB-INF/jsp/items/itemsList.jsp").forward(request, response);
}
}
特点:没有返回modelAndView,那么可以通过response修改定义响应内容,比如说返回json数据
response.setCharacterEncoding("utf-8");
response.setContentType("application/json;charset=utf-8");
response.getWriter().write("json串");
此外,springmvc的DispatcherServlet.properties中默认加载了一些映射器和适配器,因此就算我们不在配置文件中指定,它也能找到映射器和配置器
2、注解的处理器映射器和适配器
2.1 注解的映射器
从spring3.1版本开始,废除了DefaultAnnotationHandlerMapping的使用,推荐使用RequestMappingHandlerMapping完成注解式处理器映射。
配置如下:
<!--注解映射器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
2.2 注解的适配器
从spring3.1版本开始,废除了AnnotationMethodHandlerAdapter的使用,推荐使用RequestMappingHandlerAdapter完成注解式处理器适配。
配置如下:
<!--注解适配器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
2.3 小小小结
<!-- 处理器映射器 -->
<!--注解映射器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
<!--注解适配器 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
<!-- 另外还有一种方式: mvc:annotation-driven
可以代替上面的映射器和适配器编写
而且它自带了很多参数绑定的方法:例如json解析 -->
<!-- <mvc:annotation-driven></mvc:annotation-driven> -->
3、开发注解的Handler
注解的映射器和适配器要同时!!
这里学到了两个注释
- @Controller(注意,属于import org.springframework.stereotype.*?
- @RequestMapping
package cn.iot.ssm.controller;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.HttpRequestHandler;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.stereotype.*;
import com.iot.ssm.po.Items;
// 注解式的controller 编写
//@Controller标识它是一个控制器
@Controller
public class ItemsController3 {
//商品查询列表
//@RequestMapping把url和action方法进行映射
@RequestMapping("/queryItems.action")
public ModelAndView queryItems() throws Exception{
// TODO Auto-generated method stub
List<Items> itemsList = new ArrayList<Items>();
//向list填充静态数据
Items items = new Items();
items.setName("联想笔记本");
items.setPrice(6000f);
items.setDetail("非常好用");
Items items2 = new Items();
items2.setName("苹果笔记本");
items2.setPrice(6002f);
items2.setDetail("mac book");
itemsList.add(items);
itemsList.add(items2);
// 返回ModelAndView
ModelAndView modelAndView = new ModelAndView();
// 相当于request的setAttribut,在jsp页面中通过key:itemsList获取数据
modelAndView.addObject("itemsList",itemsList);
// 指定视图
modelAndView.setViewName("/WEB-INF/jsp/items/itemsList.jsp");
return modelAndView;
}
// 定义其他的方法
}
4、在spring容器中加载Handler
加载方法类似于之前的方法
使用context:时遇到了一个错误,通过这里解决
<!-- 对于注解的Handler,可以单个配置 -->
<!-- <bean class="cn.iot.ssm.controller.ItemsController3"></bean>-->
<!-- 实际开发中,用的是扫描包 -->
<!-- 扫描controller注解,多个包中间使用半角逗号分隔 -->
<context:component-scan base-package="cn.iot.ssm.controller"/>