天天看點

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

SpringMVC架構01—使用IDEA搭建SpringMVC環境

1、Spring MVC 入門

1.1、Spring MVC 簡介

把Web應用程式分為三層,分别是:

  • 控制器(Controller):負責接收并處理請求,響應用戶端;
  • 模型(Model):模型資料,業務邏輯;
  • 視圖(View):呈現模型,與使用者進行互動;
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

目前最好的實作MVC設計模式的架構,是Spring架構的一個子子產品,可以與Spring很好的結合使用,無需整合。

1.2、SpringMVC核心元件

  • DispatcherServlet:前置控制器
  • Handler:處理器,完成具體業務邏輯
  • HandlerMapping:将請求映射到Handler
  • HandlerInterceptor:處理器攔截器
  • HandlerExecutionChain:處理器執行鍊
  • HandlerAdapter:處理器擴充卡
  • ModelAndView:裝載模型資料和視圖資訊
  • ViewResolver:視圖解析器

 1.3、SpringMVC工作流程

(1)用戶端請求送出到DispatcherServlet;

(2)由DispatcherServlet控制器尋找一個或多個HandlerMapping,找到處理請求的Controller;

(3)DispatcherServlet将請求送出到Controller;

(4)Controller調用業務邏輯處理後傳回ModelAndView;

(5)DispatcherServlet尋找一個或多個ViewResolver視圖解析器,找到ModelAndView指定的視圖;

(6)視圖負責将結果顯示到用戶端;

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

2、SpringMVC的實作

2.1、建立SpringMVC項目

實作步驟:

打開IDEA工具,建立新項目,選擇Maven工程,使用jdk1.8版本,勾選“Create from archetype”,選擇maven-archetype-webapp的方式建立,點選Next

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

 配置項目資訊,點選Next

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

配置Maven資訊,點選Next

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

 配置工作空間,點選Finish

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

在控制台顯示BUILD SUCCESS,項目建立完成

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

預設建立的項目目錄,resource存放配置檔案,webapp目錄存放web頁面群組件

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

在main目錄上右鍵,選擇New-->Directory建立java目錄

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

在java目錄上點選右鍵,選擇Mark Directory as-->Sources Root,将java目錄設定為資源目錄

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

在pom.xml中引入依賴

<dependencies>
  <!--junit測試依賴-->
  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.11</version>
    <scope>test</scope>
  </dependency>
  <!--SpringMVC依賴-->
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-webmvc</artifactId>
    <version>4.3.1.RELEASE</version>
  </dependency>
</dependencies>      

打開src-->main-->webapp-->WEB-INF-->web.xml,配置SpringMVC的Servlet:

<servlet>
  <servlet-name>SpringMVC</servlet-name>
  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  <!--配置springmvc.xml的路徑-->
  <init-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:springmvc.xml</param-value>
  </init-param>
</servlet>
<servlet-mapping>
  <servlet-name>SpringMVC</servlet-name>
  <url-pattern>/</url-pattern>
</servlet-mapping>      

2.2、基于XML配置SpringMVC

在src-->main-->resources目錄上點選右鍵,選擇New-->XML Configuration File-->Spring Config,建立springmvc.xml配置檔案

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

在java目錄上建立MyHandler類,實作Controller接口,并重寫handelRequest()方法

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

如果出現HttpServletRequest報紅,原因是沒有引入依賴

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

選擇File-->Project Structure

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

參考圖檔依次選擇Modules,點選右邊+号,選擇Library

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

添加Tomcat,點選Add Selected

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

編輯模型視圖代碼:

import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;

public class MyHandler implements Controller {
    public ModelAndView handleRequest(httpServletRequest, httpServletResponse) throws Exception {
        //裝載模型資料和邏輯視圖
        ModelAndView modelAndView = new ModelAndView();
        //添加模型資料
        modelAndView.addObject("name","Tom");
        //添加邏輯視圖
        modelAndView.setViewName("show");
        return modelAndView;
    }
}      

在webapp目錄下建立show.jsp,使用EL表達式輸出name

如果使用EL表達式,必須配置isELIgnored="false"

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

在springmvc.xml檔案中配置Controller和HandlerMapping元件映射

<!--配置HandlerMapping,将URL映射到Handler-->
<bean id="handlerMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
    <!--配置mapping-->
    <property name="mappings">
        <props>
            <!--配置test請求對應的handler-->
            <prop key="/test">testHandler</prop>
        </props>
    </property>
</bean>
<!--配置handler-->
<bean id="testHandler" class="com.springtest.MyHandler"></bean>
<!--配置視圖解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <!--配置字首-->
    <property name="prefix" value="/"></property>
    <!--配置字尾-->
    <property name="suffix" value=".jsp"></property>
</bean>      

配置Tomcat

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

完成以上步驟操作後,點選OK,在控制台處點選運作

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

在浏覽器中通路 localhost:8080/test,頁面就會顯示ModelAndView傳回的值

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

2.3、基于注解配置SpringMVC

 使用注解配置SpringMVC,隻需要修改springmvc.xml檔案:

<!--将AnnotationHandler自動掃描到IOC容器中-->
<context:component-scan base-package="com.springdemo.controller"></context:component-scan>

<!--配置視圖解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <!--配置字首-->
    <property name="prefix" value="/"></property>
    <!--配置字尾-->
    <property name="suffix" value=".jsp"></property>
</bean>      

建立AnnotationHandler類,使用注解實作:

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

@Controller
public class AnnotationHandler {

    /**
     * 業務方法
     * 使用ModelAndView完成資料傳遞、視圖解析
     */
    @RequestMapping("/modelAndViewTest")
    public ModelAndView modelAndViewTest(){
        ModelAndView modelAndView = new ModelAndView();
        modelAndView.addObject("name","Jack");
        modelAndView.setViewName("show");
        return modelAndView;
    }

}      

啟動Tomcat

SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

業務方法還可以使用以下兩種方式實作:

(1)使用Model傳值,String解析視圖

/**
 * 業務方法
 * 使用Model傳值,String進行視圖解析
 */
@RequestMapping("/modelTest")
public String modelTest(Model model){
    model.addAttribute("name","Lucy");
    return "show" ;
}      
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

(2)使用Map傳值,String解析視圖

/**
 * 業務方法
 * 使用Map傳值,String解析視圖
 */
@RequestMapping("/mapTest")
public String mapTest(Map<String,String> map){
    map.put("name","Lilei");
    return "show";
}      
SpringMVC架構01—使用IDEA搭建SpringMVC環境1、Spring MVC 入門2、SpringMVC的實作

2.4、解決用戶端請求亂碼問題

在web.xml中配置filter

<!--進行中文亂碼-->
  <filter>
    <filter-name>encodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
      <param-name>forceEncoding</param-name>
      <param-value>true</param-value>
    </init-param>
  </filter>
  <filter-mapping>
    <filter-name>encodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>      

2.5、配置靜态資源通路

在web.xml中配置:

<!--設定通路靜态資源-->
<servlet-mapping>
  <servlet-name>default</servlet-name>
  <url-pattern>*.css</url-pattern>
</servlet-mapping>
<servlet-mapping>
  <servlet-name>default</servlet-name>
  <url-pattern>*.js</url-pattern>
</servlet-mapping>
<servlet-mapping>
  <servlet-name>default</servlet-name>
  <url-pattern>*.jpg</url-pattern>
</servlet-mapping>      

 原文位址

https://www.cnblogs.com/jpwz/p/10538635.html