1.1非注解的處理器映射器
前面我們配置的org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping是非注解的處理器映射器。這種映射器其實有一個問題就是要一個bean里面配置一個url。
現(xiàn)在我們再配置另一個非注解映射器
org.springframework.web.servlet.handler.SimpleUrlHandlerMapping,它會將url和handler集中進行配置。
<!-- 配置Handler --> <bean id="ItemsController1" name="/queryItems.action" class="joanna.yan.ssm.controller.ItemsController1"/> <!-- 配置處理器映射器 將bean的name作為url進行查找,需要在配置Handler時指定beanname(就是url) --> <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/> <!-- 簡單url映射 simpleUrlHandlerMapping是BeanNameUrlHandlerMapping的增強版, 它可以將url和處理器bean的id進行統(tǒng)一映射配置。 --> <bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"> <property name="mappings"> <props> <!-- 對ItemsController1進行url映射,url是/queryItems1.action --> <prop key="/queryItems1.action">ItemsController1</prop> <prop key="/queryItems2.action">ItemsController1</prop> </props> </property> </bean>
疑問:可以同時配置這兩個映射器嗎?
解答:多個映射器可以并存,前端控制器判斷url能讓哪些映射器映射,就讓正確的映射器處理。
1.2非注解的處理器適配器
前面我們配置的org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter是一個非注解的適配器。它要求你編寫的Handler要實現(xiàn)Controller接口。
再說另一個非注解的適配器:
org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter。它要求編寫的Handler實現(xiàn)HttpRequestHandler接口。
public class ItemsController2 implements HttpRequestHandler{ @Override public void handleRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //調用service查找數(shù)據(jù)庫,查詢商品列表,這里使用靜態(tài)數(shù)據(jù)模擬 List<Items> itemsList=new ArrayList<Items>(); Items items_1=new Items(); items_1.setName("聯(lián)想筆記本"); items_1.setPrice(6000f); items_1.setDetail("ThinkPad T430 聯(lián)想筆記本電腦!"); Items items_2 = new Items(); items_2.setName("蘋果手機"); items_2.setPrice(5000f); items_2.setDetail("iphone6蘋果手機!"); itemsList.add(items_1); itemsList.add(items_2); //設置模型數(shù)據(jù) request.setAttribute("itemsList", itemsList); //設置轉發(fā)的視圖 request.getRequestDispatcher("/WEB-INF/jsp/items/itemsList.jsp").forward(request, response); // 從上邊可以看出此適配器器的handleRequest方法沒有返回ModelAndView,可通過response修改定義響應內容,比如返回json數(shù)據(jù):// response.setCharacterEncoding("utf-8");// response.setContentType("application/json;charset=utf-8");// response.getWriter().write("json串"); } }
在springmvc.xml中配置:
2.DispatcherServlet.properties
前端控制器從上邊的文件中加載處理映射器、適配器、視圖解析器等組件,如果不在springmvc.xml中配置,則使用默認加載的。
3.注解的處理器映射器和適配器
在spring3.1之前使用org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping注解映射器。
在spring3.1之后使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping注解映射器。
在spring3.1之前使用org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter注解適配器。
在spring3.1之后使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter注解適配器。
3.1配置注解映射器和適配器
<!--注解映射器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/> <!--注解適配器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/> <!--使用mvc:annotation-driven代替上邊注解映射器和注解適配器 配置 mvc:annotation-driven默認加載很多的參數(shù)綁定方法, 比如json轉換解析器就默認加載了,如果使用mvc:annotation-driven就不用配置上面的RequestMappingHandlerMapping和RequestMappingHandlerAdapter 實際開發(fā)時使用mvc:annotation-driven --> <!-- <mvc:annotation-driven></mvc:annotation-driven> -->
3.2開發(fā)注解Handler
使用注解的映射器和注解的適配器。(注解的映射器和注解的適配器必須配對使用,理解為不能使用非注解映射器進行映射)
/** * 開發(fā)注解Handler * 使用@Controller標明它是一個控制器 * @author Joanna.Yan * */@Controllerpublic class ItemsController3{ //商品查詢列表 //@RequestMapping實現(xiàn)對queryItems方法和url進行映射,一個方法對應一個url //一般建議將url和方法名寫成一樣,方便維護 @RequestMapping("/queryItems") public ModelAndView queryItems() throws Exception{ //調用service查找數(shù)據(jù)庫,查詢商品列表,這里使用靜態(tài)數(shù)據(jù)模擬 List<Items> itemsList=new ArrayList<Items>(); Items items_1=new Items(); items_1.setName("聯(lián)想筆記本"); items_1.setPrice(6000f); items_1.setDetail("ThinkPad T430 聯(lián)想筆記本電腦!"); Items items_2 = new Items(); items_2.setName("蘋果手機"); items_2.setPrice(5000f); items_2.setDetail("iphone6蘋果手機!"); itemsList.add(items_1); itemsList.add(items_2); //返回ModelAndView ModelAndView modelAndView=new ModelAndView(); modelAndView.addObject("itemsList", itemsList); //指定視圖 modelAndView.setViewName("/WEB-INF/jsp/items/itemsList.jsp"); return modelAndView; } //定義其它方法 //商品添加 //商品修改}
3.3在spring容器中加載Handler
<!-- 對于注解的Handler可以單個配置 實際開發(fā)中建議使用組件掃描 --> <!-- <bean class="joanna.yan.ssm.controller.ItemsController3" /> --> <!-- 可以掃描controller、service、... 這里讓掃描controller,指定controller的包 --> <context:component-scan base-package="joanna.yan.ssm.controller"></context:component-scan>
使用組件掃描器省去在spring容器配置每個controller類的繁瑣。使用<context:component-scan/>自動掃描標記@Controller的控制類。
3.4 部署調試
訪問:http://localhost:8080/SpringMVC/jyqueryItems.action
注意:在測試過程中單個配置注解的Handler運行沒有問題,在配置組件掃描器運行時,啟動Tomcat報錯:
View Code
原因是:我的Tomcat的jdk是1.8,項目的jdk版本是1.7,兩者不一樣造成的。記得要統(tǒng)一版本!
4.前端控制器源碼分析
通過前端控制器源碼分析springmvc的執(zhí)行過程。
第一步:前端控制器接收請求
調用doDispatch
第二步:前端控制器調用處理器映射器查找Handler
第三步:調用處理器適配器執(zhí)行Handler,得到執(zhí)行結果ModeAndView
第四步:視圖渲染,將model數(shù)據(jù)填充到request域。
視圖解析,得到view:
調用view的渲染方法,將model數(shù)據(jù)填充到request域。
渲染方法:
5.視圖解析器配置前綴和后綴
springmvc.xml中:
<!-- 配置視圖解析器 解析jsp視圖,默認使用jstl標簽,所有classpath下得有jstl的包 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <!--配置jsp路徑的前綴 --> <property name="prefix" value="/WEB-INF/jsp/"/> <!--配置jsp路徑的后綴 --> <property name="suffix" value=".jsp"/> </bean>
程序中不用指定前綴和后綴:
//指定視圖// modelAndView.setViewName("/WEB-INF/jsp/items/itemsList.jsp"); //下邊的路徑,如果在視圖解析器中配置jsp路徑的前綴和jsp路徑的后綴,修改為 modelAndView.setViewName("items/itemsList");
早年同窗始相知,三載瞬逝情卻萌。年少不知愁滋味,猶讀紅豆生南國。別離方知相思苦,心田紅豆根以生。
http://www.cnblogs.com/shanheyongmu/p/7198757.html