MVC模式
MVC即Model-View-Controller,將應(yīng)用按照Model(模型)、View(視圖)、Controller(控制器)方式分離。
- Model:是業(yè)務(wù)的處理以及業(yè)務(wù)規(guī)則的指定。模型接收視圖請求的數(shù)據(jù),并返回最終的處理結(jié)果。業(yè)務(wù)模型的設(shè)計(jì)師MVC最主要的核心。MVC設(shè)計(jì)模式告訴我們,把應(yīng)用的模型按一定的規(guī)則抽取出來,抽取的層次很重要,抽象與具體不能隔離得太遠(yuǎn),也不能太近。MVC并沒有提供模型的設(shè)計(jì)方法,而只是組織管理這些模型,以便于模型的重構(gòu)和提高重用性。
- View:代表用于交互界面,對于web應(yīng)用來說,可以是HTML、JSP、Applet等。一個(gè)應(yīng)用可能有很多不同的視圖,MVC設(shè)計(jì)模式對于視圖的處理僅限于視圖上數(shù)據(jù)的采集和處理,以及用戶的請求,而不包括在視圖上的業(yè)務(wù)流程的處理。業(yè)務(wù)流程的處理交予Model處理。
- Controller:可以理解為從用戶接收請求,將模型與視圖匹配在一起,共同完成用戶的請求。劃分控制層的作用也很明顯,它清楚地告訴你,它就是一個(gè)分發(fā)器,選擇什么樣的模型,選擇什么樣的視圖,可以完成什么樣的用戶請求,控制層并不做任何的數(shù)據(jù)處理。
Spring MVC的處理流程
- 用戶發(fā)送請求至前端控制器DispatcherServlet
- DispatcherServlet收到請求調(diào)用HandlerMapping處理器映射器。
- 處理器映射器根據(jù)請求url找到具體的處理器,生成處理器對象及處理器攔截器(如果有則生成)一并返回給DispatcherServlet。
- DispatcherServlet通過HandlerAdapter處理器適配器調(diào)用處理器
- 執(zhí)行處理器(Controller,也叫后端控制器)。
- Controller執(zhí)行完成返回ModelAndView
- HandlerAdapter將controller執(zhí)行結(jié)果ModelAndView返回給DispatcherServlet
- DispatcherServlet將ModelAndView傳給ViewReslover視圖解析器
- ViewReslover解析后返回具體View
- DispatcherServlet對View進(jìn)行渲染視圖(即將模型數(shù)據(jù)填充至視圖中)。
- DispatcherServlet響應(yīng)用戶
使用方式
- 導(dǎo)入相關(guān)依賴
<!--spring-webmvc 相關(guān)依賴-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.1.RELEASE</version>
</dependency>
<!--Servlet-API 相關(guān)依賴-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.0</version>
<scope>provided</scope>
</dependency>
- 在web.xml配置文件中關(guān)于SpringMVC的配置
<!-- 配置springMVC的核心控制器DispatcherServlet -->
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 設(shè)置springmvc的配置文件 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
- 在resource目錄下添加springmvc.xml配置文件
<!-- 視圖解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 前綴 -->
<property name="prefix" value="/WEB-INF/view/"/>
<!-- 后綴 -->
<property name="suffix" value=".jsp"/>
</bean>
如果一個(gè)xml文件中要引用另一個(gè)xml文件有兩種解決方式
<!-- 方式1:在要引用的xml文件中導(dǎo)入另一個(gè)xml文件 -->
<import resource="springcore.xml"/>
<!-- 方式2:在web.xml中配置監(jiān)聽器 -->
<!-- 配置ContextLoaderListener需要讀取的spring容器配置文件的位置 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springcore.xml</param-value>
</context-param>
<!-- 配置ContextLoaderListener監(jiān)聽器 -->
<!-- 作用 : 在服務(wù)器啟動時(shí),加載Spring容器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
2. Spring JDBC的用途以及使用方式
Spring JDBC主要作用是簡化了開發(fā)人員對數(shù)據(jù)庫的操作,其中,最主要的就是JdbcTemplate類來實(shí)現(xiàn)相應(yīng)的數(shù)據(jù)庫操作。
JdbcTemplate是core包的核心類。它替我們完成了資源的創(chuàng)建以及釋放工作,從而簡化了我們對JDBC的使用。我們可以在DAO實(shí)現(xiàn)類中通過傳遞一個(gè)DataSource引用來完成JdbcTemplate的實(shí)例化,也可以在Spring的IOC容器中配置一個(gè)JdbcTemplate的bean賦予DAO實(shí)現(xiàn)類作為一個(gè)實(shí)例。
使用方式
- 導(dǎo)入相關(guān)依賴
<!-- spring-jdbc依賴 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.2.9.RELEASE</version>
</dependency>
<!-- druid數(shù)據(jù)源依賴 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.22</version>
</dependency>
<!-- mysql驅(qū)動依賴 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.15</version>
</dependency>
- 注入數(shù)據(jù)源
<!-- 可以使用org.springframework.jdbc.datasource.DriverManagerDataSource自帶數(shù)據(jù)源 -->
<!-- 此處使用第三方Alibaba的Druid數(shù)據(jù)源 -->
<bean id="druidDataSourceBean" class="com.alibaba.druid.pool.DruidDataSource">
<property name="url" value="jdbc:mysql://39.104.122.117/數(shù)據(jù)庫名? useSSL=false&serverTimezone=GMT%2B8"/>
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</bean>
<!-- JdbcTemplate -->
<bean id="jdbcTemplateBean" class="org.springframework.jdbc.core.JdbcTemplate">
<!-- 注入數(shù)據(jù)源 -->
<property name="dataSource" ref="druidDataSourceBean"/>
</bean>
<!-- 將JdbcTemplate注入數(shù)據(jù)訪問層DAO -->
<bean id="employeeDaoBean" class="com.my.dao.MaterialsDAO">
<!-- 注入JdbcTemplate -->
<property name="jdbcTemplate" ref="jdbcTemplateBean"/>
</bean>
import org.springframework.jdbc.core.JdbcTemplate;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import com.apesource.entity.MaterialsInfo;
import org.springframework.jdbc.core.RowMapper;
//數(shù)據(jù)訪問層
public class MyDAO {
private JdbcTemplate jdbcTemplate;
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
jdbcTemplate.query(String sql, RowMapper<T> var2);
jdbcTemplate.update(String sql);
}