導依賴html
<dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>javax.servlet.jsp-api</artifactId> <version>2.3.1</version> <scope>provided</scope> </dependency> </dependencies>
寫springMvc配置文件前端
<?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 http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 開啓註解掃描 --> <context:component-scan base-package="cn.ann"/> <!-- 配置視圖解析器 --> <bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value=""/> <property name="suffix" value=".html"/> </bean> <!-- 開啓springMvc註解支持 --> <mvc:annotation-driven/> <!-- 靜態資源放行 --> <mvc:default-servlet-handler/> </beans>
web.xmljava
<?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"> <servlet> <!-- 配置springMvc --> <servlet-name>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springMvc.xml</param-value> </init-param> <!-- 配置加載時機 --> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
編寫Controller類git
@Controller public class HelloController { @RequestMapping("/hello") public String hello() { System.out.println("hello springMvc"); return "success"; } }
<mvc:annotation-driven/>
的做用: 配置這個標籤就至關於配置了處理器映射器(HandleMapping), 處理器適配器(HandleAdapter) 和 異常解析器(ExceptionResolver)亂碼問題: 添加過濾器便可程序員
<filter> <filter-name>characterEncodingFilter</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> </filter> <filter-mapping> <filter-name>characterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
編寫自定義的轉換器github
public class StringToDateConverter implements Converter<String, Date> { @Override public Date convert(String s) { try { if (Pattern.matches("^\\d{4}-\\d{1,2}-\\d{1,2}$", s)) { SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); return format.parse(s); } else if (Pattern.matches("^\\d{4}-\\d{1,2}-\\d{1,2} \\d{1,2}:\\d{1,2}:\\d{1,2}$", s)) { SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); return format.parse(s); } else if (Pattern.matches("^\\d{4}-\\d{1,2}-\\d{1,2}[T]\\d{1,2}:\\d{1,2}:\\d{1,2}$", s)) { s = s.replace('T', ' '); SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); return format.parse(s); } else { throw new RuntimeException("輸入格式不正確"); } } catch (ParseException e) { e.printStackTrace(); throw new RuntimeException(e); } } }
註冊到spring中web
<!-- 註冊自定義轉換器 --> <bean id="conversionServiceFactory" class="org.springframework.context.support.ConversionServiceFactoryBean"> <property name="converters"> <set> <bean class="cn.ann.utils.StringToDateConverter"/> </set> </property> </bean> <!-- 開啓springMvc註解支持 --> <mvc:annotation-driven conversion-service="conversionServiceFactory"/>
rest風格:ajax
什麼是rest: REST(英文:Representational State Transfer,簡稱REST)描述了一個架構樣式的網絡系統,好比 web 應用程序。它首次出如今 2000 年 Roy Fielding 的博士論文中,他是 HTTP 規範的主要編寫者之一。在目前主流的三種Web服務交互方案中,REST相比於SOAP(Simple Object Access protocol,簡單對象訪問協議)以及XML-RPC更加簡單明瞭,不管是對URL的處理仍是對Payload的編碼,REST都傾向於用更加簡單輕量的方法設計和實現。值得注意的是REST並無一個明確的標準,而更像是一種設計的風格。 它自己並無什麼實用性,其核心價值在於如何設計出符合REST風格的網絡接口。 restful的優勢 它結構清晰、符合標準、易於理解、擴展方便,因此正獲得愈來愈多網站的採用。 restful的特性: 資源(Resources):網絡上的一個實體,或者說是網絡上的一個具體信息。 它能夠是一段文本、一張圖片、一首歌曲、一種服務,總之就是一個具體的存在。能夠用一個URI(統一資源定位符)指向它,每種資源對應一個特定的 URI 。要 獲取這個資源,訪問它的URI就能夠,所以 URI 即爲每個資源的獨一無二的識別符。 表現層(Representation):把資源具體呈現出來的形式,叫作它的表現層 (Representation)。 好比,文本能夠用 txt 格式表現,也能夠用 HTML 格式、XML 格式、JSON 格式表現,甚至能夠採用二進制格式。 狀態轉化(State Transfer):每 發出一個請求,就表明了客戶端和服務器的一次交互過程。 HTTP協議,是一個無狀態協議,即全部的狀態都保存在服務器端。所以,若是客戶端想要操做服務器,必須經過某種手段,讓服務器端發生「狀態轉化」(State Transfer)。而這種轉化是創建在表現層之上的,因此就是 「表現層狀態轉化」。具體說,就是 HTTP 協議裏面,四個表示操做方式的動詞:GET、POST、PUT、DELETE。它們分別對應四種基本操做:GET 用來獲取資源,POST 用來新建資源,PUT 用來更新資源,DELETE 用來刪除資源。
<input type="hidden" name="_method" value="GET|POST|PUT|DELETE"/>
示例代碼spring
@RequestMapping("/testModelAttribute") public String testModelAttribute(@ModelAttribute("user01") User user) { System.out.println("testModelAttribute run..."); System.out.println(user); return "success"; } /** * 多用於填充對象的空數據, 能夠在使用對象以前將對象的全部信息從數據庫中查出來 */ @ModelAttribute public void model(User user, Map<String, User> map) { System.out.println("model run..."+user); // 能夠在這裏面寫從數據庫查詢的操做 user.setBirthday(new Date()); map.put("user01", user); }
@SessionAttributes(value = "user", types = User.class)
@RequestMapping("/testSessionAttributesPut") public String testSessionAttributesPut(Model model) { User user = new User(); user.setName("sessionZS"); user.setAge(23); user.setBirthday(new Date()); model.addAttribute(user); return "success"; } @RequestMapping("/testSessionAttributesGet") public String testSessionAttributesGet(ModelMap model) { System.out.println(model.get("user")); return "success"; } @RequestMapping("/testSessionAttributesClean") public String testSessionAttributesClean(SessionStatus status) { status.setComplete(); return "success"; }
本文代碼: 此處的 springMvc01數據庫