SpringMVC+Spring+MyBatis整合步骤代码

简介: 1.jar包    spring的jar包:        spring-aop-4.2.5.RELEASE.jar        spring-aspects-4.
1.jar包
    spring的jar包:
        spring-aop-4.2.5.RELEASE.jar
        spring-aspects-4.2.5.RELEASE.jar
        spring-beans-4.2.5.RELEASE.jar
        spring-context-4.2.5.RELEASE.jar
        spring-core-4.2.5.RELEASE.jar
        spring-expression-4.2.5.RELEASE.jar
        spring-jdbc-4.2.5.RELEASE.jar
        spring-tx-4.2.5.RELEASE.jar
        spring-web-4.2.5.RELEASE.jar
        spring-webmvc-4.2.5.RELEASE.jar
    mybatis的jar包:
        asm-4.2.jar
        cglib-3.1.jar
        commons-logging-1.2.jar
        log4j-1.2.17.jar
        log4j-api-2.2.jar
        log4j-core-2.2.jar
        mybatis-3.3.0.jar
        mybatis-spring-1.3.0.jar
        slf4j-api-1.7.12.jar
        slf4j-log4j12-1.7.12.jar
    jdbc的jar包:
        mysql-connector-java-5.1.20-bin.jar
    c3p0的jar包:
        c3p0-0.9.5.2.jar
        mchange-commons-java-0.2.11.jar
    jstl的jar包:
        taglibs-standard-compat-1.2.5.jar
        taglibs-standard-impl-1.2.5.jar
        taglibs-standard-jstlel-1.2.5.jar
        taglibs-standard-spec-1.2.5.jar
    分页的jar包:
        jsqlparser-0.9.5.jar
        mybatis-paginator-1.2.15.jar
        pagehelper-4.1.6.jar
    jackson的jar包:
        jackson-annotations-2.6.3.jar
        jackson-core-2.6.3.jar
        jackson-databind-2.6.3.jar
2.配置web.xml
    <!-- 监听器启动spring框架 -->
        <listener>
            <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
        </listener>
        <context-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>/WEB-INF/applicationContext/applicationContext-*.xml</param-value>
        </context-param>
    <!-- 字符过滤器 -->
        <filter>
            <filter-name>encodingFilter</filter-name>
            <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
            <init-param>
                <param-name>encoding</param-name>
                <param-value>utf-8</param-value>
            </init-param>
        </filter>
        <filter-mapping>
            <filter-name>encodingFilter</filter-name>
            <!-- 对springmvc处理的请求进行转码 -->
            <servlet-name>springmvc</servlet-name>
        </filter-mapping>
    <!-- springmvc配置 -->
        <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/applicationContext/springmvc.xml</param-value>
            </init-param>
            <load-on-startup>1</load-on-startup>
        </servlet>
        <servlet-mapping>
            <servlet-name>springmvc</servlet-name>
            <url-pattern>*.do</url-pattern>
        </servlet-mapping>
3.配置jdbc.properties
    jdbc.driver=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost:3306/rbac?useUnicode=true&amp;characterEncoding=utf8
    jdbc.user=root
    jdbc.password=123456

    c3p0.initialPoolSize=10
    c3p0.maxPoolSize=100
    c3p0.minPoolSize=10
4.配置application-*.xml
    配置application-dao.xml(数据库连接、mybatis配置部署)
        <!-- 设置spring扫描器扫描 -->
            <context:component-scan base-package="com.bjsxt.rbac">
            <!-- 禁止扫描Controller注解的类 -->
                <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
            </context:component-scan>
            <context:property-placeholder location="classpath:jdbc.properties"/>
        <!-- 数据源 -->
            <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
                <property name="jdbcUrl" value="${jdbc.url}"/>
                <property name="driverClass" value="${jdbc.driver}"/>
                <property name="user" value="${jdbc.user}"/>
                <property name="password" value="${jdbc.password}"/>
                <property name="initialPoolSize" value="${c3p0.initialPoolSize}"/>
                <property name="maxPoolSize" value="${c3p0.maxPoolSize}"/>
                <property name="minPoolSize" value="${c3p0.minPoolSize}"/>
            </bean>
        <!-- sqlSessionFactory -->
            <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
                <property name="dataSource" ref="dataSource"/>
                <property name="configLocation" value="classpath:mybatis.cfg.xml"/>
            </bean>
        <!-- mybatis的包扫描器 -->
            <bean id="mapperScanner" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
                <property name="basePackage" value="com.bjsxt.rbac.mapper"/>
                <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
            </bean>
    application-*.xml(spring事务管理)
        <!-- 设置spring事务管理哪个数据源 -->
            <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
            <property name="dataSource" ref="dataSource"/>
            </bean>
        <!-- 通知 -->
        <!-- 在什么地方,做什么(事务管理) 什么时候 -->
            <tx:advice id="myAdvice" transaction-manager="transactionManager">
                <tx:attributes>
                <!-- 当调用方法是以save开头的方法的时候,要求有一个事务,如果当前没有已经存在的事务,则开启一个事务 -->
                    <tx:method name="save*" propagation="REQUIRED"/>
                    <tx:method name="update*" propagation="REQUIRED"/>
                    <tx:method name="delete*" propagation="REQUIRED"/>
                <!-- 以get开头的方法,如果在调用的时候,当前方法已经在事务中运行,则直接运行,如果没有在事务中运行,则也可以运行 -->
                    <tx:method name="get*" propagation="SUPPORTS"/>
                    <tx:method name="select*" propagation="SUPPORTS"/>
                </tx:attributes>
            </tx:advice>
        <!-- 切面 -->
        <!-- 在什么时候,什么地方,做什么 -->
        <!-- 什么时候?事务管理,肯定是在方法开始之前开启一个事务,方法调用完成之后提交事务或者回滚事务 -->
            <aop:config>
            <!-- 切点:指定什么地方 -->
                <aop:pointcut expression="execution(* com.bjsxt.rbac.service.*.*(..))" id="myPcut"/>
            <!-- 通知:指定做什么 -->
                <aop:advisor advice-ref="myAdvice" pointcut-ref="myPcut"/>
            </aop:config>
