1. 程式人生 > 實用技巧 >json 的定義和語法

json 的定義和語法

Hello,SpringMVC

配置版

1、新建一個Moudle , springmvc-02-hello , 新增web的支援!

2、確定匯入了SpringMVC 的依賴!

3、配置web.xml , 註冊DispatcherServlet

<?xml version="1.0" encoding="UTF-8"?>

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"

        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

        xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"

        version="4.0">

   <!--1.註冊DispatcherServlet-->

   <servlet>

       <servlet-name>springmvc</servlet-name>

       <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

       <!--關聯一個springmvc的配置檔案:【servlet-name】-servlet.xml-->

       <init-param>

           <param-name>contextConfigLocation</param-name>

           <param-value>classpath:springmvc-servlet.xml</param-value>

       </init-param>

       <!--啟動級別-1-->

       <load-on-startup>1</load-on-startup>

   </servlet>

   <!--/ 匹配所有的請求;(不包括.jsp)-->

   <!--/* 匹配所有的請求;(包括.jsp)-->

   <servlet-mapping>

       <servlet-name>springmvc</servlet-name>

       <url-pattern>/</url-pattern>

   </servlet-mapping>

</web-app>

4、編寫SpringMVC 的 配置檔案!名稱:springmvc-servlet.xml : [servletname]-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"

      xsi:schemaLocation="http://www.springframework.org/schema/beans

       http://www.springframework.org/schema/beans/spring-beans.xsd">

</beans>

5、新增 處理對映器

<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>

6、新增 處理器介面卡

<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>

7、新增 檢視解析器

<!--檢視解析器:DispatcherServlet給他的ModelAndView-->

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="InternalResourceViewResolver">

   <!--字首-->

   <property name="prefix" value="/WEB-INF/jsp/"/>

   <!--字尾-->

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

</bean>

8、編寫我們要操作業務Controller ,要麼實現Controller介面,要麼增加註解;需要返回一個ModelAndView,裝資料,封檢視;

package com.kuang.controller;

import org.springframework.web.servlet.ModelAndView;

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

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

//注意:這裡我們先匯入Controller介面

public class HelloController implements Controller {

   public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {

       //ModelAndView 模型和檢視

       ModelAndView mv = new ModelAndView();

       //封裝物件,放在ModelAndView中。Model

       mv.addObject("msg","HelloSpringMVC!");

       //封裝要跳轉的檢視,放在ModelAndView中

       mv.setViewName("hello"); //: /WEB-INF/jsp/hello.jsp

       return mv;

  }

}

9、將自己的類交給SpringIOC容器,註冊bean

<!--Handler-->

<bean id="/hello" class="com.kuang.controller.HelloController"/>

10、寫要跳轉的jsp頁面,顯示ModelandView存放的資料,以及我們的正常頁面;

<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<html>

<head>

   <title>Kuangshen</title>

</head>

<body>

${msg}

</body>

</html>

11、配置Tomcat 啟動測試!

可能遇到的問題:訪問出現404,排查步驟:

  1. 檢視控制檯輸出,看一下是不是缺少了什麼jar包。
  2. 如果jar包存在,顯示無法輸出,就在IDEA的專案釋出中,新增lib依賴!
  3. 重啟Tomcat 即可解決!

註解版

1、新建一個Moudle,springmvc-03-hello-annotation 。新增web支援!

2、由於Maven可能存在資源過濾的問題,我們將配置完善

<build>

   <resources>

       <resource>

           <directory>src/main/java</directory>

           <includes>

               <include>**/*.properties</include>

               <include>**/*.xml</include>

           </includes>

           <filtering>false</filtering>

       </resource>

       <resource>

           <directory>src/main/resources</directory>

           <includes>

               <include>**/*.properties</include>

               <include>**/*.xml</include>

           </includes>

           <filtering>false</filtering>

       </resource>

   </resources>

</build>

3、在pom.xml檔案引入相關的依賴:主要有Spring框架核心庫、Spring MVC、servlet , JSTL等。我們在父依賴中已經引入了!

4、配置web.xml

注意點:

<?xml version="1.0" encoding="UTF-8"?>

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"

        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

        xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"

        version="4.0">

   <!--1.註冊servlet-->

   <servlet>

       <servlet-name>SpringMVC</servlet-name>

       <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

       <!--通過初始化引數指定SpringMVC配置檔案的位置,進行關聯-->

       <init-param>

           <param-name>contextConfigLocation</param-name>

           <param-value>classpath:springmvc-servlet.xml</param-value>

       </init-param>

       <!-- 啟動順序,數字越小,啟動越早 -->

       <load-on-startup>1</load-on-startup>

   </servlet>

   <!--所有請求都會被springmvc攔截 -->

   <servlet-mapping>

       <servlet-name>SpringMVC</servlet-name>

       <url-pattern>/</url-pattern>

   </servlet-mapping>

</web-app>

/ 和 /* 的區別:< url-pattern > / </ url-pattern > 不會匹配到.jsp, 只針對我們編寫的請求;即:.jsp 不會進入spring的 DispatcherServlet類 。< url-pattern > /* </ url-pattern > 會匹配 *.jsp,會出現返回 jsp檢視 時再次進入spring的DispatcherServlet 類,導致找不到對應的controller所以報404錯。

  • 注意web.xml版本問題,要最新版!
  • 註冊DispatcherServlet
  • 關聯SpringMVC的配置檔案
  • 啟動級別為1
  • 對映路徑為 / 【不要用/*,會404】

5、新增Spring MVC配置檔案

在resource目錄下新增springmvc-servlet.xml配置檔案,配置的形式與Spring容器配置基本類似,為了支援基於註解的IOC,設定了自動掃描包的功能,具體配置資訊如下:

<?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: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.xsd

       http://www.springframework.org/schema/context

       https://www.springframework.org/schema/context/spring-context.xsd

       http://www.springframework.org/schema/mvc

       https://www.springframework.org/schema/mvc/spring-mvc.xsd">

   <!-- 自動掃描包,讓指定包下的註解生效,由IOC容器統一管理 -->

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

   <!-- 讓Spring MVC不處理靜態資源 -->

   <mvc:default-servlet-handler />

   <!--

   支援mvc註解驅動

       在spring中一般採用@RequestMapping註解來完成對映關係

       要想使@RequestMapping註解生效

       必須向上下文中註冊DefaultAnnotationHandlerMapping

       和一個AnnotationMethodHandlerAdapter例項

       這兩個例項分別在類級別和方法級別處理。

       而annotation-driven配置幫助我們自動完成上述兩個例項的注入。

    -->

   <mvc:annotation-driven />

   <!-- 檢視解析器 -->

   <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"

         id="internalResourceViewResolver">

       <!-- 字首 -->

       <property name="prefix" value="/WEB-INF/jsp/" />

       <!-- 字尾 -->

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

   </bean>

</beans>

在檢視解析器中我們把所有的檢視都存放在/WEB-INF/目錄下,這樣可以保證檢視安全,因為這個目錄下的檔案,客戶端不能直接訪問。

  • 讓IOC的註解生效
  • 靜態資源過濾 :HTML . JS . CSS . 圖片 , 視訊 .....
  • MVC的註解驅動
  • 配置檢視解析器

6、建立Controller

編寫一個Java控制類:com.kuang.controller.HelloController , 注意編碼規範

package com.kuang.controller;

import org.springframework.stereotype.Controller;

import org.springframework.ui.Model;

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

@Controller

@RequestMapping("/HelloController")

public class HelloController {

   //真實訪問地址 : 專案名/HelloController/hello

   @RequestMapping("/hello")

   public String sayHello(Model model){

       //向模型中新增屬性msg與值,可以在JSP頁面中取出並渲染

       model.addAttribute("msg","hello,SpringMVC");

       //web-inf/jsp/hello.jsp

       return "hello";

  }

}
  • @Controller是為了讓Spring IOC容器初始化時自動掃描到;
  • @RequestMapping是為了對映請求路徑,這裡因為類與方法上都有對映所以訪問時應該是/HelloController/hello;
  • 方法中宣告Model型別的引數是為了把Action中的資料帶到檢視中;
  • 方法返回的結果是檢視的名稱hello,加上配置檔案中的前後綴變成WEB-INF/jsp/hello.jsp。

7、建立檢視層

在WEB-INF/ jsp目錄中建立hello.jsp , 檢視可以直接取出並展示從Controller帶回的資訊;

可以通過EL表示取出Model中存放的值,或者物件;

<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<html>

<head>

   <title>SpringMVC</title>

</head>

<body>

${msg}

</body>

</html>

8、配置Tomcat執行

配置Tomcat , 開啟伺服器 , 訪問 對應的請求路徑!

OK,執行成功!

小結

實現步驟其實非常的簡單:

  1. 新建一個web專案
  2. 匯入相關jar包
  3. 編寫web.xml , 註冊DispatcherServlet
  4. 編寫springmvc配置檔案
  5. 接下來就是去建立對應的控制類 , controller
  6. 最後完善前端檢視和controller之間的對應
  7. 測試執行除錯.

使用springMVC必須配置的三大件:

處理器對映器、處理器介面卡、檢視解析器

通常,我們只需要手動配置檢視解析器,而處理器對映器處理器介面卡只需要開啟註解驅動即可,而省去了大段的xml配置

再來回顧下原理吧~