SpringMVC入门案例&请求&响应

SpringMVC简介

  • SpringMVC是一种基于java实现MVC模型的轻量级Web框架

  • Spring下的子项目:Spring Web MVC是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web框架,即使用了MVC架构模式的思想,将web层进行职责解耦,基于请求驱动指的就是使用请求-响应模型,框架的目的就是帮助我们简化开发,Spring Web MVC也是要简化我们日常Web开发的。

  • 优点

    • 使用简单
    • 性能突出
    • 灵活性强
  • MVC

    • Model 数据
    • View 视图
    • Controller 控制

入门案例

在这里插入图片描述

  • 流程
    1. tomcat启动加载web.xml
    2. 保证DispatcherServlet能够正常加载配置文件
    3. Spring配置文件必须扫描对应的controller

web.xml

<servlet>
		<servlet-name>DispatcherServlet</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath*:spring-mvc.xml</param-value>
		</init-param>
	</servlet>
	<servlet-mapping>
		<servlet-name>DispatcherServlet</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>

spring-mvc.xml

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd">

    <context:component-scan base-package="com.itheima"/>
</beans>

HelloWorld.java

@Controller
public class HelloWorld {

    @RequestMapping("/hello")
    public String Hello(){
        System.out.println("hello world");
        return "success.jsp";
    }
}

success.jsp

<%@page pageEncoding="UTF-8" language="java" contentType="text/html;UTF-8" %>
<html>
<body>
<h1>第一个spring-mvc页面</h1>
</body>
</html>

SpringMVC技术架构图

在这里插入图片描述

在这里插入图片描述

请求参数的获取

@Controller
@RequestMapping("/user")
public class UserController {
    //方法传递普通类型参数,数量任意,类型必须匹配
    //http://localhost/requestParam1?name=itheima
    //http://localhost/requestParam1?name=itheima&age=14
    @RequestMapping("/requestParam1")
    public String requestParam1(String name,int age){
        System.out.println(name+","+age);
        return "page.jsp";
    }

    //方法传递普通类型参数,使用@RequestParam参数匹配URL传参中的参数名称与方法形参名称
    //http://localhost/requestParam2?userName=Jock
    @RequestMapping("/requestParam2")
    public String requestParam2(@RequestParam(value = "userName",required = true) String name){
        System.out.println(name);
        return "page.jsp";
    }

    //方法传递POJO类型参数,URL地址中的参数作为POJO的属性直接传入对象
    //http://localhost/requestParam3?name=Jock&age=39
    @RequestMapping("/requestParam3")
    public String requestParam3(User user){
        System.out.println(user);
        return "page.jsp";
    }

    //当方法参数中具有POJO类型参数与普通类型参数嘶,URL地址传入的参数不仅给POJO对象属性赋值,也给方法的普通类型参数赋值
    //http://localhost/requestParam4?name=Jock&age=39
    @RequestMapping("/requestParam4")
    public String requestParam4(User user,int age){
        System.out.println("user="+user+",age="+age);
        return "page.jsp";
    }

    //使用对象属性名.属性名的对象层次结构可以为POJO中的POJO类型参数属性赋值
    //http://localhost/requestParam5?address.city=beijing
    @RequestMapping("/requestParam5")
    public String requestParam5(User user){
        System.out.println(user.getAddress().getCity());
        return "page.jsp";
    }

    //通过URL地址中同名参数,可以为POJO中的集合属性进行赋值,集合属性要求保存简单数据
    //http://localhost/requestParam6?nick=Jock1&nick=Jockme&nick=zahc
    @RequestMapping("/requestParam6")
    public String requestParam6(User user){
        System.out.println(user);
        return "page.jsp";
    }

    //POJO中List对象保存POJO的对象属性赋值,使用[数字]的格式指定为集合中第几个对象的属性赋值
    //http://localhost/requestParam7?addresses[0].city=beijing&addresses[1].province=hebei
    @RequestMapping("/requestParam7")
    public String requestParam7(User user){
        System.out.println(user.getAddresses());
        return "page.jsp";
    }
    //POJO中Map对象保存POJO的对象属性赋值,使用[key]的格式指定为Map中的对象属性赋值
    //http://localhost/requestParam8?addressMap['job'].city=beijing&addressMap['home'].province=henan
    @RequestMapping("/requestParam8")
    public String requestParam8(User user){
        System.out.println(user.getAddressMap());
        return "page.jsp";
    }

    //方法传递普通类型的数组参数,URL地址中使用同名变量为数组赋值
    //http://localhost/requestParam9?nick=Jockme&nick=zahc
    @RequestMapping("/requestParam9")
    public String requestParam9(String[] nick){
        System.out.println(nick[0]+","+nick[1]);
        return "page.jsp";
    }