5.配置mybatis.cfg.xml
    <!-- 指定包下的实体类起别名 -->
        <configuration>
            <typeAliases>
                <package name="com.bjsxt.rbac.vo"/>
            </typeAliases>
        </configuration>
6.配置springmvc.xml
    <!-- 设置扫描器扫描controller注解类 -->
        <context:component-scan base-package="com.bjsxt.rbac.controller"></context:component-scan>
    <!-- HandlerMapping、MappingAdaptor、messageConverter可省略 -->
    <!-- 向spring上下文中添加消息转换器,还加入了映射器和适配器 -->
        <mvc:annotation-driven />
    <!-- 定义拦截器链 -->
        <mvc:interceptors>
            <mvc:interceptor>
                <mvc:mapping path="/**"/>
                <bean class="com.bjsxt.rbac.interceptor.LoginInterceptor"></bean>
            </mvc:interceptor>
            <mvc:interceptor>
                <mvc:mapping path="/**"/>
                <bean class="com.bjsxt.rbac.interceptor.UrlInterceptor"></bean>
            </mvc:interceptor>
        </mvc:interceptors>
    <!-- 视图解析器 -->
        <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
            <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
            <property name="prefix" value="/"/>
            <property name="suffix" value=".jsp"/>
        </bean>
7.源码包三层模式开发。。。
目录
相关文章
|
12月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
1642 1
Spring boot 使用mybatis generator 自动生成代码插件
|
12月前
|
Java 数据库连接 API
Java 对象模型现代化实践 基于 Spring Boot 与 MyBatis Plus 的实现方案深度解析
本文介绍了基于Spring Boot与MyBatis-Plus的Java对象模型现代化实践方案。采用Spring Boot 3.1.2作为基础框架,结合MyBatis-Plus 3.5.3.1进行数据访问层实现,使用Lombok简化PO对象,MapStruct处理对象转换。文章详细讲解了数据库设计、PO对象实现、DAO层构建、业务逻辑封装以及DTO/VO转换等核心环节,提供了一个完整的现代化Java对象模型实现案例。通过分层设计和对象转换,实现了业务逻辑与数据访问的解耦,提高了代码的可维护性和扩展性。
467 1
|
11月前
|
SQL Java 数据库连接
Spring、SpringMVC 与 MyBatis 核心知识点解析
我梳理的这些内容,涵盖了 Spring、SpringMVC 和 MyBatis 的核心知识点。 在 Spring 中,我了解到 IOC 是控制反转,把对象控制权交容器;DI 是依赖注入,有三种实现方式。Bean 有五种作用域,单例 bean 的线程安全问题及自动装配方式也清晰了。事务基于数据库和 AOP,有失效场景和七种传播行为。AOP 是面向切面编程,动态代理有 JDK 和 CGLIB 两种。 SpringMVC 的 11 步执行流程我烂熟于心,还有那些常用注解的用法。 MyBatis 里,#{} 和 ${} 的区别很关键,获取主键、处理字段与属性名不匹配的方法也掌握了。多表查询、动态
333 0
|
SQL Java 数据库
解决Java Spring Boot应用中MyBatis-Plus查询问题的策略。
保持技能更新是侦探的重要素质。定期回顾最佳实践和新技术。比如,定期查看MyBatis-Plus的更新和社区的最佳做法,这样才能不断提升查询效率和性能。
717 1
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
1153 0
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
831 2
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
822 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
933 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
3505 2
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
Java 数据库连接 mybatis
Springboot整合Mybatis,MybatisPlus源码分析,自动装配实现包扫描源码
该文档详细介绍了如何在Springboot Web项目中整合Mybatis,包括添加依赖、使用`@MapperScan`注解配置包扫描路径等步骤。若未使用`@MapperScan`,系统会自动扫描加了`@Mapper`注解的接口;若使用了`@MapperScan`,则按指定路径扫描。文档还深入分析了相关源码,解释了不同情况下的扫描逻辑与优先级,帮助理解Mybatis在Springboot项目中的自动配置机制。
1380 1
Springboot整合Mybatis,MybatisPlus源码分析,自动装配实现包扫描源码