需求:客戶端發(fā)起請求,服務器端接收請求,執(zhí)行邏輯并進行視圖跳轉(zhuǎn)。
開發(fā)步驟:
①導入SpringMVC相關坐標
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.5.RELEASE</version>
</dependency>
②配置SpringMVC核心控制器DispathcerServlet
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param> =>服務器加載配置掃描
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.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>
③創(chuàng)建Controller類和視圖頁面
@Controller
@RequestMapping("/user") =>可以和方法的value拼接,可以表示模塊例如user表示用戶模塊
public class UserController {
@RequestMapping(value="/quick",method = RequestMethod.GET,params = {"accountName"}) =>http:/\/localhost:8081/spring_ioc_mvc/user/quick?accountName
public String save(){
System.out.println("spring-mvc....");
return "success"; =>"forward:/success.jsp【轉(zhuǎn)發(fā)】|redirect:/success.jsp【重定向】要配置視圖解析器才可以這樣寫
}
}
④使用注解配置Controller類中業(yè)務方法的映射地址配置SpringMVC核心文件spring-mvc.xml
<context:component-scan base-package="com.xjbt.spring_MVC.controller"/>
<context:component-scan base-package="com.xjbt.spring_MVC">
=>只掃描當前包下的@Corntroller注解
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
=>只掃描當前包下的除了....注解之外的所有注解
<context:exclude-filter type="annotation" expression="...."/>
</context:component-scan>
配置內(nèi)部資源視圖解析器
=>InternalResourceViewResolver的父類有Getprefix和GetSuffix 重寫這個方法 后臺控制器controller轉(zhuǎn)發(fā)地址拼接
<bean id="viewResolver" class=" org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"></property>
<property name="suffix" value=".jsp"></property>
=>前綴是/,后綴是.jsp,controller轉(zhuǎn)發(fā)地址直接寫success就自動拼接為/success.jsp
</bean>
⑤客戶端發(fā)起請求測試