    //方法传递保存普通类型的List集合时,无法直接为其赋值,需要使用@RequestParam参数对参数名称进行转换
    //http://localhost/requestParam10?nick=Jockme&nick=zahc
    @RequestMapping("/requestParam10")
    public String requestParam10(@RequestParam("nick") List<String> nick){
        System.out.println(nick);
        return "page.jsp";
    }

    //数据类型转换,使用自定义格式化器或@DateTimeFormat注解设定日期格式
    //两种方式都依赖springmvc的注解启动才能运行
    //http://localhost/requestParam11?date=1999-09-09
    @RequestMapping("/requestParam11")
    public String requestParam11(@DateTimeFormat(pattern = "yyyy-MM-dd") Date date){
        System.out.println(date);
        return "page.jsp";
    }

    //数据类型转换,使用自定义类型转换器,需要配置后方可使用
    @DateTimeFormat(pattern = "yyyy-MM-dd")
	private Date birthday;
    //http://localhost/requestParam12?date=1999-09-09
    @RequestMapping("/requestParam12")
    public String requestParam12(Date date){
        System.out.println(date);
        return "page.jsp";
    }

    //无类映射地址访问格式
    //http://localhost/requestURL1
    @RequestMapping("/requestURL1")
    public String requestURL1(){
        return "page.jsp";
    }

    //带有类映射地址访问格式,需要将类映射地址作为前缀添加在实际映射地址的前面
    //最终返回的页面如果未设定绝对访问路径,将从类映射地址所在目录中查找
    //http://localhost/user/requestURL2     (注意:要配合类上定义的路径使用)
    @RequestMapping("/requestURL2")
    public String requestURL2(){
        return "/page.jsp";
    }

    //@RequestMapping参数,一个路径参数,6个访问限定性参数(了解)
    @RequestMapping(value="/requestURL3",params = "name")
    public String requestURL3(){
        return "page.jsp";
    }
}
日期类型格式转换(配置文件方式)
<!--5.启用自定义Converter-->
<mvc:annotation-driven conversion-service="conversionService"/>
<!--1.设定格式类型Converter,注册为Bean,受SpringMVC管理--> 
<bean id="conversionService" 
class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
	<!--2.自定义Converter格式类型设定,该设定使用的是同类型覆盖的思想--> 
    <property name="formatters">
		<!--3.使用set保障相同类型的转换器仅保留一个,避免冲突-->
    	<set>
			<!--4.设置具体的格式类型--> 
    		<bean class="org.springframework.format.datetime.DateFormatter">
					<!--5.类型规则--> 
    				<property name="pattern" value="yyyy-MM-dd"/>
			</bean>
		</set>
	</property>
</bean>
日期类型格式转换(注解方式)
  • @DateTimeFormat
  • 形参注解,成员变量注解
  • 位置 : 形参前面 或 成员变量上方
  • 作用 : 为当前参数或变量指定类型装好规则
  • 范例
//数据类型转换,使用自定义格式化器或@DateTimeFormat注解设定日期格式
//两种方式都依赖springmvc的注解启动才能运行
//http://localhost/requestParam11?date=1999-09-09
@RequestMapping("/requestParam11")
public String requestParam11(@DateTimeFormat(pattern = "yyyy-MM-dd") Date date){
    System.out.println(date);
    return "page.jsp";
}

//数据类型转换,使用自定义类型转换器,需要配置后方可使用
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday;
//http://localhost/requestParam12?date=1999-09-09
@RequestMapping("/requestParam12")
public String requestParam12(Date date){
    System.out.println(date);
    return "page.jsp";
}
  • 注意 : 依赖注解驱动支持
<mvc:annotation-driven />
自定义转换器
<!--6.启用自定义Converter-->
<mvc:annotation-driven conversion-service="conversionService"/> 
<!--1.将自定义Converter注册为Bean,受SpringMVC管理--> 
<bean id="myDateConverter" class="com.itheima.converter.MyDateConverter"/> 
<!--2.设定自定义Converter服务bean--> 
<bean id="conversionService"  
class="org.springframework.context.support.ConversionServiceFactoryBean"> 
<!--3.注入所有的自定义Converter,该设定使用的是同类型覆盖的思想--> 
	<property name="converters"> 
		<!--4.set保障同类型转换器仅保留一个,去重规则以Converter<S,T>的泛型为准-->*
		<set> 
			<!--5.具体的类型转换器-->
			<ref bean="myDateConverter"/> 
		</set> 
	</property> 
</bean>
public class MyDateConverter implements Converter<String,Date> {
	@Override
	public Date convert(String source) {
		DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
		Date date = null;
		try {
			date = format.parse(source);
		} catch (ParseException e) {
			e.printStackTrace();
		}
		return date;
	} 
}

