SpringMvc

本文详细介绍了SpringMVC的入门案例,包括工程搭建、核心控制器配置及视图解析器设置。同时深入讲解了@RequestMapping、@RequestParam、@RequestBody、@PathVariable等常用注解的使用方法和应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SpringMvc(后期持续完善)

1.SpringMvc的入门案列

1.创建WEB工程,引入开发jar包

​ 1.具体的坐标如下:

<!-- 版本锁定 -->
<properties>
	<spring.version>5.0.2.RELEASE</spring.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>${spring.version}</version>
        </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>servlet-api</artifactId>
        <version>2.5</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet.jsp</groupId>
        <artifactId>jsp-api</artifactId>
        <version>2.0</version>
        <scope>provided</scope>
    </dependency>
</dependencies>

2.配置核心的控制器(配置DispatcherServlet)

​ 1.在web.xml配置文件中核心控制器DispatcherServlet

<!-- SpringMVC的核心控制器 -->
<servlet>
    <servlet-name>dispatcherServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servletclass>
    <!-- 配置Servlet的初始化参数,读取springmvc的配置文件,创建spring容器 -->
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:springmvc.xml</param-value>
    </init-param>
    <!-- 配置servlet启动时加载对象 -->
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>

3.编写springmvc.xml的配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">
    <!-- 配置spring创建容器时要扫描的包 -->
    <context:component-scan base-package="com.itheima"></context:component-scan>
    <!-- 配置视图解析器 -->
    <bean id="viewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/pages/"></property>
        <property name="suffix" value=".jsp"></property>
	</bean>
    <!-- 配置spring开启注解mvc的支持
    <mvc:annotation-driven></mvc:annotation-driven>-->
</beans>

4.编写index.jsp和HelloController控制器类

​ 1.index.jsp

<body>
    <h3>入门案例</h3>
    <a href="${ pageContext.request.contextPath }/hello">入门案例</a>
</body>

​ 2.HelloController

package cn.itcast.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
/**
* 控制器
* @author rt
*/
@Controller
public class HelloController {
/**
* 接收请求
* @return
*/
@RequestMapping(path="/hello")
public String sayHello() {
System.out.println("Hello SpringMVC!!");
return "success";
}
}

5.在WEB-INF目录下创建pages文件夹,编写success.jsp的成功页面

<body>
	<h3>入门成功!!</h3>
</body>

6.启动Tomcat服务器,进行测试

2.SpringMvc中的常用注解

1.@RequestMapping注解

1. RequestMapping注解的作用是建立请求URL和处理方法之间的对应关系
2. RequestMapping注解可以作用在方法和类上
    1. 作用在类上:第一级的访问目录
    2. 作用在方法上:第二级的访问目录
    3. 细节:路径可以不编写 / 表示应用的根目录开始
    4. 细节:${ pageContext.request.contextPath }也可以省略不写,但是路径上不能写 /
3. RequestMapping的属性
    1. path 指定请求路径的url
    2. value value属性和path属性是一样的
    3. mthod 指定该方法的请求方式
4. params 指定限制请求参数的条件
5. headers 发送的请求中必须包含的请求头

**2.@RequestParam注解 **

1. 作用:把请求中的指定名称的参数传递给控制器中的形参赋值
2. 属性
    1. value:请求参数中的名称
    2. required:请求参数中是否必须提供此参数,默认值是true,必须提供

代码如下:

<a href="/testRequestParam?username=王五">测试@RequestParam</a>

/**
 * @Author: gcl
 * @Date: 2019/4/29 8:44
 */
@Controller
public class AnnotationTest {
    /**
     * 测试@RequestParam
     */
    @RequestMapping("/testRequestParam")
    public String testRequestParam(@RequestParam("username") String name){
        System.out.println("name"+name);
        return "success";
    }

}

注意:  如果写成<a href="/testRequestParam?name=王五">测试@RequestParam</a>
	  会出现如下错误:

1556499913732

<a href="/testRequestParam2?age=3">testRequestParam2</a>

 /**
     * 测试@RequestParam注解
     */
    @RequestMapping("/testRequestParam2")
    public String testRequestParam2(@RequestParam(value="username") int age){
        System.out.println(age);
        return "success";
    }

1556503935714

解决上面问题:

提交的参数是字符串类型
方案一:
 /**
     * 测试@RequestParam注解
     */
    @RequestMapping("/testRequestParam2")
    public String testRequestParam2(@RequestParam(value="username",defaultValue = "0") int age){
        System.out.println(age);
        return "success";
    }

方案二:(推荐使用)
/**
     * 测试@RequestParam注解
     */
    @RequestMapping("/testRequestParam2")
    public String testRequestParam2(@RequestParam(value="username") Integer age){
        System.out.println(age);
        return "success";
    }

**3.@RequestBody注解 **

作用:
    用于获取请求体内容。 直接使用得到是 key=value&key=value...结构的数据。
    get 请求方式不适用。
    属性:
required:是否必须有请求体。默认值是:true。当取值为 true 时,get 请求方式会报错。如果取值
为 false, get 请求得到是 null。

代码如下:

<form ACTION="/testRequestBody" method="post">
    <input type="text" name="username" >
    <input type="submit" value="submit">
