依賴注入方式
- 1.0開始,setter、構(gòu)造器注入
- 2.5開始,Autowired注解的基于field方式注入
創(chuàng)建對象并配置如何注入
XML配置
- 可從類加載路徑中加載配置文件(ClassPathXmlApplicationContext),或從文件系統(tǒng)中加載配置文件(FileSystemXmlApplicationContext)。
通過構(gòu)造器創(chuàng)建bean實例
- 首先編寫好Product類的Java代碼
- xml配置bean:
<bean name="product" class="app01a.bean.Product"/>
- 如果是調(diào)用帶參數(shù)的構(gòu)造器,可以用constructor-arg參數(shù)(這里的參數(shù)不僅可以是java基本數(shù)據(jù)類型,還可以是所依賴的其他對象,如simpleAddress):
<bean name="featuredProduct" class="app01a.bean.Product">
<constructor-arg name="name" value="Ultimate Olive Oil"/>
<constructor-arg name="description" value="The purest olive oil on the market"/>
<constructor-arg name="price" value="9.95"/>
</bean>
/********************/
<bean name="simpleAddress" class="app01a.bean.Address">
<constructor-arg name="line1" value="151 Corner Street"/>
<constructor-arg name="line2" value=""/>
<constructor-arg name="city" value="Albany"/>
<constructor-arg name="state" value="NY"/>
<constructor-arg name="zipCode" value="99999"/>
<constructor-arg name="country" value="US"/>
</bean>
<bean name="employee2" class="app01a.bean.Employee">
<constructor-arg name="firstName" value="Senior"/>
<constructor-arg name="lastName" value="Moore"/>
<constructor-arg name="homeAddress" ref="simpleAddress"/>
</bean>
- ApplicationContext加載xml文件:
ApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"spring-config.xml"});
- 調(diào)用context的getBean獲取product對象:
Product product1 = context.getBean("product", Product.class);
通過工廠方法創(chuàng)建bean實例
- 將上述1中xml配置改為
<bean name="product" class="app01a.bean.Product" factory-method="getInstance"/>
- 說明:可能還需要Product類本身支持工廠模式,具體情況稍后探究
Setter方式注入
- 首先要Product類的java代碼中有setXXX的形式
- 用property屬性來完成注入:
<bean name="simpleAddress" class="app01a.bean.Address">
<constructor-arg name="line1" value="151 Corner Street"/>
<constructor-arg name="line2" value=""/>
<constructor-arg name="city" value="Albany"/>
<constructor-arg name="state" value="NY"/>
<constructor-arg name="zipCode" value="99999"/>
<constructor-arg name="country" value="US"/>
</bean>
<bean name="employee1" class="app01a.bean.Employee">
<property name="homeAddress" ref="simpleAddress"/>
<property name="firstName" value="Junior"/>
<property name="lastName" value="Moore"/>
</bean>
Spring的第一個重要的類:DispatcherServlet
- DispatcherServlet將使用Spring MVC諸多默認(rèn)的組件,初始時會在WEB-INF目錄下尋找配置文件servletName-servlet.xml。
- 也可以設(shè)置init-param指定其他位置的配置文件
- /WEB-INF/web.xml:
<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/config/springmvc-config.xml</param-value> //注意這里的Path值應(yīng)為配置文件在應(yīng)用中的相對路徑
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>*.action</url-pattern>
</servlet-mapping>
- /WEB-INF/config/springmvc-config.xml
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
<bean name="/product_input.action" class="app03b.controller.InputProductController"/>
<bean name="/product_save.action" class="app03b.controller.SaveProductController"/>
Autowired注解
@Controller
- 用在類上
- 指示這個類的實例是一個控制器
- 有點:一個控制器類可以包含多個請求處理方法(通過@RequestMapping注解實現(xiàn)),而如果是配置的方法,則只能一個類實現(xiàn)Controller接口,然后實現(xiàn)一個處理方法handleRequest。
- 生效要求:首先在配置文件 springmvc-config.xml中聲明xmlns:context和component-scan元素指定要掃描的包
<?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:p="http://www.springframework.org/schema/p"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<context:component-scan base-package="app04a.controller"/>
<mvc:annotation-driven/>
<mvc:resources mapping="/css/**" location="/css/"/>
<mvc:resources mapping="/*.html" location="/"/>
</beans>
- 解釋:<mvc:annotation-driven/>的作用是注冊用于支持基于注解的控制器的請求處理方法的bean對象,和可以使用<mvc:resources/>元素
- <mvc:resources/>元素指示Spring MVC哪些靜態(tài)資源需要單獨處理(不通過DispatcherServlet,即:阻止任意控制器被調(diào)用
- 若不需要使用<mvc:resources/>,則不需要<mvc:annotation-driven/>元素
@RequestMapping
- 用于注釋類或方法
- 注釋的方法將成為一個請求處理方法,并由調(diào)度程序在接收到對應(yīng)URL請求時調(diào)用
- 注釋一個控制器類時,將所有的方式都映射為相同類級別的請求,但在具體方法上還可以再設(shè)置更精確的映射地址
@RequestMapping(value="/employee_input")
public String inputEmployee() {
logger.info("inputEmployee called");
return "ProductForm";
}
Model
- import org.springframework.ui.Model;
- saveProduct()的第二個參數(shù)是Mode類型,無論是否使用,Spring MVC都會在每一個請求處理方法被調(diào)用時創(chuàng)建一個Model實例,用于增加需要顯示在視圖中的屬性,通過 model.addAttribute("product", product);來添加,Product實例就可以像被添加到HttpServletRequest中那樣訪問了。
public String saveProduct(ProductForm productForm, Model model) {
logger.info("saveProduct called");
// no need to create and instantiate a ProductForm
// create Product
Product product = new Product();
product.setName(productForm.getName());
product.setDescription(productForm.getDescription());
try {
product.setPrice(Float.parseFloat(
productForm.getPrice()));
} catch (NumberFormatException e) {
}
// add product
model.addAttribute("product", product);
return "ProductDetails";
}
@Autowired和@Service
- @Service注釋一個類,表示這是一個服務(wù)
- 服務(wù)類也需要像控制類一樣設(shè)置掃描包的范圍<context:component-scan base-package="app04b.service"/>
- @Autowired可以將一個服務(wù)類的實例注入到控制類中,注入后可以直接使用該服務(wù)類的實例
@Autowired
private ProductService productService;// 無需手動new ProductService,
Product savedProduct = productService.add(product);//直接使用實例productService
@RequestParam
- 請求參數(shù)采用key=value的形式,并用&分隔
- 例:http://localhost:8080/app/product?productID=3
- ?問號后面的就是請求參數(shù),key為productID,value為3
- 傳統(tǒng)servlet方法:
String productId = httpServletRequest.getParameter("productID")
- Spring MVC方法:直接在處理該請求的方法的參數(shù)列表中加上@RequestParam注解,
public void sendProduct(@RequestParam int productID)
- 參數(shù)類型不一定要是字符串,可以設(shè)置為自己想要的類型,Spring MVC會盡力轉(zhuǎn)換為非字符串類型
@PathVariable
- 有時候參數(shù)不是采用鍵值對的方式,也沒有?問號分割,而是直接放在了請求中
- 例如:/product/productID
- 用SpringMVC的方法,首先在RequestMapping注解的在value屬性中添加一個變量,用花括號{}括起來,然后在方法形式參數(shù)上加一個同名變量,并用@PathVariable注解
@RequestMapping(value = "/product_view/{id}")
public String viewProduct(@PathVariable Long id, Model model) {
Product product = productService.get(id);
model.addAttribute("product", product);
return "ProductView";
}