SpringMVC学习(1)--SpringMVC的第一个HelloWorld及@RequestMapping注解的基本使用

7 篇文章 0 订阅

一、SpringMVC的第一个HelloWorld

Spring MVC主要由DispatcherServlet、处理器映射、处理器(控制器)、视图解析器、视图组成。他的两个核心是:
处理器映射:选择使用哪个控制器来处理请求 
视图解析器:选择结果应该如何渲染

1.导入基本所需jar包:


2.在Web.xml配置文件中配置SpringMVC

<?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>springDispatcherServlet</servlet-name>
	<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
	<!--配置SpringMVC的一个初始化参数:作用是配置SpringMVC配置文件的位置和名称  -->
	<init-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>classpath:spring-mvc.xml</param-value>
	</init-param>
	<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
	<servlet-name>springDispatcherServlet</servlet-name>
	<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自已定义,把拦截下来的请求,依据相应的规则分发到目标Controller来处理,是配置spring MVC的第一步。

3.在src下添加springmvc.xml配置文件

<!-- 自动扫描controller包下的所有类,使其认为spring mvc的控制器 -->
<context:component-scan base-package="com.study.springmvc.handlers" />
<!-- 配置视图解析器:如何把handler方法返回值解析为实际的物理视图 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
	<property name="prefix" value="/WEB-INF/views/"></property>
	<property name="suffix" value=".jsp"></property>
</bean>
4.在WEB-INF下添加views文件夹,用于存放jsp页面

5.建立扫描的包并创建类用于实现helloworld


package com.study.springmvc.handlers;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

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

6.在index.jsp中编写代码,实现导向上述helloworld地址的链接

<body>
    <a href="helloworld">Hello World</a>
</body>

7.在views文件夹下创建success.jsp
<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    <title>success page</title>
  </head>
  <body>
    <h4>success page</h4>
  </body>
</html>

8.将工程加入tomcat中。启动服务器,访问:http://localhost:8080/springMVC-study/index.jsp

二、@RequestMapping注解的基本使用

@RequestMapping 注解为控制器指定可以处理哪些 URL 请求。

1.@RequestMapping 修饰类和方法

除了类似于上述代码中可以放在方法的上面修饰方法,还可以用来修饰类。

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

2).方法处:提供进一步的细分映射信息。若类定义处没有使用@RequestMapping ,则方法处的请求映射信息就相当于WEB应用的根目录。

2.@RequestMapping 的value属性

value的值:指定请求的实际地址
@RequestMapping("/helloworld")和@RequestMapping(value="/helloworld")一样

3.@RequestMapping 的method属性

method的值:指定请求的method类型, GET、POST、PUT、DELETE等

@RequestMapping(value="/helloworld",method=RequestMethod.POST)
	public String test(){
		System.out.println("HelloWorld");
		return "success";
	}
当请求的方法指定请求方式时,则需要用对应的请求方式进行请求,否则会出现类似下面的错误:定义的POST,却使用了GET请求方式

4.@RequestMapping 的params属性: 指定request中必须包含某些参数值时,才让该方法处理。

5.@RequestMapping 的headers属性: 指定request中必须包含某些指定的header值,才能让该方法处理请求。

6. @RequestMapping 和@PathVariable的配合使用

@PathVariable 可以来映射url中的占位符到目标方法的参数中

例如:index.jsp:

<a href="pathVariable/aha">pathVariable</a>
HelloWorld.java:

/**
	 * @PathVariable 可以来映射url中的占位符到目标方法的参数中
	 */
	@RequestMapping("/pathVariable/{str}")
	public String pathVariable(@PathVariable("str") String aaa){
		System.out.println("pathVariable:"+aaa);
		return "success";
	}

输出结果:pathVariable:aha



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值