1. 程式人生 > 程式設計 >Springboot-springmvc4.x

Springboot-springmvc4.x

SpringMVC學習:how2j.cn/k/springmvc…

SpringMVC4概述

M:資料模型,是包含資料的物件。

V:檢視頁面,包含JSP、Thymeleaf

C:控制器(SpringMVC的註解@Controller的類)

快速搭建SpringMVC專案

一、介紹

SpringMVC提供了一個DispatcherServlet來開發Web應用,在SpringMVC中實現了WebApplicationInitializer介面就相當於實現了web.xml配置。

二、示例

1.pom檔案
<project xmlns="http://maven.apache.org/POM/4.0.0"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<groupId>com.eleven</groupId>
	<artifactId>springmvc4</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>war</packaging>

	<!-- 定義變數 -->
	<properties>
		<java.version>1.7</java.version>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>

		<!-- WEB -->
		<jsp.version>2.2</jsp.version>
		<jstl.version>1.2</jstl.version>
		<servlet.version>3.1.0</servlet.version>
		<!-- Spring -->
		<spring-framework.version>4.1.5.RELEASE</spring-framework.version>
		<!-- Logging -->
		<Logback.version>1.0.13</Logback.version>
		<slf4j.version>1.7.5</slf4j.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>javax</groupId>
			<artifactId>javaee-web-api</artifactId>
			<version>7.0</version>
			<scope>provided</scope>
		</dependency>
		<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-webmvc</artifactId>
			<version>${spring-framework.version}</version>
		</dependency>
		<!-- 其它依賴 -->
		<!--配置servlet -->
		<dependency>
			<groupId>javax.servlet</groupId>
			<artifactId>javax.servlet-api</artifactId>
			<version>${servlet.version}</version>
			<scope>provided</scope>
		</dependency>
		<!--配置jsp jstl的支援 -->
		<dependency>
			<groupId>javax.servlet</groupId>
			<artifactId>jstl</artifactId>
			<version>${jstl.version}</version>
		</dependency>
		<dependency>
			<groupId>javax.servlet.jsp</groupId>
			<artifactId>jsp-api</artifactId>
			<version>${jsp.version}</version>
			<scope>provided</scope>
		</dependency>
		<!-- https://mvnrepository.com/artifact/org.springframework/spring-tx -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-tx</artifactId>
			<version>${spring-framework.version}</version>
		</dependency>
		<!-- 使用SLF4J和LogBack作為日誌 -->
		<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>${slf4j.version}</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/log4j/log4j -->
		<dependency>
			<groupId>log4j</groupId>
			<artifactId>log4j</artifactId>
			<version>1.2.16</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/org.slf4j/jcl-over-slf4j -->
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>jcl-over-slf4j</artifactId>
			<version>${slf4j.version}</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/ch.qos.logback/logback-classic -->
		<dependency>
			<groupId>ch.qos.logback</groupId>
			<artifactId>logback-classic</artifactId>
			<version>${Logback.version}</version>
		</dependency>
		<dependency>
			<groupId>ch.qos.logback</groupId>
			<artifactId>logback-core</artifactId>
			<version>${Logback.version}</version>
		</dependency>
		<dependency>
			<groupId>ch.qos.logback</groupId>
			<artifactId>logback-access</artifactId>
			<version>${Logback.version}</version>
		</dependency>
		<!-- 新增jackson依賴,獲得物件和json或xml之間的轉換 -->
		<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.dataformat/jackson-dataformat-xml -->
		<dependency>
			<groupId>com.fasterxml.jackson.dataformat</groupId>
			<artifactId>jackson-dataformat-xml</artifactId>
			<version>2.5.3</version>
		</dependency>
		<!-- 實際開發中,沒必要同時支援xml和json,只用json就可以 -->
		<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind -->
		<dependency>
			<groupId>com.fasterxml.jackson.core</groupId>
			<artifactId>jackson-databind</artifactId>
			<version>2.3.5</version>
		</dependency>


	</dependencies>
	<build>
		<plugins>
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<version>2.3.2</version>
				<configuration>
					<source>${java.version}</source>
					<target>${java.version}</target>
				</configuration>
			</plugin>
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-war-plugin</artifactId>
				<version>2.3</version>
				<configuration>
					<failOnMissingWebXml>false</failOnMissingWebXml>
				</configuration>
			</plugin>
		</plugins>
	</build>

</project>
複製程式碼
2.日誌檔案

在src/main/resources目錄下,新建logback.xml用來配置日誌

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="1 seconds">
	<contextListener class="ch.qos.logback.classic.jul.LevelChangePropagator">
		<resetJUL>true</resetJUL>
	</contextListener>
	
	<jmxConfigurator/>
	<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
		<encoder>
			<pattern>Logback: %d{HH:mm:ss.SSS} %logger{36} - %msg%n</pattern>
		</encoder>
	</appender>
    <!-- 配置級別為DEBUG,我們可以看到更詳細的錯誤資訊 -->
	<logger name="org.springframework.web" level="DEBUG"/>
	<root level="info">
		<appender-ref ref="console"/>
	</root>
</configuration>

複製程式碼
3.演示頁面

在src/main/resources下建立views目錄,並在此目錄下建立index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<pre
>
MVC </pre> </body> </html> 複製程式碼
4.SpringMVC配置

為什麼要放到/WEB-INF/classes/views/下面,因為在springboot中,將會使用Thymeleaf作為模板,因此不需要這樣配置。

