Controller配置
控制器Controller
控制器複雜提供通路應用程式的行為,通常通過接口定義或注釋定義的兩種方法實作
控制器負責解析使用者的請求并将其轉換為一個模型
SpringMVC中一個控制器可以包含多個方法
實作Controller接口
Controller是一個接口,在org.springframework.web.servlet.mvc包下,接口隻有一個方法
//實作Controller接口的類可以獲得控制器的功能
public interface Controller {
//處理請求且傳回一個模型與視圖對象
@Nullable
ModelAndView handleRequest(HttpServletRequest var1, HttpServletResponse var2) throws Exception;
}
接口方法實作Controller
配置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">
<!--配置DispatcherServlet-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-servlet.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
- 配置springmvc-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"
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.wei.controller"/>
<!--過濾靜态資源-->
<mvc:default-servlet-handler/>
<!--配置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>
- 編寫Controller類(ControllerTest1)
package com.wei.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 ControllerTest1 implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
//建立模型和視圖對象
ModelAndView modelAndView = new ModelAndView();
封裝資料,向模型添加屬性msg與值,可以在jsp頁面取出、渲染
modelAndView.addObject("msg","ControllerTest1");
//視圖跳轉
modelAndView.setViewName("test");
//傳回視圖模型對象
return modelAndView;
}
}
- test.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
${msg}
</body>
</html>
缺點:一個控制器隻要一個方法,如果多個方法需要多個Controller,使用這種方法比較麻煩
注解方法實作Controller
@Controller注解的類會自動添加到Spring上下文中,被這個注解的類,傳回String,并且有具體頁面跳轉,就會被視圖解析器解析
@Controller控制器(注入服務)
@Component(把普通pojo執行個體化到spring容器中,相當于配置檔案中的 )
@Service服務(注入dao)
@Respository(現dao通路)
- Spring可以使用掃描機制找到應用程式中所有基于注解的控制器類,為保證Spring能找到控制器,需要在配置檔案中聲明元件掃描
<!--自動掃描包,讓指定包下的注釋生效,由IOC容器統一管理-->
<context:component-scan base-package="com.wei.controller"/>
- 增加一個ControllerTest類,使用注解實作
package com.wei.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
//@Controller注解的類會自動添加到Spring上下文中,被這個注解的類,傳回String,并且有具體頁面跳轉,就會被視圖解析器解析
@Controller
public class ControllerTest2 {
@RequestMapping("/t2")
public String test1(Model model){
model.addAttribute("msg","ControllerTest2");
return "test"; // /WEB-INF/jsp/test.jsp
}
}
RequestMapping配置
@RequestMapping注解用于映射url到控制器或一個特定的處理程式方法,可用于類或方法上
用于類上,表示類中的所有響應請求的方法都是以該位址作為父路徑
- 通路路徑為:http://localhost:8080/項目名/c3/t1
package com.wei.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("/c3")
public class ControllerTest3 {
@RequestMapping({"/t1"})
//或者 @RequestMapping({"/c3/t1"})
public String test1(Model model){
model.addAttribute("msg","ControllerTest3");
return "test";
}
}
RestFul
概念
RestFul是一種網絡應用程式的設計風格和開發方式,基于HTTP,可以使用XML格式定義或JSON格式定義。RestFul适用于移動網際網路廠商作為業務接口的場景,實作第三方OTT調用移動網絡資源的功能,動作類型為新增、變更、删除所調用資源
RestFul就是資源定位及資源操作的風格,不是标準也不是協定,隻是一種風格,基于RestFul風格設計的軟體可以更高效、有層次、易于實作緩存機制
傳統方式
package com.wei.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
//@Controller注解的類會自動添加到Spring上下文中,被這個注解的類,傳回String,并且有具體頁面跳轉,就會被視圖解析器解析
@Controller
public class RestFulController {
@RequestMapping("/add")
public String test1(int a, int b, Model model) {
int result = a + b;
model.addAttribute("msg", "結果為:" + result);
return "test";
}
}
RestFul方式
@PathVariable:讓方法參數的值對應綁定到一個URL模闆變量上
package com.wei.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
//@Controller注解的類會自動添加到Spring上下文中,被這個注解的類,傳回String,并且有具體頁面跳轉,就會被視圖解析器解析
@Controller
public class RestFulController {
@RequestMapping("/add/{a}/{b}")
public String test1(@PathVariable int a,@PathVariable int b, Model model) {
int result = a + b;
model.addAttribute("msg", "結果為:" + result);
return "test";
}
}
方式一:
@GetMapping(“/add/{a}/{b}”)
@PostMapping(“/add/{a}/{b}”)
@PutMapping(“/add/{a}/{b}”)
@DeleteMapping(“/add/{a}/{b}”)
@PatchMapping(“/add/{a}/{b}”)
package com.wei.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;
//@Controller注解的類會自動添加到Spring上下文中,被這個注解的類,傳回String,并且有具體頁面跳轉,就會被視圖解析器解析
@Controller
public class RestFulController {
// @GetMapping("/add/{a}/{b}")
// @PostMapping("/add/{a}/{b}")
// @PutMapping("/add/{a}/{b}")
// @DeleteMapping("/add/{a}/{b}")
// @PatchMapping("/add/{a}/{b}")
@GetMapping("/add/{a}/{b}")
public String test1(@PathVariable int a,@PathVariable int b, Model model) {
int result = a + b;
model.addAttribute("msg", "test1結果為:" + result);
return "test";
}
@PostMapping("/add/{a}/{b}")
public String test2(@PathVariable int a,@PathVariable int b, Model model) {
int result = a + b;
model.addAttribute("msg", "test2結果為:" + result);
return "test";
}
}
方式二:
package com.wei.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;
//@Controller注解的類會自動添加到Spring上下文中,被這個注解的類,傳回String,并且有具體頁面跳轉,就會被視圖解析器解析
@Controller
public class RestFulController {
@RequestMapping(value = "/add/{a}/{b}",method = RequestMethod.GET)
public String test1(@PathVariable int a,@PathVariable int b, Model model) {
int result = a + b;
model.addAttribute("msg", "test1結果為:" + result);
return "test";
}
@RequestMapping(value = "/add/{a}/{b}",method = RequestMethod.POST)
public String test2(@PathVariable int a,@PathVariable int b, Model model) {
int result = a + b;
model.addAttribute("msg", "test2結果為:" + result);
return "test";
}
}