1. 程式人生 > >IDEA+Maven+Spring MVC HelloWorld示例

IDEA+Maven+Spring MVC HelloWorld示例

-type rop 相同 bin urn public mapping web.xml www

用Maven創建Web項目

選擇webapp模板
技術分享圖片
技術分享圖片

創建成功後點Enable Auto-Import
技術分享圖片

idea給我們創建出來的結構是這樣的,這還不標準,需要自己修改。
技術分享圖片

在main文件夾下創建java文件夾,這是放置源碼的地方,標記為sources。創建resources文件夾且標記為resource。
技術分享圖片

初始結構如下。
技術分享圖片

配置Spring

pom.xml的配置

在<dependecies>與</dependecies>之間插入以下代碼,添加依賴包。

 <dependency>
  <groupId>junit</groupId>
  <artifactId>junit</artifactId>
  <version>3.8.1</version>
  <scope>test</scope>
</dependency>

<!-- Servlet Library -->
<!-- http://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
<dependency>
  <groupId>javax.servlet</groupId>
  <artifactId>javax.servlet-api</artifactId>
  <version>3.1.0</version>
  <scope>provided</scope>
</dependency>

<!-- Spring dependencies -->
<!-- http://mvnrepository.com/artifact/org.springframework/spring-core -->
<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-core</artifactId>
  <version>4.1.4.RELEASE</version>
</dependency>

<!-- http://mvnrepository.com/artifact/org.springframework/spring-web -->
<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-web</artifactId>
  <version>4.1.4.RELEASE</version>
</dependency>

<!-- http://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-webmvc</artifactId>
  <version>4.1.4.RELEASE</version>
</dependency>

配置web.xml

<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xmlns="http://java.sun.com/xml/ns/javaee"
     xsi:schemaLocation="http://java.sun.com/xml/ns/javaeehttp://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
     id="WebApp_ID" version="3.0">
<display-name>HelloWorldSpring</display-name>

  <servlet>
    <servlet-name>spring-mvc</servlet-name>
    <servlet-class>
      org.springframework.web.servlet.DispatcherServlet
    </servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>spring-mvc</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

  <!-- Other XML Configuration -->
  <!-- Load by Spring ContextLoaderListener -->
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>/WEB-INF/root-context.xml</param-value>
  </context-param>

  <!-- Spring ContextLoaderListener -->
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>

</web-app>

Spring MVC的 DispatcherServlet 將根據默認原則讀取XML配置文件: 在/WEB-INF文件夾下搜尋{servlet-name}-servlet.xml,在這裏則是 spring-mvc-servlet.xml

接下來,標記指示哪些URL將由DispatcherServlet處理。 這裏所有為/的HTTP請求都將由spring-mvc DispatcherServlet處理。

在Spring應用程序 ContextLoaderListener 將讀取其他 XML 配置文件(如下的 abc.xml 和 root-context.xml 兩個文件)。 可能不需要配置 ContextLoaderListener,如果你的應用程序並不需要讀取其他XML配置文件。

<!-- web.xml -->
<!-- Spring ContextLoaderListener -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
 
<!-- Load by Spring ContextLoaderListener -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
       /WEB-INF/root-context.xml,
       /WEB-INF/abc.xml
 </param-value>
</context-param>

下面添加了一個root-context.xml配置文件,僅僅是為了用於學習這功能。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
   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">

<!-- Empty -->

</beans>

配置spring-mvc-servlet.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xmlns:p="http://www.springframework.org/schema/p"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:mvc="http://www.springframework.org/schema/mvc"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
  http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
  http://www.springframework.org/schema/context
  http://www.springframework.org/schema/context/spring-context-4.1.xsd
  http://www.springframework.org/schema/mvc
  http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd">

<context:component-scan base-package="com.fang.controller"/>

<context:annotation-config/>

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix">
        <value>/WEB-INF/jsp/</value>
    </property>

    <property name="suffix">
        <value>.jsp</value>
    </property>
</bean>

</beans>

[servlet-name]-servlet.xml文件將用於創建定義的bean,它會覆蓋在全局範圍中使用相同名稱定義的任何bean的定義。

<context:component-scan ...>標簽將用於激活Spring MVC註釋掃描功能,允許使用@Controller和@RequestMapping等註釋。

InternalResourceViewResolver將定義用於解析視圖名稱的規則。根據上面定義的規則,hello的邏輯視圖將委托給位於/WEB-INF/jsp/hello.jsp這個視圖來實現。

創建控制器Controller

在java文件夾下創建包com.fang.controller,用於放置controller。
創建HelloWorldController類

package com.fang.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class HelloWorldController {
    @RequestMapping("/hello")
    public String hello(Model model){
        model.addAttribute("greeting","Hello Spring MVC");
        return "helloworld";
    }
}

value屬性指示處理程序方法映射到的URL。

定義的服務方法可以返回一個String,它包含要用於渲染模型的視圖的名稱。此示例將“helloworld”返回為邏輯視圖名稱。

創建jsp視圖

在WEB-INF文件夾下創建jsp文件夾,然後創建helloworld.jsp。

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

這裏${greeting}是在Controller中設置的屬性。可以在視圖中顯示多個屬性。

部署tomcat server服務

點擊工具欄的run->edit configurations
技術分享圖片

點擊+號,選擇tomcat-local
技術分享圖片

部署tomcat,選擇war結尾的那個
技術分享圖片
技術分享圖片
技術分享圖片

完成後左下角會出現這個
技術分享圖片

點擊綠色小箭頭就運行了
技術分享圖片

運行結果

技術分享圖片

技術分享圖片

DispatcherServlet攔截解析請求,發現是/hello,轉到HelloWorldController下的hello方法中->helloworld 將請求轉發到/WEB-INF/jsp/helloworld.jsp界面

項目最終結構圖

技術分享圖片

應用程序的流程

現在來看看程序的運行流程吧!這很重要!
技術分享圖片

參考

Spring4 MVC HelloWord實例

Spring MVC概述

IDEA+Maven+Spring MVC HelloWorld示例