SpringMVC內(nèi)部組件解析
用戶發(fā)送請求至前端控制器DispatcherServlet。
DispatcherServlet收到請求調(diào)用HandlerMapping處理器映射器。
處理器映射器找到具體的處理器(可以根據(jù)xml配置、注解進行查找),生成處理器對象及處理器攔截器(如果
有則生成)一并返回給DispatcherServlet。
DispatcherServlet調(diào)用HandlerAdapter處理器適配器。
HandlerAdapter經(jīng)過適配調(diào)用具體的處理器(Controller,也叫后端控制器)。Controller執(zhí)行完成返回ModelAndView。
HandlerAdapter將controller執(zhí)行結果ModelAndView返回給DispatcherServlet。
DispatcherServlet將ModelAndView傳給ViewReslover視圖解析器。
ViewReslover解析后返回具體View。
DispatcherServlet根據(jù)View進行渲染視圖((即將模型數(shù)據(jù)填充至視圖中)。DispatcherServlet響應用戶。

SpringMVC數(shù)據(jù)響應
-
頁面跳轉(zhuǎn)
-
返回字符串形式:此種方式會將返回的字符串與視圖解析器的前后綴拼接后跳轉(zhuǎn)。
@Controller @RequestMapping("/user") public class UserController { @RequestMapping("quick") public String save(){ return "/success.jsp"; =>返回字符串表明轉(zhuǎn)發(fā)或重定向【servlet攜帶302和地址給瀏覽器最后重定向是http:/ /ip:端口+/user/quick】地址。 } } -
返回ModelAndView對象
@RequestMapping("/quick2") public ModelAndView save2(){ ModelAndView modelAndView=new ModelAndView(); =》設置模型(model)數(shù)據(jù) modelAndView.addObject("name","zhangsan"); =》設置頁面(view)名稱 轉(zhuǎn)發(fā)的地址 modelAndView.setViewName("success"); return modelAndView; } @RequestMapping("/quick3") public ModelAndView save3(ModelAndView modelAndView){ =>會自動創(chuàng)建對象 modelAndView.addObject("name","zhangsan"); modelAndView.setViewName("success"); return modelAndView; } @RequestMapping("/quick4") public String save4(Model model){ =。拆解Model和View model.addAttribute("name","lisi"); return "success"; }
-
-
不跳轉(zhuǎn)直接返回字符串
-
將需要回寫的字符串直接返回,但此時需要通過
@ResponseBody注解告知SpringMVC框架,方法返回的字符串不是跳轉(zhuǎn)是直接在http響應體中返回。@RequestMapping("/quick5") @ResponseBody //告知框架不進行視圖跳轉(zhuǎn) public String save5(){ return "success"; } @RequestMapping("/quick6") @ResponseBody public String save6(HttpServletRequest req) throws Exception { ServletContext servletContext = req.getServletContext(); WebApplicationContext app = WebApplicationContextUtils.getWebApplicationContext(servletContext); user.setName("zhangsan"); user.setAge(20); ObjectMapper jackson=app.getBean(ObjectMapper.class); String json = jackson.writeValueAsString(user); return json; } -
返回對象或集合
在SpringMVC的各個組件中,處理器映射器、處理器適配器、視圖解析器稱為SpringMVC的三大組件。使用<mvcannotation-driven>自動加載RequestMappingHandlerMapping (處理映射器)和RequestMappingHandlerAdapter(處理適配器)并且默認底層就會集成jackson進行對象或集合的json格式字符串的轉(zhuǎn)換.=>配置處理器適配 可返回對象或集合【不推薦】 <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"> <property name="messageConverters"> <list> <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter" /> </list> </property> </bean> =>mvc注解驅(qū)動 <mvc:annotation-driven>@RequestMapping("/quick7") @ResponseBody public User save6() throws Exception { user.setName("zhangsan"); user.setAge(10); user.setAddr("新疆"); return user; }
-
SpringMVC獲得請求數(shù)據(jù)
- 客戶端請求參數(shù)的格式是: name=value&name=value... ...
- 服務器端要獲得請求的參數(shù),有時還需要進行數(shù)據(jù)的封裝,
-
基本類型參數(shù)
Controller中的業(yè)務方法的參數(shù)名稱要與請求參數(shù)的name一致,參數(shù)值會自動映射匹配。@RequestMapping("/quick8") @ResponseBody public void save8(String username,int age) throws Exception { System.out.println(username); System.out.println(age); } -
POJO類型【Bean對象】
Controller中的業(yè)務方法的POJO參數(shù)的屬性名與請求參數(shù)的name一致,參數(shù)值會自動映射匹配。@RequestMapping("/quick9") @ResponseBody public void save8(User user) throws Exception { System.out.println(user); } -
參數(shù)數(shù)組類型參數(shù)
Controller中的業(yè)務方法數(shù)組名稱與請求參數(shù)的name一致,參數(shù)值會自動映射匹配。
請求鏈接:http://localhost:8081/spring_ioc_mvc/user/quick10?strs=aaa&strs=bbb&strs=ccc@RequestMapping("/quick10") @ResponseBody public void save10(String[] strs) throws Exception { System.out.println(Arrays.asList(strs)); => 數(shù)組打印出來是一個地址,轉(zhuǎn)成list可看里面內(nèi)容 } -
集合類型參數(shù)
獲得集合參數(shù)時,要將集合參數(shù)包裝到一個POJO中才可以。
請求表單:<form action="${pageContext.request.contextPath}/user/quick11"> <input type="text" name="user_list[0].name"> <input type="text" name="user_list[0].age"> <input type="text" name="user_list[0].addr"> <input type="text" name="user_list[1].name"> <input type="text" name="user_list[1].age"> <input type="text" name="user_list[1].addr"> <input type="submit" value="提交"> </form>Vo集合類:
public class Vo { private List<User> user_list; getANDset....... }@RequestMapping("/quick11") @ResponseBody public void save10(Vo vo) throws Exception { System.out.println(vo); }獲得集合參:@RequestBody注解:
當使用ajax提交時,可以指定contentType為json形式,那么在方法參數(shù)位置使用@RequestBody可以直接接收集合數(shù)據(jù)而無需使用POJO進行包裝。
先配置開放訪問靜態(tài)資源:<mvc:resources mapping="/js/**" location="/js/" /> =>開啟靜態(tài)資源訪問 <mvc:default-servlet-handler /> =>找不到資源交由原始的容器【tomCat】去尋找資源【推薦】 </beans>ajax請求:
<script src="${pageContext.request.contextPath}/js/jquery-3.3.1.js"></script> <script> let userList=[]; userList.push({name:"zhangsan",age:12,addr:"xinjiang"}); userList.push({name:"lis",age:15,addr:"bejing"}); $.ajax({ type:"POST", url:"${pageContext.request.contextPath}/user/quick12", data:JSON.stringify(userList), contentType:"application/json;charset=utf-8" }) </script>@RequestMapping("/quick12") @ResponseBody public void save10(@RequestBody List<User> userList) throws Exception { System.out.println(userList); }
-
配置全局編碼:【解決請求過來的漢語數(shù)據(jù)亂碼】
<!--配置全局過濾的filter-->
<!--配置全局編碼-->
<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>
參數(shù)綁定注解@requestParam
當請求的參數(shù)名稱與Controller的業(yè)務方法參數(shù)名稱不一致時,就需要通過@RequestParam注解顯示的綁定。
@RequestMapping("/quick13")
@ResponseBody
public void save13(@RequestParam(value = "username",required = true,defaultValue = "admin")String name) throws Exception {
System.out.println(name);
}
獲得Restful風格的參數(shù)
定義:Restful是一種軟件架構風格、設計風格,而不是標準,只是提供了一組設計原則和約束條件。
作用:主要用于客戶端和服務器交互類的軟件,基于這個風格設計的軟件可以更簡潔,更有層次,更易于實現(xiàn)緩存機制等。
格式:、“url+請求方式”表示一次請求目的,HTTP協(xié)議里面四個表示操作方式的動詞如下:
GET:用于獲取資源
POST:用于新建資源
PUT:用于更新資源
DELETE:用于刪除資源
例如:
/user/1 GET :得到id =1的user
/user/1 DELETE:刪除id = 1的user
/user/1 PUT:更新 id = 1的user
/user POST:新增user
上述url地址/user/1中的1就是要獲得的請求參數(shù),在SpringMNC中可以使用占位符進行參數(shù)綁定。地址/user/1可以寫成/user/{id},占位符{id}對應的就是1的值。在業(yè)務方法中我們可以使用@PathVariable注解進行占位符的匹配獲取工作。
獲取地址:http://localhost:8081/spring_ioc_mvc/user/quick14/zhangsna
@RequestMapping("/quick14/{username}",method="GET/DELETE/PUT/POST") =>{username}占位符
@ResponseBody
public void save14(@PathVariable(value="username",required = true)String name) throws Exception { =>value="username"和{username}一致
System.out.println(name);
}
自定義類型轉(zhuǎn)換器
.SpringMVC默認已經(jīng)提供了一些常用的類型轉(zhuǎn)換器,例如客戶端提交的字符串轉(zhuǎn)換成int型進行參數(shù)設置。
·但是不是所有的數(shù)據(jù)類型都提供了轉(zhuǎn)換器,沒有提供的就需要自定義轉(zhuǎn)換器,
例如:日期類型的數(shù)據(jù)就需要自定義轉(zhuǎn)換器。
-
自定義類型轉(zhuǎn)換器的開發(fā)步驟:
- 定義轉(zhuǎn)換器類實現(xiàn)Converter接口
public class DateConverter implements Converter<String, Date> { public Date convert(String dateStr) { Date date=null; try { SimpleDateFormat format=new SimpleDateFormat("yyyy-MM-dd"); date=format.parse(dateStr); } catch (ParseException e) { e.printStackTrace(); } return date; } }- 在配置文件中聲明轉(zhuǎn)換器
<!--聲明轉(zhuǎn)換器--> <bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean"> <property name="converters"> <list> <bean class="com.xjbt.spring_MVC.converter.DateConverter"></bean> </list> </property> </bean>- 在<annotation-driven>中引用轉(zhuǎn)換器
<mvc:annotation-driven conversion-service="conversionService"/>
獲取頭信息@RequestHeader(value,require)和獲取Cookie@CookieValue(value,require)
@RequestMapping("/quick17")
@ResponseBody
public void save17(@RequestHeader(name="User-Agent",required = false)String agent){
System.out.println(agent);
}
@RequestMapping("/quick18")
@ResponseBody
public void save18(@CookieValue(name="JSESSIONED",required = false)String jsessioned){
System.out.println(jsessioned);
}
文件上傳
-
上傳三要素:
image.png -
文件上傳的原理
當form表單enctype=formMutilpart/form-date【多部分形式】時,request.getParameter()將失效。
enctype= "application/x-www-form-urlencoded”[url編碼方式]時,form表單的正文內(nèi)容格式是:key=value&key=value&key=value
enctype=formMutilpart/form-date【多部分形式】↓
image.png -
上傳步驟:
1,導入fileupload和io坐標
<!--文件上傳所需要的坐標-->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.2.2</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
2,配置文件上傳解析器
<!--配置文件上傳解析器-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="UYF-8"></property>
<property name="maxUploadSize" value="500000"></property>
</bean>
3,編寫文伴上傳代碼
<form action="${pageContext.request.contextPath}/user/quick19" method="post" enctype="multipart/form-data">
名稱<input type="text" name="username" ><br/>
文件<input type="file" name="up1oadFile"><br/>
文件<input type="file" name="up1oadFile2"><br/>
<input type="submit" value="提交">
</form>
<%--數(shù)組形式--%>
<form action="${pageContext.request.contextPath}/user/quick20" method="post" enctype="multipart/form-data">
名稱<input type="text" name="username" ><br/>
文件<input type="file" name="up1oadFile"><br/>
文件<input type="file" name="up1oadFile"><br/>
<input type="submit" value="提交">
</form>
//文件上傳
@RequestMapping("/quick19")
@ResponseBody
public void save19(String username, MultipartFile up1oadFile,MultipartFile up1oadFile2) throws Exception{
//獲得上傳文件的名稱
String originalFilename = up1oadFile.getOriginalFilename();
String originalFilename2 = up1oadFile2.getOriginalFilename();
//保存到一個目錄
up1oadFile.transferTo(new File("G:\\Spring\\"+originalFilename));
up1oadFile2.transferTo(new File("G:\\Spring\\"+originalFilename2));
}
//文件上傳
@RequestMapping("/quick20")
@ResponseBody
public void save19(String username, MultipartFile[] up1oadFile) throws Exception{
for (MultipartFile file:up1oadFile) {
String originalFilename = file.getOriginalFilename();
file.transferTo(new File("G:\\Spring\\duowenjian\\"+originalFilename));//=>G:\Spring\duowenjian\目錄必須存在
}
}

