1. 程式人生 > 實用技巧 >spring系列---- spring-mvc1

spring系列---- spring-mvc1

環境:jdk,eclipse,tomcat,spring-mvc,commonlog

1.新建Dynamic Web Project專案。

2.匯入springmvc包與commonlog兩個包。

3.專案引入jsp-api,servlet-api兩個包,在tomcat下。

4.web.xml配置(SpringMVC1\WebContent\WEB-INF)

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1"> <!-- 定義servlet --> <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</
servlet-class> <init-param> <!--指定路徑--> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/springmvc-config.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </
servlet> <!-- 讓spring mvc的前端控制器攔截所有請求 --> <servlet-mapping> <servlet-name>springmvc</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>

5.springmvc-config.xml配置(SpringMVC1\WebContent\WEB-INF)

<?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-4.2.xsd">
       <!-- 配置handle,對映“/hello”請求 -->
       <bean name="/hello" class="org.fkit.controller.HelloController" />
        <!-- 處理對映器將bean的name作為地址進行查詢,需要在配置Handle指定地址 -->
       <bean
        class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping" />
          <!-- SimpleControllerHandlerAdapter處理器介面卡,所有處理介面卡都要實現 HandlerAdapter介面-->
       <bean
        class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter" />
       <!-- 檢視解析器-->
       <bean 
        class="org.springframework.web.servlet.view.InternalResourceViewResolver"/> 
</beans>

6.Controller層(SpringMVC1\src\org\fkit\controller)

package org.fkit.controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
public class HelloController implements Controller {
    public static final Log logger = LogFactory.getLog(HelloController.class);
    @Override
    public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
        ModelAndView mv = new ModelAndView();
        mv.addObject("message", "Hello World!");
        mv.setViewName("/WEB-INF/content/index.jsp");
        return mv;
    }
}

7.index.jsp(SpringMVC1\WebContent\WEB-INF\content)

<%@ 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>Insert title here</title>
</head>
<body>
    ${requestScope.message}
</body>
</html>

8.執行ok。

執行網址:http://localhost:8080/SpringMVC1/hello

9.問題總結

  @1.tomcat預設顏色為紅色 解決為其他顏色以方便識別錯誤

    原因:tomcat預設的日誌輸出按jdk中的System.err來輸出,而System.err在eclipse中,以紅色顯示。

    解決方案:Eclipse 中 System.err 的顯示顏色可以通過 Window --> Preference --> Run/Debug --> Console 的 Standard Error text color 進行更改。

  @2.tomcat一執行就警告[SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.e

    原因:eclipse配置錯誤

    解決方案:雙擊Servers裡的Tomcat v7.0 at localhost,在Server Options選項選中Publish module contexts to separate XML files。

@3.tomcat有一個還是紅色org.apache.catalina.startup.HostConfig deployDescriptor

    原因:linux或者部分unix系統提供隨機數裝置是/dev/random 和/dev/urandom ,兩個有區別,urandom安全性沒有random高,但random需要時間間隔生成隨機數。jdk預設呼叫random。

    解決方案:找到jdk1.x.x_xx/jre/lib/security/Java.security檔案,在檔案中找到securerandom.source這個設定項,將其改為:securerandom.source=file:/dev/./urandom

   @4.eclipse快捷鍵註釋 alt+/

@5.org.springframework.web.servlet.DispatcherServlet noHandlerFound

    原因:訪問路徑有問題