SpringMVC基础

SpringMVC:是一个基于MVC模式的WEB/表现层框架,可以理解为它代替了Servlet;
是Spring框架中的一个功能模块,可以与Spring无缝集成,提高开发效率;
它解决WEB开发中常见的问题:参数接收、文件上传/下载、表单验证、国际化等等;

===================================================================
webmvc框架的心脏就是核心控制器(就是前端控制器),负责所有请求的公共功能,然后在分发给具体的控制器(我们编写的控制器),完成业务逻辑,响应视图;

核心控制器其实就是一个Servlet,只不过这个Servlet是由SpringMVC框架提供的,不需要自己写,只需要配置,交给容器去管理。在web.xml配置核心控制器(容器启动时就创建sevlet实例对象,并加载classpath下的一个名为spring-mvc.xml文件);

===================================================================

业务处理控制器的三种实现
1、实现Controller接口,重写handleRequest方法;
需要配置

<!--浏览器访问,直接输id -->
<bean id="/controller01" class="cn.itsource.springmvc.Controller01"></bean>

2、实现HttpRequestHandler接口,重写handleRequest方法;
需要配置

<!--和上一种差不多 -->
<bean id="/controller02" class="cn.itsource.springmvc.Controller02"></bean>

3、普通类(pojo)和注解 @Controller@RequestMapping
SpringMVC中的Controller是单例的,所以使用成员变量请注意线程安全问题
要开启扫描包和spring对MVC注解的支持

1.要使用@Controller注解(创建对象的注解),就需要配置:
<!-- 扫描包路径:会扫描cn.itsource包及其子包下所有的类,
	 如果类上面有实例化Bean的注解(例如:@Controller),容器就会创建该类的实例,并交给容器管理。否则不创建 -->
<context:component-scan base-package="cn.itsource" />
2.要使用@RequestMapping注解(请求映射注解),就需要配置:
<!-- 开启spring对mvc的支持:即能够使用@RequestMapping注解 -->
<mvc:annotation-driven/>

在这里插入图片描述

===================================================================

/**
 * SpringMvc执行请求的处理器写法三:普通类+注解
 * @Controller,要在application中开启注解扫描才有效,<context:component-scan base-package="放controller类的包的限定路径" />
 * @RequestMapping("/login"),类上面也可以加
 * 
 * SpringMvc执行请求的处理器写法四,原始写servlet
 */
@Controller
@RequestMapping("/login")
public class LoginController {
	/**
	 *路径为/login/form2
	 *  前端值到后台一:通过参数接收
	 * 参数名必须和表单项的name属性值保持一致
	 */
	@RequestMapping("/form2")
	public void login2(String name,String pwd) {
		System.out.println(name);
		System.out.println(pwd);
	}
	/**
	 *  前端值到后台二:通过对象接收(字段太多的情况)
	 * 参数名必须和表单项的name属性值保持一致
	 */
	 @RequestMapping("/form3")
	 public void login3(User user) {
		System.out.println(user);
	 }
	 /**
	 * 
	 *前端值到后台三:原始的HttpServletRequest,req.getParamter("name")
	 * 
	 * 前端值到后台四:过路径接收参数(reatful风格),
	 * @RequestMapping("/form4/{id}/{username}")
	 * public void form4(@PathVariable("id")Long id,@PathVariable("username")String name){}
	 */
	
	
//==========================================================================

	/**
	 * 不管用什么,都是放到当前页面这个作用域
	 * 后台到前端值一:用Model(MVC层的标准)
	 */
	@RequestMapping("/form4")
	public String login4(Model model) {
		model.addAttribute("name", "hp");
		return "/WEB-INF/jsp/index.jsp";
	}
	
	/**
	 * 后台到前端值二:用Map
	 */
	@RequestMapping("/form5")
	public String login5(Map<String, Object> map) {
		map.put("name", "shp");
		return "/WEB-INF/jsp/index.jsp";
	}
	
	/**
	 * 后台到前端值三:用ModelAndView(不常用)
	 */
	@RequestMapping("/form6")
	public ModelAndView login6() {
		ModelAndView view = new ModelAndView();
		view.addObject("name", "shiheping");
		view.setViewName("/WEB-INF/jsp/index.jsp");
		return view;
	}
	
	/**
	 * 后台到前端值四:原生的req.setAttribute("message5", "tom");
	 */
	@RequestMapping("/form7")
	public void login7(HttpServletRequest req,HttpServletResponse resp) throws ServletException, IOException {
		req.setAttribute("name", "和");
		req.getRequestDispatcher("/WEB-INF/jsp/index.jsp").forward(req, resp);//这种转发或者重定向不会用视图解析器
	}


//==========================================================================	
	
	/**
	 * 视图解析器开启
	 * 那么之前的路径就不对了哟
	 * 如果是配置下的页面,直接return "页面名",默认跳转方式为:转发
	 */
	@RequestMapping("/form8")
	public String login8(Map<String, Object> map) {
		map.put("name", "shp2");
		return "index";
	}
	
	/**
	 * 视图解析器开启
	 * 如果不是配置下的页面
	 * 转发:forward:/WEB-INF/error.jsp;
	 * 重定向:redirect:/hello.jsp;
	 */
	@RequestMapping("/form9")
	public String login9(Map<String, Object> map) {
		map.put("name", "shp3");
//		return "forward:/WEB-INF/index.jsp";
		return "redirect:/index.jsp";//不能访问/WEB-INF下的资源
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值