spring+springMVC+jdbcTemplate框架整合(XML配置)

spring+springMVC+jdbcTemplate框架整合(XML配置)

1.创建Maven工程

选择web工程

导入坐标
<dependencies>
        <!--spring相关-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.0.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.8.7</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.0.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-tx</artifactId>
            <version>5.0.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>5.0.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.0.5.RELEASE</version>
        </dependency>

        <!--servlet和jsp-->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet.jsp</groupId>
            <artifactId>jsp-api</artifactId>
            <version>2.0</version>
        </dependency>
        <dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>

        <!--mybatis相关-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.5</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>1.3.1</version>
        </dependency>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.30</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.6</version>
        </dependency>

        <dependency>
            <groupId>c3p0</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.1.2</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>

    </dependencies>

2.首先编写jdbc.properties文件

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/test
jdbc.username=root
jdbc.password=1234

3.编写Mybatis-config.xml的配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" 
"http://mybatis.org/dtd/mybatis-3-config.dtd">


<configuration>

    <!--加载外部properties-->
    <properties resource="jdbc.properties"></properties>

    <!--定义别名-->
    <typeAliases>
        <typeAlias type="com.kk.domain.Account" alias="account"/>
        <!--或者,扫包,包下的实体都会定义别名为 类名小写开头的类名 -->
        <!--<package name="com.kk.domain"/>-->
    </typeAliases>

    <!--数据源的环境-->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"></transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
    </environments>

    <!--加载映射关系-->
    <mappers>
        <mapper resource="com/kk/mapper/AccountMapper.xml"></mapper>
        <!--或者,指定接口所在的包,就会自动加载-->
        <!-- <package name="com.kk.mapper"/>-->
    </mappers>

</configuration>

4.编写spring所需要的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:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
                          http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context.xsd
                          http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
                          http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd"
        >
        <!--引入properties配置文件-->
        <context:property-placeholder location="classpath:jdbc.properties"/>

        <!--配置druid数据源-->
        <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
                <property name="driverClassName" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
        </bean>

        <!--配置jdbcTemplate-->
        <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
                <property name="dataSource" ref="dataSource"/>
        </bean>

        <!--配置平台事务管理器-->
        <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
                <property name="dataSource" ref="dataSource"/>
        </bean>

        <!--配置spring提供好的Advice-->
        <tx:advice id="txAdvice" transaction-manager="transactionManager">
                <!--配置事务的参数-->
                <tx:attributes>
                        <!--name 指定哪些方法上添加事物-->
                        <tx:method name="*"/>
                </tx:attributes>
        </tx:advice>

        <!--事物增强的aop-->
        <aop:config>
                <!--配置切点表达式-->
                <aop:pointcut id="txPointcut" expression="execution(* com.gxuwz.*.*(..))"/>
                <!--配置织入关系 通知advice-red引入Spring提供好的-->
                <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>
        </aop:config>

        <!--开启包扫描-->
        <context:component-scan base-package="com.gxuwz.service"/>
        <context:component-scan base-package="com.gxuwz.dao"/>
        <context:component-scan base-package="com.gxuwz.util"/>


</beans>

5.编写spring-mvc的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  http://www.springframework.org/schema/context/spring-context.xsd
                         http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"
