SpringMVC学习 --------- 2、注解式的Handler开发

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"/>	
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值