idea中怎么整合springspringmvcmybatis
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了idea中怎么整合springspringmvcmybatis相关的知识,希望对你有一定的参考价值。
完成基本的SpringMVC + spring + MyBatis框架整合数据库使用mysql
加入阿里巴巴的druid数据库连接池
使用gson作为json解析工具
实现日志输出
maven依赖的版本管理
第一步: 使用idea的maven创建一个基本的web工程.
打开Idea在欢迎界面选择创建一个新的Project或者是(在菜单界面选择:New→Project),这是会出现一个界面如下图所示:
maven新建WebApp项目第一步
如上图所示,我们需要勾选的地方已经使用红色框标注出来.
最左边的是maven,是我们需要使用的项目构建工具.
勾选右边上面的Create from archetype,我们才能在下面选择我们需要构建成什么类型的项目.
接着我们选中maven-archetype-webapp,这时候我们的项目类型就确定为是web项目.
需要注意一点,我上面图中没标注出来的Project SDK,这里是选择我们开发的JDK版本. 参考技术A 完成基本的SpringMVC + spring + MyBatis框架整合
数据库使用MySQL
加入阿里巴巴的druid数据库连接池
使用gson作为json解析工具
实现日志输出
maven依赖的版本管理
第一步: 使用idea的maven创建一个基本的web工程.
打开Idea在欢迎界面选择创建一个新的Project或者是(在菜单界面选择:New→Project),这是会出现一个界面如下图所示:
maven新建WebApp项目第一步
如上图所示,我们需要勾选的地方已经使用红色框标注出来.
最左边的是maven,是我们需要使用的项目构建工具.
勾选右边上面的Create from archetype,我们才能在下面选择我们需要构建成什么类型的项目.
接着我们选中maven-archetype-webapp,这时候我们的项目类型就确定为是web项目.
需要注意一点,我上面图中没标注出来的Project SDK,这里是选择我们开发的JDK版本.本回答被提问者采纳
使用 IDEA和Maven 整合SSH框架
1.创建web工程
一路next 下去就行。完成后,IDEA会自动构建maven工程。
2.创建如下项目结构
需要将 java文件夹设置为SourcesRoot目录,否则无法创建package
设置操作如下:选择文件夹,右击。
3.在pom.xml文件中引入框架包
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.ssh</groupId> <artifactId>ssh</artifactId> <packaging>war</packaging> <version>1.0-SNAPSHOT</version> <name>ssh Maven Webapp</name> <url>http://maven.apache.org</url> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> <!-- hibernate --> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-core</artifactId> <version>5.2.12.Final</version> </dependency> <!-- struts2 --> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-core</artifactId> <version>2.5.14.1</version> </dependency> <!-- struts2 spring 整合的核心包--> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-spring-plugin</artifactId> <version>2.5.14.1</version> </dependency> <!-- spring --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-expression</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>cglib</groupId> <artifactId>cglib-nodep</artifactId> <version>2.1_3</version> </dependency> <!--spring aop包 注释方式使用事务管理 可以不引用--> <dependency> <groupId>aspectj</groupId> <artifactId>aspectjrt</artifactId> <version>1.5.0</version> </dependency> <dependency> <groupId>aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.5.0</version> </dependency> <!-- 添加对数据库的支持 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.0.5</version> </dependency> <!-- https://mvnrepository.com/artifact/c3p0/c3p0 --> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <version>0.9.1.2</version> </dependency> </dependencies> <build> <finalName>ssh</finalName> </build> </project>
4.配置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> <display-name>ssh</display-name> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring.xml</param-value> </context-param> <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> </web-app>
5.配置spring的核心配置文件spring.xml,配置文件中扫描,注入各个javaBean,并且管理了hibernate的数据源和事务
--- jdbc配置文件 jdbc.properties
mysql.driverClassName = com.mysql.jdbc.Driver mysql.url = jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8 mysql.username = root mysql.password = 密码
<?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:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop" 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 "> <context:component-scan base-package="com.ssh.action"></context:component-scan> <context:component-scan base-package="com.ssh.service"></context:component-scan> <context:component-scan base-package="com.ssh.dao"></context:component-scan> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location" value="classpath:jdbc.properties"/> </bean> <!-- data connection setting --> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <property name="driverClass" value="${mysql.driverClassName}"></property> <property name="jdbcUrl" value="${mysql.url}"></property> <property name="user" value="${mysql.username}"></property> <property name="password" value="${mysql.password}"></property> <!-- 设置数据库连接池的最大连接数 --> <property name="maxPoolSize"> <value>50</value> </property> <!-- 设置数据库连接池的最小连接数 --> <property name="minPoolSize"> <value>5</value> </property> <!-- 设置数据库连接池的初始化连接数 --> <property name="initialPoolSize"> <value>5</value> </property> <!-- 设置数据库连接池的连接最大空闲时间 --> <property name="maxIdleTime"> <value>20</value> </property> <!-- c3p0缓存Statement的数量数 --> <property name="maxStatements"> <value>50</value> </property> <!-- 当连接池里面的连接用完的时候,C3P0一下获取新的连接数 --> <property name="acquireIncrement"> <value>20</value> </property> </bean> <!-- hibernate 管理--> <bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean"> <!-- 引用上面设置的数据源 --> <property name="dataSource"> <ref bean="dataSource"/> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> <prop key="hibernate.autoReconnect">true</prop> <prop key="hibernate.connection.autocommit">true</prop> <prop key="hibernate.hbm2ddl.auto">update</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <!-- 解决session关闭问题 --> <prop key="hibernate.enable_lazy_load_no_trans">true</prop> <!-- spring 和 hibernate 整合的时候默认就是使用线程的,下面这一行不用写,写了反而要报错,此外 sessionFaction,不能使用openSession 既不能保存数据到数据库,还不能实现事务功能 --> <!--<prop key="current_session_context_class">thread</prop>--> <prop key="hibernate.max_fetch_depth">3</prop> <prop key="hibernate.connection.url" >jdbc:mysql://localhost:3306/test</prop> <prop key="hibernate.connection.driver_class">com.mysql.jdbc.Driver</prop> </props> </property> <!-- 包扫描的方式加载注解类 --> <property name="packagesToScan"> <list> <value>com.ssh.model</value> </list> </property> <property name="mappingLocations"> <list> <value>classpath:com/ssh/model/User.hbm.xml</value> </list> </property> </bean> <!-- 用注解来实现事物管理 --> <bean id="txManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory"/> </bean> <tx:annotation-driven transaction-manager="txManager"/> <!--<tx:advice id="txAdvice" transaction-manager="txManager">--> <!--<tx:attributes>--> <!--<tx:method name="*" read-only="false"/>--> <!--</tx:attributes>--> <!--</tx:advice>--> <!--<aop:config>--> <!--<aop:pointcut id="pt" expression="execution(* com.ssh.service.impl.*.*(..))"/>--> <!--<aop:advisor advice-ref="txAdvice" pointcut-ref="pt"/>--> <!--</aop:config>--> </beans>
6.配置struts2的核心配置文件struts.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.5//EN" "http://struts.apache.org/dtds/struts-2.5.dtd"> <struts> <!-- 修改常量管理struts 中的action的工程,这个常量的使用,必须引入 spring和struts的整合包,不然spring无法管理struts2 Action 中的实体类--> <constant name="struts.objectFactory" value="spring" />
<package name="user" extends="struts-default" namespace="/"> <action name="user_*" class="userAction" method="{1}"> <result name="success">/test.jsp</result> <allowed-methods>m1,saveUser</allowed-methods><!-- struts 2.5 之后,使用通配符必须加上这一行 ,否则无法使用通配符访问--> </action> </package> </struts>
7.使用IDEA生成数据库对应实体类和hibernate的映射文件
第一步:连接数据库
选择后边侧边栏的Database
第二步,生成映射文件
选中左边侧边栏的Persistence菜单
等待生成映射文件,完成后,在对应的包 下面生成如下文件
USer 代码
/** * FileName: User * Author: GET_CHEN * Date: 2017/12/13 13:45 * Description: */ package com.ssh.model; import以上是关于idea中怎么整合springspringmvcmybatis的主要内容,如果未能解决你的问题,请参考以下文章在IDEA中SpringBoot整合Junit4,运行一个@Test注解的方法结果这个方法运行了两次?