SpringMVC框架詳細教程(六)_HelloWorld

  • 2020 年 4 月 17 日
  • 筆記

HelloWorld

在src下創建包com.pudding.controller,然後創建一個類HelloWorldController

package com.pudding.controller;

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

@Controller
public class HelloWorldController {

	@RequestMapping("/hello")
	public String hello() {

		return "/WEB-INF/views/success.jsp";
	}

}

然後在webapp/WEB-INF/views/下創建success.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "//www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	<h1>success</h1>
</body>
</html>

項目目錄結構如下:

在Servers視圖下右擊伺服器選擇 Start 啟動Tomcat伺服器:

確認Tomcat伺服器啟動成功之後,打開瀏覽器訪問 //localhost:8080/SpringMVC/hello:

可以發現我們請求了 //localhost:8080/SpringMVC/hello 地址,並且顯示了success.jsp頁面。你可以試一試將上一節我們配置的<context:component-scan base-package="com.pudding" />刪掉,是不是就不能正常執行了。


分析一下HelloWorldController的程式碼:

package com.pudding.controller;

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

@Controller
public class HelloWorldController {

	@RequestMapping("/hello")
	public String hello() {

		return "/WEB-INF/views/success.jsp";
	}

}
  • @Controller:首先有一個類註解@Controller,@Controller註解表明了一個類是作為控制器的角色而存在的。Spring不要求你去繼承任何控制器基類,也不要求你去實現Servlet的那套API。當然,如果你需要的話也可以去使用任何與Servlet相關的特性和設施。

    俗話講就是@Controller註解把類註冊進Spring容器中,讓Spring容器來管理這個類,並告訴Spring容器這個類是一個控制器

  • @RequestMapping:你可以使用@RequestMapping註解來將請求URL,如`/hello等,映射到整個類上或某個特定的控制器方法上。一般來說,類級別的註解負責將一個特定(或符合某種模式)的請求路徑映射到一個控制器上,同時通過方法級別的註解來細化映射,即根據特定的HTTP請求方法(「GET」「POST」方法等)、HTTP請求中是否攜帶特定參數等條件,將請求映射到匹配的方法上。

    俗話講就是@RequestMapping註解是用來辨別你請求的地址,並執行對應的方法。而且還可以對地址進行一系列的處理與約束。

  • return:跳轉到的頁面。