zoukankan      html  css  js  c++  java
  • SpringMVC基础学习(一)—初识SpringMVC

    一、HelloWorld

    1.导入SpringMVC所需的jar包

         image

    2.配置web.xml

         配置DispatcherServletDispatcherServlet默认加载/WEB-INF/<servletName-servlet>.xml 的Spring配置文件,启动Web层的Spring容器。可以通过contextConfigLocation初始化参数自定义配置文件的位置和名称。

    web.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
        http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
    
    
        <!-- 配置DispatcherServlet -->
        <servlet>
            <servlet-name>dispatcherServlet</servlet-name>
            <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
            <!-- 配置 DispatcherServlet 的一个初始化参数: 配置 SpringMVC 配置文件的位置和名称 -->
            <init-param>
                <param-name>contextConfigLocation</param-name>
                <param-value>classpath:springmvc.xml</param-value>
            </init-param>
        </servlet>
    
        <servlet-mapping>
            <servlet-name>dispatcherServlet</servlet-name>
            <url-pattern>/</url-pattern>
        </servlet-mapping>
    
    </web-app>

    3.创建SpringMVC的配置文件

    springmvc.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <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"
        xmlns:mvc="http://www.springframework.org/schema/mvc"
        xsi:schemaLocation="http://www.springframework.org/schema/beans 
                            http://www.springframework.org/schema/beans/spring-beans.xsd
                            http://www.springframework.org/schema/context
                            http://www.springframework.org/schema/context/spring-context.xsd
                            http://www.springframework.org/schema/mvc
                            http://www.springframework.org/schema/mvc/spring-mvc.xsd">
                            
            <!-- 配置自动扫描的包 -->
            <context:component-scan base-package="com.kiwi"/>                
            
            <!-- 配置视图解析器: 如何把handler方法返回值解析作为实际的物理视图-->
            <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
                <property name="prefix" value="/WEB-INF/views/"/>
                <property name="suffix" value=".jsp"/>
            </bean>
    </beans>

    4.创建请求处理类

    @Controller
    public class HelloWorld{
    
    	/*
    	 * 1.使用@RequestMapping注解来映射请求的URL
    	 * 2.返回值会通过视图解析器解析为实际的物理视图,对于InternalResourceViewResolver会做如下解析
    	 *   prefix + returnVal + "suffix 会得到实际的物理视图,然后做转发操作
    	 *   /WEB-INF/views/success.jsp
    	 */
    	@RequestMapping("/helloWorld")
    	public String hello(){
    		System.out.println("Hello World");
    		return "success";
    	}
    }

    index.jsp

    <a href="helloWorld">Test</a>

    二、使用@RequestMapping映射请求

    1.@RequestMapping修饰类

    (1)SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些URL请求。

    (2)@RequestMapping可以在类和方法处定义:

        类定义处: 提供初步的请求映射信息,相当于WEB应用的根目录。

        方法处: 提供细分映射信息,相当于类定义处URL,如果类定义未标注,相当于WEB根目录。

    @Controller
    @RequestMapping("/demo")
    public class TestDemo{
    
    	private static final String SUCCESS = "success";
    	
    	/*
    	 * 1.@RequestMapping不仅可以修饰方法,还可以修饰类
    	 */
    	@RequestMapping("/test")
    	public String test(){
    		
    		System.out.println("test()......");
    		
    		return SUCCESS;
    	}
    }
    此时请求路径: http://localhost:8080/springmvc-01/demo/test

    (1)类定义处@RequestMapping限定处理器类可以处理所有URI为"/demo"的请求,它相当于WEB容器的根目录。

    (2)处理器可以定义多个方法来处理来之"/demo"的请求。

    2.请求参数、请求方法、请求头

    (1)@RequestMapping除了可以使用请求URL映射请求外,还可以使用请求方法、请求参数及请求头映射请求。

    (2)valuemethodparamsheaders分别表示请求URL、请求方法、请求参数、请求头

    (3)params和headers支持简单的表达式。

         param1: 请求必须包含param1的请求参数。

         !param1: 表示请求不能包含名为param1的请求参数。

        param1 != value1: 请求包含名为param1的请求参数但是不能为value1。

    	/*
    	 * 1.请求方式必须是GET请求
    	 * 2.请求参数必须带有"name"
    	 * 3.eg: http://localhost:8080/springmvc-01/demo/method?name=Tom
    	 */
    	@RequestMapping(value="/method",method=RequestMethod.GET,params="name")
    	public String testMethod(){
    		
    		return SUCCESS;
    	}

    3.匹配符

    ?: 匹配文件名中的一个字符。
    *: 匹配文件名中的任意字符。
    **:  匹配多层路径。

    /a/*/b

    匹配: /a/aaa/b、/a/bbb/b


    /a/**/b

    匹配: /a/b、/a/aaa/bbb/b

    /a/b??

    匹配: /a/baa、/a/bbb

    4.@PathVariable映射URL绑定的占位符

         通过@PathVariable可以将URL中站位符参数绑定到控制器处理方法的入参中。

    	@RequestMapping(value = "/user/{userId}/role/{roleId}",method = RequestMethod.GET)
    	public String getLogin(@PathVariable("userId") String userId,
    						   @PathVariable("roleId") String roleId){
    		System.out.println("User Id : " + userId);
    		System.out.println("Role Id : " + roleId);
    		return SUCCESS;
    	}

    http://localhost:8080/springmvc-01/demo/user/11/role/22

    结果:

         User Id : 11
         Role Id : 22

    5.使用@RequestParam绑定请求参数值

    (1)在处理方法入参处使用@RequestParam可以把请求参数传递给请求方法。

    (2)value: 参数名。

        required: 是否必须,默认为true。表示请求参数必须包含对应的参数,不存在,将抛出异常。

    	@RequestMapping("/param")
    	public String testParam(@RequestParam(value="username",required=false) String username,
    						  @RequestParam(value="password") String password){
    		
    		System.out.println("username: " + username);
    		System.out.println("password: " + password);
    		
    		return SUCCESS;
    	}

    http://localhost:8080/springmvc-01/demo/param?username=Tom&password=123

    结果:

          username: Tom
          password: 123

    6.使用POJO对象绑定请求参数值

    SpringMVC会按请求参数名POJO属性名进行自动匹配自动为该对象填充属性值,支持级联属性。

    index.jsp

    <form action="${pageContext.request.contextPath}/demo/test" method="post">
              username: <input type="text" name="username"/><br>
              password: <input type="password" name="password"/><br>
              province: <input type="text" name="address.province"/><br>
              city: <input type="text" name="address.city"/><br>
              
              <input type="submit" value="提交"/>
    </form>

    User.java

    image

    TestDemo.java

    @Controller
    @RequestMapping("/demo")
    public class TestDemo{
    
    	private static final String SUCCESS = "success";
    	
    	@RequestMapping("/test")
    	public String testPOJO(User user){
    		
    		System.out.println(user);
    		
    		return SUCCESS;
    	}
    	
    }
    结果:

         User [username=Tom, password=123, address=Address [province=BeiJing, city=Changping]]

    7.使用Servlet API作为入参

    可以接受以下类型的参数:

    1.HttpServletRequest、2.HttpServletResponse、3.HttpSession、4.java.security.Principal
    5.Locale、6.InputStream、7.OutputStream、8.Reader

    	@RequestMapping("/test")
    	public String testServlet(HttpServletRequest request){
    		
    		String username = request.getParameter("username");
    		
    		System.out.println(username);
    		
    		return SUCCESS;
    	}

    http://localhost:8080/springmvc-01/demo/test?username=Tom

    结果:

        Tom

  • 相关阅读:
    轮播效果
    获取用户请求过来的URL
    前端框架——AmazeUI学习
    评论功能——多说插件学习
    SqlServer中——查找杀死阻塞进程
    Java 时区(转)
    大型网站技术演进的思考(转)
    elasticsearch threadpool
    UML 类图
    elasticsearch No node available
  • 原文地址:https://www.cnblogs.com/yangang2013/p/5594026.html
Copyright © 2011-2022 走看看