Springboot-springmvc4.x

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

SpringMVC4概述

M:數據模型,是包含數據的對象。java

V:視圖頁面,包含JSP、Thymeleafweb

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

快速搭建SpringMVC項目

1、介紹

SpringMVC提供了一個DispatcherServlet來開發Web應用,在SpringMVC中實現了WebApplicationInitializer接口就至關於實現了web.xml配置。apache

2、示例

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用來配置日誌json

<?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.jspapi

<%@ 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做爲模板,所以不須要這樣配置。springboot

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.運行

經常使用的註解

1、@Controller

代表這個類是SpringMVC裏的Controller,將其聲明一個Bean,而後DispatcherServlet會自動掃描,並將Web請求映射到註解了@RequestMapping方法上。mvc

2、@RequestMapping

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

3、@ResponseBody

將java對象轉爲json格式的數據。

4、@PathVariable

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

5、@RestController

組合了@Controller和@ResponseBody。

6、示例
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, HttpServletRequest request) {
		return "url:" + request.getRequestURI() + "can access,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, HttpServletRequest request) {
		return "url:" + request.getRequestURI() + "can access,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";
	}
	
}

複製代碼
相關文章
相關標籤/搜索