响应

页面跳转

转发
@RequestMapping("/showPage1")
public String showPage1() {
	System.out.println("user mvc controller is running ...");
	return "forward:page.jsp"; 
}
重定向
@RequestMapping("/showPage2")
public String showPage2() {
	System.out.println("user mvc controller is running ...");
	return "redirect:page.jsp"; 
}
快捷设定(视图解析器)
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
	<property name="prefix" value="/WEB-INF/pages/"/>
	<property name="suffix" value=".jsp"/>
</bean>
@RequestMapping("/showPage3")
public String showPage3() {
	return "page"; 
}

注意 : 默认是forward转发,如果要用redirect重定向就不能使用视图解析器

携带数据跳转

@Controller
public class BookController {
    //使用原生request对象传递参数
    @RequestMapping("/showPageAndData1")
    public String showPageAndData1(HttpServletRequest request) {
        request.setAttribute("name","itheima");
        return "page";
    }
    //使用Model形参传递参数
    @RequestMapping("/showPageAndData2")
    public String showPageAndData2(Model model) {
        //添加数据的方式,key对value
        model.addAttribute("name","Jock");
        Book book  = new Book();
        book.setName("SpringMVC入门案例");
        book.setPrice(66.66d);
        //添加数据的方式,key对value
        model.addAttribute("book",book);
        return "page";
    }

    //使用ModelAndView形参传递参数,该对象还封装了页面信息
    @RequestMapping("/showPageAndData3")
    public ModelAndView showPageAndData3(ModelAndView modelAndView) {
        //ModelAndView mav = new ModelAndView();    替换形参中的参数
        Book book  = new Book();
        book.setName("SpringMVC入门案例");
        book.setPrice(66.66d);

        //添加数据的方式,key对value
        modelAndView.addObject("book",book);
        //添加数据的方式,key对value
        modelAndView.addObject("name","Jockme");
        //设置页面的方式,该方法最后一次执行的结果生效
        modelAndView.setViewName("page");
        //返回值设定成ModelAndView对象
        return modelAndView;
    }

    //ModelAndView对象支持转发的手工设定,该设定不会启用前缀后缀的页面拼接格式
    @RequestMapping("/showPageAndData4")
    public ModelAndView showPageAndData4(ModelAndView modelAndView) {
        modelAndView.setViewName("forward:/WEB-INF/page/page.jsp");
        return modelAndView;
    }

    //ModelAndView对象支持重定向的手工设定,该设定不会启用前缀后缀的页面拼接格式
    @RequestMapping("/showPageAndData5")
    public ModelAndView showPageAndData5(ModelAndView modelAndView) {
        modelAndView.setViewName("redirect:page.jsp");
        return modelAndView;
    }
}

返回JSON数据

@Controller
public class AccountController {
    //使用原生response对象响应数据
    @RequestMapping("/showData1")
    public void showData1(HttpServletResponse response) throws IOException {
        response.getWriter().write("message");
    }

    //使用@ResponseBody将返回的结果作为响应内容,而非响应的页面名称
    @RequestMapping("/showData2")
    @ResponseBody
    public String showData2(){
        return "{'name':'Jock'}";
    }

    //使用jackson进行json数据格式转化
    @RequestMapping("/showData3")
    @ResponseBody
    public String showData3() throws JsonProcessingException {
        Book book  = new Book();
        book.setName("SpringMVC入门案例");
        book.setPrice(66.66d);

        ObjectMapper om = new ObjectMapper();
        return om.writeValueAsString(book);
    }

    //使用SpringMVC注解驱动,对标注@ResponseBody注解的控制器方法进行结果转换,由于返回值为引用类型,自动调用jackson提供的类型转换器进行格式转换
    @RequestMapping("/showData4")
    @ResponseBody
    public Book showData4() {
        Book book  = new Book();
        book.setName("SpringMVC入门案例");
        book.setPrice(66.66d);
        return book;
    }

    //转换集合类型数据
    @RequestMapping("/showData5")
    @ResponseBody
    public List showData5() {
        Book book1  = new Book();
        book1.setName("SpringMVC入门案例");
        book1.setPrice(66.66d);

        Book book2  = new Book();
        book2.setName("SpringMVC入门案例");
        book2.setPrice(66.66d);

        ArrayList al = new ArrayList();
        al.add(book1);
        al.add(book2);
        return al;
    }
}
<mvc:annotation-driven/>

简单小结

SpringMVC会不会使用Spring?

  • 使用了

如果使用了,那么容器什么时候创建(配置文件什么时候加载)?

  • web.xml中的DispatcherServlet中加载的

启动tomcat会先加载web.xml

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值