1. 程式人生 > >【spring MVC】新手從零新建第一個hello world專案

【spring MVC】新手從零新建第一個hello world專案

說明

本文適合一個沒有搭建過spring MVC專案的新手(甚至沒怎麼參與過java相關專案的新手)參閱!
這也是arvik參考網路文章學習spring MVC搭建的一個筆記

軟體安裝

安裝jdk

這裡寫圖片描述

開啟windows命令列視窗執行命令檢查jdk是否成功安裝,如下執行java -version,顯示如下結果

Microsoft Windows [版本 6.1.7601]
版權所有 (c) 2009 Microsoft Corporation。保留所有權利。

C:\Users\Administrator>java -version
java version "9.0.4"
Java(TM) SE Runtime Environment (build 9.0.4+11) Java HotSpot(TM) 64-Bit Server VM (build 9.0.4+11, mixed mode) C:\Users\Administrator>

安裝eclipse

這裡寫圖片描述

安裝tomcat

直接選擇最新版,地址https://tomcat.apache.org,目前9.0.4最新。按照截圖步驟下載安裝包(不要解壓包,安裝包在安裝過程中會自動配置環境變數)

這裡寫圖片描述

如果安裝過程需要配置jre地址,則填寫安裝jdk時附帶的jre安裝地址

安裝執行後,瀏覽器開啟localhost:8080

,看到tomcat預設首頁則成功
這裡寫圖片描述

提示

以上步驟通通不需要手動去設定環境變數,沒有其它地方介紹的一堆那麼複雜的環境變數配置。

安裝maven

這裡寫圖片描述

將maven解壓目錄末尾追加/bin加入path變數

最新的eclipse應該集成了maven,可能不是最新的maven,但是能用,也可更改為最新下載的maven,eclipse更改如下,window---->preference--->maven

  • installations選擇想要的maven版本

這裡寫圖片描述

  • 然後在user settings填上maven的配置檔案路徑
  • 開啟maven配置檔案settings.xml
    檔案,找到<localRepository>path/to/your/repository </localRepository>的地方,其中D:\app\maven\maven_repository更改為自己的maven倉庫位置(自己設定),也就是存放公共java包的地方。
<localRepository>D:\app\maven\maven_repository</localRepository>

新建專案

  • 開啟eclipse指定workspace地址後,file--->new--->maven
    project
    或者file--->new---other搜尋找到maven project

這裡寫圖片描述

這裡寫圖片描述

這裡寫圖片描述

  • 新建目錄com/main/java,自己的java包就可建立在這個裡面,在src/main/java下建立包com.test

這裡寫圖片描述

  • 配置tomcat

這裡寫圖片描述

com.test包下新建一個class,取名HelloWorldController
這裡寫圖片描述

這裡寫圖片描述

配置專案根目錄下pom.xml,如下(如下內容幾乎為最小配置)

<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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.arvik</groupId>
  <artifactId>helloworld</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <name>helloworld Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <properties>
    <spring.version>4.1.1.RELEASE</spring.version>
  </properties>

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

<!--     <dependency>
         <groupId>javax.servlet</groupId>
         <artifactId>javax.servlet-api</artifactId>
         <version>3.1.0</version>
     </dependency>    -->

         <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-core</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>${spring.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>${spring.version}</version>
    </dependency>

    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.1.0</version>
    </dependency>


  </dependencies>
  <build>
    <finalName>helloworld</finalName>
  </build>
</project>

配置web.xml,在src/main/webapp/WEB-INF/修改/新建 web.xml如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns="http://java.sun.com/xml/ns/javaee" xmlns:jsp="http://java.sun.com/xml/ns/javaee/jsp"
 xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
 version="2.5">
  <display-name>Archetype Created Web Application</display-name>

  <servlet>
      <servlet-name>dispatcher</servlet-name>
      <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
          <init-param>
             <param-name>contextConfigLocation</param-name>
          <param-value>classpath:springContext.xml</param-value>
      </init-param>
      <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
      <servlet-name>dispatcher</servlet-name>
      <url-pattern>/</url-pattern>
  </servlet-mapping>

  <context-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:springContext.xml</param-value>
  </context-param>

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

</web-app>

/src/main/java目錄下新建springContext.xml檔案

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

    <!-- 搜尋spring控制元件 -->
    <context:component-scan base-package="com.test"></context:component-scan>
    <!-- 檢視頁面配置 -->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix">
            <value>/WEB-INF/views/</value>
        </property>
        <property name="suffix">
            <value>.jsp</value>
        </property>
    </bean>
</beans>

效果

右鍵執行專案,helloworld--->run as--->run on server(初次執行可能彈出框需要選擇tomcat V9.0),即可看到,如圖內容
這裡寫圖片描述

顯示的helloworld就是預設/src/main/webapp/下的index.jsp展示的內容,index.jsp內容如下

<html>
<body>
<h2>Hello World!</h2>
</body>
</html>

更近一步顯示hello world

這次用spring MVC框架方法來返回顯示一個Hello World, Ideas worth spreading!字串

com.test包下的HelloWorldController.java輸入如下內容

package com.test;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;

@Controller
public class HelloWorldController {
    @RequestMapping(value = "/say") 
    @ResponseBody
    public String showhello() {

        String str = "Hello World, Ideas worth spreading! ";
        return str;
    }  
}

這裡寫圖片描述

專案基本搭建完成,基本例子也跑通!