</form>

	
    /**
     * 测试@RequestBody
     */
    @RequestMapping("/testRequestBody")
    public String testRequestBody(@RequestBody String body){
        System.out.println("body"+body);
        return "success";
    }

问题:

​ 1.中文会乱码,如何解决?

​ 2.@RequestBody 的另一种作用?

4.@PathVariable注解

1. 作用:拥有绑定url中的占位符的。例如:url中有/delete/{id},{id}就是占位符
2. 属性
	1. value:指定url中的占位符名称
3. Restful风格的URL
    1. 请求路径一样,可以根据不同的请求方式去执行后台的不同方法
    2. restful风格的URL优点
        1. 结构清晰
        2. 符合标准
        3. 易于理解
        4. 扩展方便

5.@RequestHeader注解

作用:
    用于获取请求消息头。
属性:
    value:提供消息头名称
    required:是否必须有此消息头
注:
	在实际开发中一般不怎么用。

代码如下:

jsp 中代码:
<!-- RequestHeader 注解 -->
<a href="springmvc/useRequestHeader">获取请求消息头</a>
控制器中代码:
/**
* RequestHeader 注解
* @param user
* @return
*/
@RequestMapping("/useRequestHeader")
public String useRequestHeader(@RequestHeader(value="Accept-Language",
    required=false)String requestHeader){
    System.out.println(requestHeader);
    return "success";
}

**6.CookieValue 注解 **

作用:
	用于把指定 cookie 名称的值传入控制器方法参数。
属性:
    value:指定 cookie 的名称。
    required:是否必须有此 cookie。

代码如下:

jsp 中的代码:
<!-- CookieValue 注解 -->
<a href="springmvc/useCookieValue">绑定 cookie 的值</a>
控制器中的代码:
    /**
     * Cookie 注解注解
     * @param user
     * @return
     */
@RequestMapping("/useCookieValue")
public String useCookieValue(@CookieValue(value="JSESSIONID",required=false)String cookieValue){
    System.out.println(cookieValue);
    return "success";
}

**7.@ModelAttribute 注解 **

1. 作用
    1. 出现在方法上:表示当前方法会在控制器方法执行前线执行。
    2. 出现在参数上:获取指定的数据给参数赋值。
2. 应用场景
	1. 当提交表单数据不是完整的实体数据时,保证没有提交的字段使用数据库原来的数据。	

代码如下:


**8.@SessionAttributes 注解 **

1. 作用:用于多次执行控制器方法间的参数共享
2. 属性
	1. value:指定存入属性的名称

代码如下:


3.RestFul风格

前端代码:

<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" isErrorPage="true" %>
<html>
<body>
<h3>入门案例</h3>
<a href="${ pageContext.request.contextPath }/hello">入门案例</a>
<a href="${ pageContext.request.contextPath }/pathVariable/259">PathVariable测试</a>
<hr color="blue">
<a href="/restful/book/1">GET请求</a>
<hr color="blue">
<form action="/restful/book" method="post">
    <input type="submit" value="POST">
</form>
<hr color="blue">
 <%--当时将action="/restful/book"时报405,应该写成action="/restful/book/1"因为后端的方法上为 @RequestMapping(value = "/book/{id}",method =RequestMethod.DELETE)
    --%>
<form action="/restful/book/1" method="post">
    <input type="hidden" name="_method" value="DELETE">
    <input type="submit" value="DELETE">
</form>
<hr color="blue">
<form action="/restful/book/1" method="post">
    <input type="hidden" name="_method" value="PUT">
    <input type="submit" value="PUT">
</form>

</body>
</html>

后端代码:

package com.heimanba.controller;

/**
 * @Author: gcl
 * @Date: 2019/4/29 0:09
 */

import org.springframework.web.bind.annotation.*;

/**
 * GET  用来获取资源
 * POST    用来新建资源
 * DELETE  用来删除资源
 * PUT      用来更新资源
 *
 */

@RestController
@RequestMapping("/restful")

public class RestFulTest {
    /**
     * GET请求
     */
    @RequestMapping(value = "/book/{id}")
    public String testGet(@PathVariable("id")  int id){
        System.out.println("测试GET请求"+id);
        return "success";
    }

    /**
     * POST请求
     */
    @RequestMapping(value = "/book",method = RequestMethod.POST)
    public String testPost(){
        System.out.println("测试POST请求");
        return "success";
    }

    /**
     * DELETE请求
     */
    @RequestMapping(value = "/book/{id}",method = RequestMethod.DELETE)
    public String testDelete(@PathVariable("id") int id){
        System.out.println("测试DELETE请求"+id);
        return "success";
    }

    /**
     * PUT请求
     */
    @RequestMapping(value = "/book/{id}",method = RequestMethod.PUT)
    public String testPut(@PathVariable("id") int id){
        System.out.println("测试PUT请求"+id);
        return "success";
    }

}

出现问题:

​ 出现405,是由于tomcat版本过高,在success.jsp页面头上添加isErrorPage="true"即可解决问题

总结:如何发送DELETE或PUT请求?

  1. 需要配置HiddenHttpMethodFilter
  2. 需要发送POST请求
  3. 需要在发送POST请求时携带一个name="_method"的隐藏域,value="DELTE或PUT"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值