Maven搭建SpringMVC+Mybatis+freemarker项目详解
2017-03-16 10:30
681 查看
1、新建一个maven project ,选中maven-archetype-webapp,点击next
2、这里的Group Id就是大项目的id,ArifactId就是该项目的Id。就像一个大项目中有许多小项目组成一样。此时,我们的项目已经成型了,样子如下图:
让工程的JDK用本地的jdk;
让工程的字符集为UTF-8;
改变工程的目录顺序;
在工程上选择右键选中properties,选择Project Facets,勾选Dynamic Web Module
此时,我们看到目录中多了一个WebContent目录,由于使用maven构建,web目录是src/main/webapp,把WebContent下的内容拷贝到src/main/webapp,删除WebContent目录。
接下来,要配置web项目的发布目录,就是Deployment
Assembly,如图:
由于不需要test发布,WebContent目录没有了,所以这三项都删掉。并且增加src/main/webapp目录,和Maven
Dependenices,完成之后如下图:
于是,我们的工程就完全是一个web工程了。
自动生成表的Model,Mapping,Dao文件,并将其导入到项目的src/main/Java包中。
6.1加入数据库信息配置文件applicationContext.properties
6.2加入log4j信息配置文件log4j.properties
7
7.3 新建UserService类 以及实现类
接口:
实现类
测试成功 说明spring + mybatis配置成功
新建freemarker.xml
10.、Web容器web.xml配置
2、这里的Group Id就是大项目的id,ArifactId就是该项目的Id。就像一个大项目中有许多小项目组成一样。此时,我们的项目已经成型了,样子如下图:
3、完善项目
首先,完善目录,增加重要的sourceFolder,这个不是简单的Floder,这些文件夹是会参与编译的。增加src/main/java,src/test/resources,src/test/java目录。让目录变成标准的maven结构。如下图:让工程的JDK用本地的jdk;
让工程的字符集为UTF-8;
改变工程的目录顺序;
4、将工程变成web工程
在工程上选择右键选中properties,选择Project Facets,勾选Dynamic Web Module
此时,我们看到目录中多了一个WebContent目录,由于使用maven构建,web目录是src/main/webapp,把WebContent下的内容拷贝到src/main/webapp,删除WebContent目录。接下来,要配置web项目的发布目录,就是Deployment
Assembly,如图:
由于不需要test发布,WebContent目录没有了,所以这三项都删掉。并且增加src/main/webapp目录,和Maven
Dependenices,完成之后如下图:
于是,我们的工程就完全是一个web工程了。
5、修改pom.xml添加对应的包依赖
pom.xml<pre class="html" name="code"><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>Framework_test</groupId> <artifactId>frame</artifactId> <packaging>war</packaging> <version>0.0.1-SNAPSHOT</version> <name>frame Maven Webapp</name> <url>http://maven.apache.org</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <spring.version>4.1.4.RELEASE</spring.version> <jackson.version>2.5.0</jackson.version> </properties> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> <!-- spring --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>${spring.version}</version> </dependency> </pre><br> <pre></pre> <pre class="html" name="code"></pre><pre class="html" name="code"></pre>< 4000 ;pre class="html" name="code"></pre><pre class="html" name="code"></pre><pre class="html" name="code"></pre><pre class="html" name="code"></pre><pre class="html" name="code"></pre><pre class="html" name="code"></pre><pre class="html" name="code"></pre><pre class="html" name="code"> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>3.2.4.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>${spring.version}</version> <scope>test</scope> </dependency> <!-- mybatis 包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.2.8</version> </dependency> <!--mybatis spring 插件 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.2.2</version> </dependency> <!-- mysql连接 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.34</version> </dependency> <!-- 数据源 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.0.12</version> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.8.4</version> </dependency> <!-- log4j --> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> <!-- servlet --> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>3.0-alpha-1</version> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!-- json --> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.3</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>${jackson.version}</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>${jackson.version}</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>${jackson.version}</version> </dependency> <!-- 文件上传 --> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.2.2</version> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.1</version> </dependency> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.5</version> </dependency> <!-- Freemarker --> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.19</version> </dependency> </dependencies> <build> <finalName>frame</finalName> <plugins> <!-- Run the JUnit unit tests in an isolated classloader --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-surefire-plugin</artifactId> <version>2.4.2</version> <configuration> <skipTests>true</skipTests> </configuration> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-war-plugin</artifactId> <version>2.3</version> <configuration> <webXml>src/main/webapp/WEB-INF/web.xml</webXml> </configuration> </plugin> <!-- generate java doc --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-javadoc-plugin</artifactId> <version>2.9.1</version> <configuration> <javadocDirectory>target/javadoc</javadocDirectory> <reportOutputDirectory>target/javadoc</reportOutputDirectory> <charset>UTF-8</charset> <encoding>UTF-8</encoding> <docencoding>UTF-8</docencoding> <show>private</show> </configuration> </plugin> <plugin> <groupId>org.mortbay.jetty</groupId> <artifactId>maven-jetty-plugin</artifactId> <version>6.1.25</version> <configuration> <scanIntervalSeconds>10</scanIntervalSeconds> <stopKey>${project.groupId}:${project.artifactId}</stopKey> <stopPort>9999</stopPort> <contextPath>/${project.artifactId}</contextPath> <connectors> <connector implementation="org.mortbay.jetty.nio.SelectChannelConnector"> <port>8080</port> <maxIdleTime>3600000</maxIdleTime> </connector> </connectors> <systemProperties> <systemProperty> <name>slf4j</name> <value>true</value> </systemProperty> <systemProperty> <name>app.config</name> <value>${app.config}</value> </systemProperty> <systemProperty> <name>http.nonProxyHosts</name> <value>localhost|127.0.0.1 </value> </systemProperty> </systemProperties> </configuration> </plugin> </plugins> </build> </project>
6、使用Generator自动生成Mybatis相关表信息
6.1加入数据库信息配置文件applicationContext.properties
jdbc_driverClassName=com.mysql.jdbc.Driver jdbc_url=jdbc:mysql://localhost:3306/frameworker?useUnicode=true&characterEncoding=utf-8 jdbc_username=root jdbc_password=123%aa #=======================# # Logging Configuration # #=======================# log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target=System.out log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n log4j.rootLogger=debug, stdout log4j.logger.org.apache=info log4j.logger.org.springframework=info
6.2加入log4j信息配置文件log4j.properties
### set log levels ### log4j.rootLogger = INFO , C , D , E ### console ### log4j.appender.C = org.apache.log4j.ConsoleAppender log4j.appender.C.Target = System.out log4j.appender.C.layout = org.apache.log4j.PatternLayout log4j.appender.C.layout.ConversionPattern = [police][%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n ### log file ### log4j.appender.D = org.apache.log4j.DailyRollingFileAppender log4j.appender.D.File = ../logs/springmvc-mybatis-demo.log log4j.appender.D.Append = true log4j.appender.D.Threshold = INFO log4j.appender.D.layout = org.apache.log4j.PatternLayout log4j.appender.D.layout.ConversionPattern = [police][%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n ### exception ### log4j.appender.E = org.apache.log4j.DailyRollingFileAppender log4j.appender.E.File = ../logs/springmvc-mybatis-demo_error.log log4j.appender.E.Append = true log4j.appender.E.Threshold = ERROR log4j.appender.E.layout = org.apache.log4j.PatternLayout log4j.appender.E.layout.ConversionPattern = [police][%p] [%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n
7
7.1引入Spring并配置相关属性
在src/main/resources创建spring的配置文件,这里创建了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" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd"> <!--引入jdbc配置文件--> <context:property-placeholder location="classpath:applicationContext.properties"></context:property-placeholder> <!--自动扫描含有@Service将其注入为bean--> <context:component-scan base-package="com.himal"/> </beans>
7.2配置Mybatis相关信息
以下是mybatis的配置信息:spring-mybatis.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: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-4.1.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.1.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd "> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" > <property name="driverClassName"> <value>${jdbc_driverClassName}</value> </property> <property name="url"> <value>${jdbc_url}</value> </property> <property name="username"> <value>${jdbc_username}</value> </property> <property name="password"> <value>${jdbc_password}</value> </property> <!-- 连接池最大使用连接数 --> <property name="maxActive"> <value>20</value> </property> <!-- 初始化连接大小 --> <property name="initialSize"> <value>1</value> </property> <!-- 获取连接最大等待时间 --> <property name="maxWait"> <value>60000</value> </property> <!-- 连接池最大空闲 --> <property name="maxIdle"> <value>20</value> </property> <!-- 连接池最小空闲 --> <property name="minIdle"> <value>3</value> </property> <!-- 自动清除无用连接 --> <property name="removeAbandoned"> <value>true</value> </property> <!-- 清除无用连接的等待时间 --> <property name="removeAbandonedTimeout"> <value>180</value> </property> <!-- 连接属性 --> <property name="connectionProperties"> <value>clientEncodi ddd3 ng=UTF-8</value> </property> </bean> <!-- mybatis文件配置,扫描所有mapper文件 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 --> <property name="mapperLocations" value="classpath:com/himal/dao/mapper/interfaces/*.xml" /><!-- configLocation为mybatis属性 mapperLocations为所有mapper--> </bean> <!-- spring与mybatis整合配置,扫描所有dao --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.himal.dao.mapper.interfaces" /> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" /> </bean> <!-- 配置事务管理器 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> </beans>
7.3 新建UserService类 以及实现类
接口:
package com.himal.service.interfaces; import com.himal.dao.mapper.bo.Member; public interface UserService { int insert(Member record); }
实现类
package com.himal.service; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import com.himal.dao.mapper.bo.Member; import com.himal.dao.mapper.interfaces.MemberMapper; import com.himal.service.interfaces.UserService; @Service public class UserServiceImpl implements UserService { @Autowired private MemberMapper memberMapper; @Override public int insert(Member record) { memberMapper.insert(record); return 0; } }
7.4 测试Spring和Mybatis配置
在src/test/java中写测试类,检测是否能够读出数据,若能读出则证明Spring+Mybatis整合成功。package com.himal.test; import java.util.Date; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import com.himal.dao.mapper.bo.Member; import com.himal.service.interfaces.UserService; @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations={"classpath:applicationContext.xml"}) public class TestUserService { @Autowired private UserService userService; @Test public void testInsert(){ Member record = new Member(); record.setBirthday(new Date()); record.setId(2l); record.setCreateDate(new Date()); record.setModifyDate(new Date()); int insert = userService.insert(record ); System.out.println(insert); } }
测试成功 说明spring + mybatis配置成功
8.引入SpringMVC
8.1 配置SpringMVC配置信息
SpringMVC的配置信息主要包括控制层Controller的bean管理,视图层和控制层配置等等,下面是spring-mvc.xml信息:<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd"> <!-- 自动扫描controller包下的所有类,如果@Controller注入为bean --> <context:component-scan base-package="com.himal.controller" /> <!-- 避免IE执行AJAX时,返回JSON出现下载文件 --> <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/html;charset=UTF-8</value> </list> </property> </bean> <!-- 启动Spring MVC的注解功能,完成请求和注解POJO的映射 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <!-- json转换器 --> <ref bean="mappingJacksonHttpMessageConverter" /> </list> </property> </bean> <!-- 配置多文件上传 --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="defaultEncoding"> <value>UTF-8</value> </property> <property name="maxUploadSize"> <!-- 上传文件大小限制为31M,31*1024*1024 --> <value>32505856</value> </property> <property name="maxInMemorySize"> <value>4096</value> </property> </bean> </beans>
9.配置freemarker
1在com.himal.frame.implementation.view新建AppFreemarkerView类
package com.himal.frame.implementation.view; import java.util.Map; import javax.servlet.http.HttpServletRequest; import org.springframework.web.servlet.view.freemarker.FreeMarkerView; public class AppFreemarkerView extends FreeMarkerView { public static final String CONTEXT_PATH = "base"; @SuppressWarnings("all") protected void exposeHelpers(Map model, HttpServletRequest request) throws Exception { super.exposeHelpers(model, request); model.put(CONTEXT_PATH, request.getContextPath()); } }
新建freemarker.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" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd"> <!-- 向spring中注入默认注解映射处理器以及把指定控制包下面的控制层注入到spring中 --> <mvc:annotation-driven /> <mvc:default-servlet-handler/> <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <property name="templateLoaderPath" value="/WEB-INF/freemarker/" /><!-- 将/WEB-INF/freemarker/目录下的文件当作view --> </bean> <bean id="viewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver"> <property name="cache" value="true" /> <property name="prefix" value="" /> <property name="suffix" value=".ftl" /> <property name="viewClass" value="com.himal.frame.implementation.view.AppFreemarkerView" /><!-- 解决view 中base路径问题 --> </bean> </beans>
9.2
新建web-context.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" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <import resource="spring.xml" /> <import resource="spring-mybatis.xml" /> <import resource="spring-mvc.xml" /> <import resource="freemarker.xml" /> </beans>
10.、Web容器web.xml配置
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>WebPro</display-name> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:web-context.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> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- 防止spring内存溢出监听器 --> <listener> <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class> </listener> <servlet> <servlet-name>rest</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value> classpath:spring-mvc.xml </param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!-- 配置session超时时间,单位分钟 --> <session-config> <session-timeout>30</session-timeout> </session-config> <servlet-mapping> <servlet-name>rest</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>SendReportServlet</servlet-name> <url-pattern>/SendReportServlet</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>LoginServlet</servlet-name> <url-pattern>/login</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <!-- 错误跳转页面 --> <error-page> <error-code>404</error-code> <location>/404_page.jsp</location> </error-page> <error-page> <!-- 没有访问权限,访问被禁止 --> <error-code>405</error-code> <location>/405.html</location> </error-page> <error-page> <!-- 内部错误 --> <error-code>500</error-code> <location>/500_page.jsp</location> </error-page> </web-app>
相关文章推荐
- Maven搭建SpringMVC+Mybatis+freemarker项目详解
- Maven搭建SpringMVC+Spring+Mybatis项目详解
- 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+SpringMVC项目详解
- Spring+SpringMVC+Mybatis搭建Maven项目详解
- Maven搭建Spring+SpringMVC+Mybatis+Shiro项目详解
- 基于Maven项目,搭建Spring+SpringMVC+MyBatis的WEB项目(待更新)
- Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建
- Spring+Spring MVC+Mybatis+Maven搭建多模块项目(一)
- 基于maven的springMvc+Mybatis,搭建项目的时候发现一些问题这里例举下
- Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建
- Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建
- maven+springMVC+mybatis+velocity+mysql+junit项目框架搭建
- Java后台开发<二>:Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建
- SSM(Spring+SpringMVC+Mybatis)+Maven项目搭建
- Spring+SpringMVC+Mybatis+Maven搭建项目
- 用spring mvc+mybatis+maven搭建项目骨架
- Maven搭建Spring+SpringMVC+Mybatis详解,成功搭建me
- 搭建springMVC+Mybatis的Maven项目过程中遇到的问题汇总。
- 记录-项目java项目框架搭建的一些问题(maven+spring+springmvc+mybatis)
- Spring MVC+Maven+Freemarker+Mybatis开发环境搭建