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
原因:訪問路徑有問題