Spring MVC & Spring JDBC

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的處理流程

    1. 用戶發(fā)送請求至前端控制器DispatcherServlet
    1. DispatcherServlet收到請求調(diào)用HandlerMapping處理器映射器。
    1. 處理器映射器根據(jù)請求url找到具體的處理器,生成處理器對象及處理器攔截器(如果有則生成)一并返回給DispatcherServlet。
    1. DispatcherServlet通過HandlerAdapter處理器適配器調(diào)用處理器
    1. 執(zhí)行處理器(Controller,也叫后端控制器)。
    1. Controller執(zhí)行完成返回ModelAndView
    1. HandlerAdapter將controller執(zhí)行結(jié)果ModelAndView返回給DispatcherServlet
    1. DispatcherServlet將ModelAndView傳給ViewReslover視圖解析器
    1. ViewReslover解析后返回具體View
    1. DispatcherServlet對View進(jìn)行渲染視圖(即將模型數(shù)據(jù)填充至視圖中)。
    1. 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&amp;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);
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容