>

    <!--控制器包路径-->
    <context:component-scan base-package="com.gxuwz.controller"/>

    <!--默认 Servlet 处理静态资源-->
    <mvc:default-servlet-handler/>
    <!--MVC 注解驱动以支持高级功能-->
    <mvc:annotation-driven/>

    <!--配置Thymeleaf视图解析器-->
    <!--生成模版解析器-->
    <bean id="templateResolver" class="org.thymeleaf.spring5.templateresolver.SpringResourceTemplateResolver">
        <!--设置模板前缀,指定Thymeleaf查找模板文件的起始位置-->
        <property name="prefix" value="/WEB-INF/pages/"/>
        <!--设置模板后缀,指定模板文件的文件类型-->
        <property name="suffix" value=".html"/>
        <!--设置模板模式,这里使用HTML作为模板模式-->
        <property name="templateMode" value="HTML"/>
        <!--设置字符编码,通常使用UTF-8-->
        <property name="characterEncoding" value="UTF-8"/>
        <property name="order" value="1"/>
        <property name="cacheable" value="false"/>
    </bean>

    <!--模板解析器注入到模板引擎中-->
    <bean id="templateEngine" class="org.thymeleaf.spring5.SpringTemplateEngine">
        <!--设置模板解析器,将之前配置的模板解析器注入到模板引擎中-->
        <property name="templateResolver" ref="templateResolver"/>
    </bean>

    <bean id="viewResolver" class="org.thymeleaf.spring5.view.ThymeleafViewResolver">
        <!--设置视图解析器的顺序,通常用于指定视图解析器的执行顺序-->
        <property name="order" value="1"/>
        <!--设置字符编码,通常使用UTF-8-->
        <property name="characterEncoding" value="UTF-8"/>
        <!--设置模板引擎,将之前配置的模板引擎注入到视图解析器中-->
        <property name="templateEngine" ref="templateEngine"/>
    </bean>

    <!--视图控制器-->
    <mvc:view-controller path="/" view-name="login"/>
</beans>

6.配置web.xml文件

<!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >

<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_3_1.xsd"
         version="3.1">
  <display-name>请假信息管理系统</display-name>

  <!-- 这是Spring IOC(控制反转)容器的配置部分 -->
  <listener>
    <!-- 这个监听器类是Spring Web应用程序启动时默认加载的,它负责加载Spring的上下文环境 -->
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>

  <context-param>
    <!-- 指定Spring IOC容器的配置文件路径,这个文件通常包含Spring的bean定义和配置 -->
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext-spring.xml</param-value>
  </context-param>

  <!-- 这是Spring MVC(模型-视图-控制器)框架的配置部分 -->
  <servlet>
    <!-- 这个servlet的名字是“dispatcherServlet”,它是Spring MVC框架中的核心组件,负责请求的分发和处理 -->
    <servlet-name>dispatcherServlet</servlet-name>
    <!-- servlet-class属性指定了servlet的实现类,这里是Spring MVC框架提供的DispatcherServlet类 -->
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <!-- 这个init-param用于初始化servlet,指定Spring MVC的配置文件路径 -->
      <param-name>contextConfigLocation</param-name>
      <!-- 这个值指定了Spring MVC的配置文件路径,通常包含与视图解析器、URL映射等有关的配置 -->
      <param-value>classpath:applicationContext-springMVC.xml</param-value>
    </init-param>
    <!-- load-on-startup属性表示在应用程序启动时加载这个servlet -->
    <load-on-startup>1</load-on-startup>
  </servlet>

  <!-- 这个配置映射了servlet到URL,这里表示所有的URL(即“/”)都由“dispatcherServlet”处理 -->
  <servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

  <!-- 这个部分是字符编码过滤器的配置,用于设置HTTP请求和响应的字符编码 -->
  <filter>
    <!-- filter-name属性定义了过滤器的名字,这里是“characterEncodingFilter” -->
    <filter-name>characterEncodingFilter</filter-name>
    <!-- filter-class属性指定了过滤器的实现类,这里是Spring Web框架提供的CharacterEncodingFilter类 -->
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
      <!-- 这个init-param用于初始化过滤器,设置请求的字符编码 -->
      <param-name>encoding</param-name>
      <!-- 这里设置请求的字符编码为UTF-8 -->
      <param-value>UTF-8</param-value>
    </init-param>
  </filter>

  <!-- 这个部分是过滤器的映射,这里表示所有的URL(即“/*”)都经过“characterEncodingFilter”过滤 -->
  <filter-mapping>
    <filter-name>characterEncodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
</web-app>

7.配置完基础环境文件,开始编写代码,首先建立好目录文件

在这里插入图片描述
最后就是你自己的业务和实现功能了

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

KYGALYX

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值