package com.eleven.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.view.InternalResourceViewResolver;
import org.springframework.web.servlet.view.JstlView;

@Configuration
@EnableWebMvc
@ComponentScan("com.eleven.config")
public class MyMvcConfig {

	@Bean
	public InternalResourceViewResolver viewResolver() {
		InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
		viewResolver.setPrefix("/WEB-INF/classes/views/");
		viewResolver.setSuffix(".jsp");
		viewResolver.setViewClass(JstlView.class);
		return viewResolver;
	}

}

複製程式碼
5.Web配置
package com.eleven.config;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletRegistration.Dynamic;

import org.springframework.web.WebApplicationInitializer;
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
import org.springframework.web.servlet.DispatcherServlet;

public class WebInitializer implements WebApplicationInitializer {// 替代web.xml

	@Override
	public void onStartup(ServletContext servletContext) throws ServletException {
		AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
		ctx.register(MyMvcConfig.class);
		ctx.setServletContext(servletContext); // 新建WebApplicationContext,註冊配置類,並將其和當前servletContext關聯
		Dynamic servlet = servletContext.addServlet("dispatcher",new DispatcherServlet(ctx)); // 註冊SpringMVC的DispatcherServlet
		servlet.addMapping("/");
		servlet.setLoadOnStartup(1);
	}

}

複製程式碼
6.簡單控制器
package com.eleven.config;

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

@Controller // 宣告是一個控制器
public class HeloController {

	@RequestMapping("/index") // 利用該註解配置URL和方法之間的對映
	public String hello() {
		return "index"; // 說明我們的頁面放置的路徑為/WEB-INF/classes/views/index.jsp
	}

}

複製程式碼
7.執行

常用的註解

一、@Controller

表明這個類是SpringMVC裡的Controller,將其宣告一個Bean,然後DispatcherServlet會自動掃描,並將Web請求對映到註解了@RequestMapping方法上。

二、@RequestMapping

對映Web請求(訪問路徑和引數),利用該註解配置URL和方法之間的對映

三、@ResponseBody

將java物件轉為json格式的資料。

四、@PathVariable

接收請求路徑中佔位符的值

五、@RestController

組合了@Controller和@ResponseBody。

六、示例
1.新增jackson依賴,或得物件和json之間的轉換
<!-- 新增jackson依賴,獲得物件和json或xml之間的轉換 -->
		<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.dataformat/jackson-dataformat-xml -->
		<dependency>
			<groupId>com.fasterxml.jackson.dataformat</groupId>
			<artifactId>jackson-dataformat-xml</artifactId>
			<version>2.5.3</version>
		</dependency>
		<!-- 實際開發中,沒必要同時支援xml和json,只用json就可以 -->
		<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind -->
		<dependency>
			<groupId>com.fasterxml.jackson.core</groupId>
			<artifactId>jackson-databind</artifactId>
			<version>2.3.5</version>
		</dependency>
複製程式碼
2.Domain(物件)

用來演示獲取request物件引數和返回次物件到response

package com.eleven.domain;

public class DemoObj {
	private Long id;
	private String name;

    // jackson:物件和json做轉換時,一定需要空構造。
	public DemoObj() {
		super();
	}

	public DemoObj(Long id,String name) {
		super();
		this.id = id;
		this.name = name;
	}

	public Long getId() {
		return id;
	}

	public void setId(Long id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

}

複製程式碼
3.註解演示控制器
package com.eleven.controller;

import javax.servlet.http.HttpServletRequest;

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

import com.eleven.domain.DemoObj;

@Controller // 表示此類是一個控制器
@RequestMapping("/anno") // 訪問路徑是/anno
public class DemoAnnoController {

	/**
	 * @ResponseBody:將java物件轉為json格式的資料。
	 * @param request
	 * @return
	 */
	@RequestMapping(produces = "text/plain;charset=UTF-8") // 返回的是媒體型別和字符集,需要的返回值是json物件
	public @ResponseBody String index(HttpServletRequest request) {
		return "url:" + request.getRequestURI() + " can access";

	}

	/**
	 * @PathVariable:接收請求路徑中佔位符的值
	 * @param str
	 * @param request
	 * @return
	 */
	@RequestMapping(value = "/pathvar/{str}",produces = "text/plain;charset=UTF-8")
	public String demoPathVar(@PathVariable String str,HttpServletRequest request) {
		return "url:" + request.getRequestURI() + "can access,str" + str;
	}

	/**
	 * 表示request引數獲取,訪問路徑為/anno/requestParam?id=1
	 * 
	 * @param id
	 * @param request
	 * @return
	 */
	@RequestMapping(value = "/requestParam",produces = "text/plain;charset=UTF-8")
	public @ResponseBody String passRequestParam(Long id,id:" + id;
	}

	/**
	 * 引數到物件,訪問路徑為/anno/obj?id=1&name=xx
	 * 
	 * @param obj
	 * @param request
	 * @return
	 */
	@RequestMapping(value = "/obj",produces = "application/json;charset=UTF-8")
	@ResponseBody
	public String passObj(DemoObj obj,obj ud:" + obj.getId() + "obj name" + obj.getName();
	}
	
	/**
	 * 不同路徑到相同的方法,路徑為/anno/name1或/anno/name2
	 * @param request
	 * @return
	 */
	@RequestMapping(value= {"/name1","/name2"},produces="text/plain;charset=UTF-8")
	public @ResponseBody String remove(HttpServletRequest request) {
		return "url:"+request.getRequestURI()+"can access";
	}
	
}

複製程式碼