Maven項目管理:SpringMVC+Mybatis+Velocity整合筆記

MelEQQL 8年前發布 | 75K 次閱讀 MyBatis Maven 項目構建 Spring MVC

來自: http://www.cnblogs.com/admol/p/5246032.html

Maven創建項目

略…

具體過程可參考 用Maven創建第一個web項目

</div>

配置Spring MVC

  1. 導入Spring MVC 需要的包在pom.xml 文件下加入:

       <!-- spring mvc begin -->
    <dependency>
     <groupId>org.springframework</groupId>
     <artifactId>spring-webmvc</artifactId>
     <version>3.2.6.RELEASE</version>
    </dependency>
    <dependency>
     <groupId>org.springframework</groupId>
     <artifactId>spring-context-support</artifactId>
     <version>3.2.6.RELEASE</version>
    </dependency>
    <!-- spring mvc end -->
  2. 添加baseweb-servlet.xml文件

    在WEB-INF 目錄下 添加 baseweb-servlet.xml 文件,啟用注解和添加自動包掃描

    <!-- 啟用springmvc注解 -->
    <context:annotation-config />
    
    <!-- 配置掃描路徑 -->
    <context:component-scan base-package="net.admol.baseweb"></context:component-scan>

更多詳細可參考 使用springMVC實現簡單的登錄例子

添加Velocity

  1. 在pom.xml 文件下加入:

    <!-- velocity begin -->
    <dependency>
     <groupId>org.apache.velocity</groupId>
     <artifactId>velocity</artifactId>
     <version>1.6.2</version>
    </dependency>
    <dependency>
     <groupId>org.apache.velocity</groupId>
     <artifactId>velocity-tools</artifactId>
     <version>1.3</version>
    </dependency>
    <!-- velocity end -->
  2. 在 baseweb-servlet.xml 文件加入velocity配置:

    <!-- velocity view config -->
    <bean id="velocityViewResolver"
     class="org.springframework.web.servlet.view.velocity.VelocityLayoutViewResolver">
     <property name="cache" value="true" />
     <property name="exposeSpringMacroHelpers" value="true" />
     <property name="requestContextAttribute" value="true" />
     <property name="exposeSessionAttributes" value="true" />
     <property name="prefix" value=""></property>
     <property name="order" value="1"></property>
     <property name="allowSessionOverride" value="true"></property>
     <property name="viewNames">
     <list>
     <value>*.vm</value>
     <value>*.htm</value>
     </list>
     </property>
     <property name="contentType" value="text/html; charset=UTF-8"></property>
     <property name="toolboxConfigLocation" value="/WEB-INF/config/velocity-toolbox.xml"></property>
     <property name="viewClass"
     value="org.springframework.web.servlet.view.velocity.VelocityLayoutView" />
     <property name="layoutUrl" value="layout/layout.vm" />
    </bean>
    
    <bean id="velocityConfig"
     class="org.springframework.web.servlet.view.velocity.VelocityConfigurer">
     <property name="resourceLoaderPath" value="/WEB-INF/velocity/" />
     <property name="velocityProperties">
     <props>
     <prop key="input.encoding">UTF-8</prop>
     <prop key="output.encoding">UTF-8</prop>
     <prop key="parser.pool.size">100</prop>
     <prop key="velocimacro.library">macros/macros.vm</prop>
     <prop key="velocimacro.library.autoreload">true</prop>
     </props>
     </property>
    </bean>
  3. 添加 velocity-toolbox.xml 文件

    在  /src/main/webapp/WEB-INF 目錄下添加一個  config 目錄,在 config 下添加一個名為 velocity-toolbox.xml 的文件:

    <?xml version="1.0"?>
    <toolbox> 
     <tool>
     <key>dateTool</key>
     <scope>request</scope>
     <class>org.apache.velocity.tools.generic.DateTool</class>
     </tool>
    </toolbox>
  4. 添加layout.vm

    在  /src/main/webapp/WEB-INF 目錄下添加一個  velocity 目錄, velocity 目下添加一個 layout 目錄,目錄下新建一個 layout.vm 文件,內容如:

    <!DOCTYPE HTML>
    <html>
    <head>
     <meta charset="UTF-8"> 
     <title>admol</title>
    </head>
    <body class="warp">
     <div class="container">
     <div class="content">
     ${screen_content}
     </div>
     </div>
     </body>
    </html>
  5. 配置macros.vm(非必須)

    在 /WEB-INF/velocity/macros/ 目錄添加  macros.vm 文件

  6. 測試Test.java

    @Controller
    public class Test {
     @RequestMapping(value = "/test.htm")
     public String test(ModelMap mdelMap) {
     mdelMap.addAttribute("test", "hello , this is velocity!");
     return "/testView/testVelocity.vm";
     }
    }

    編寫頁面

    新建 /velocity/testView/testVelocity.vm 頁面:

    $!test

    啟動tomcat ,測試結果:

    整合velocity測試結果

https://github.com/mybatis/generator/releases

整合Mybatis

  1. 引入包在pom.xml文件加入:

       <!-- mysql -->
     <dependency>
     <groupId>mysql</groupId>
     <artifactId>mysql-connector-java</artifactId>
     <version>5.1.31</version>
    </dependency>
    
    <!-- mybatis -->
     <dependency>
     <groupId>org.mybatis</groupId>
     <artifactId>mybatis-spring</artifactId>
     <version>1.2.2</version>
    </dependency>
    <dependency>
     <groupId>org.mybatis</groupId>
     <artifactId>mybatis</artifactId>
     <version>3.2.0</version>
    </dependency>
     <dependency>
     <groupId>commons-dbcp</groupId>
     <artifactId>commons-dbcp</artifactId>
     <version>1.2</version>
    </dependency>
    
    <!-- spring jdbc -->
    <dependency>
     <groupId>org.springframework</groupId>
     <artifactId>spring-jdbc</artifactId>
     <version>3.2.6.RELEASE</version>
    </dependency>
  2. 準備數據庫

    創建一個名為 demo 的數據庫

    <!-- 創建表 -->
    CREATE TABLE `user` (
     `id` varchar(32) NOT NULL,
     `user_id` varchar(32) NOT NULL,
     `user_name` varchar(64) NOT NULL,
     PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    <!-- 插入測試數據 -->
    INSERT INTO `user` VALUES ('1', '1000', 'admol');
  3. 添加配置文件

    在  /src/main/resources 下新建folder : spring ,新建  spring-dao.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: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-3.0.xsd 
     http://www.springframework.org/schema/tx
     http://www.springframework.org/schema/tx/spring-tx-3.1.xsd
     http://www.springframework.org/schema/aop 
     http://www.springframework.org/schema/aop/spring-aop-3.0.xsd"
     default-autowire="byName">
    
     <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" 
     destroy-method="close"> 
     <property name="driverClassName" value="com.mysql.jdbc.Driver" /> 
     <property name="url" value="jdbc:mysql://127.0.0.1:3306/demo" /> 
     <property name="username" value="test" /> 
     <property name="password" value="123456" /> 
     <!-- 初始化連接大小 --> 
     <property name="initialSize" value="5"></property> 
     <!-- 連接池最大數量 --> 
     <property name="maxActive" value="20"></property> 
     <!-- 連接池最大空閑 --> 
     <property name="maxIdle" value="20"></property> 
     <!-- 連接池最小空閑 --> 
     <property name="minIdle" value="1"></property> 
     <!-- 獲取連接最大等待時間 --> 
     <property name="maxWait" value="60000"></property> 
     </bean> 
    
     <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> 
     <property name="dataSource" ref="dataSource" /> 
     <!-- 自動掃描mapper.xml文件 -->
     <property name="mapperLocations" value="classpath:sqlmap/*.xml"></property> 
     </bean>
    
     <!-- DAO接口所在包名,Spring會自動查找其下的類 -->
     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> 
     <property name="basePackage" value="net.admol.baseweb.dal.dao" /> 
     <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property> 
     </bean>
    </beans>

    在web.xml加入:

    <listener>
     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <context-param>
     <param-name>contextConfigLocation</param-name>
     <param-value>
     classpath*:spring/*.xml
     </param-value>
    </context-param>
  4. 生成do、DAO、Mapping

    在  /src/main/resources 下新建folder :  sqlmap ,

    新建包 net.admol.baseweb.dal.dao 和 net.admol.baseweb.dal.dateobject

    配置  Mybatis-generator.xml 點擊查看代碼

    下載相應包: mybatis-generator-core-1.3.2.jar 和 mysql-connector-java-5.1.31.jar 并與 generatorConfig.xml 文件位于同一目錄下,

    然后執行命令 java -jar mybatis-generator-core-x.x.x.jar -configfile generatorConfig.xml -overwrite 更多命令使用

  5. 測試

    修改  Test.java :

    @Controller
    public class Test {
     @Autowired
     private UserMapper userMapper;
    
     @RequestMapping(value = "/test.htm")
     public String test(ModelMap mdelMap) {
     mdelMap.addAttribute("test", "hello , this is velocity!!!");
     testDB(mdelMap);
     return "/testView/testVelocity.vm";
     }
    
     public void testDB(ModelMap mdelMap) {
     UserExample ss = new UserExample();
     ss.createCriteria().andUserIdEqualTo("1000");
     List<User> list = userMapper.selectByExample(ss);
     mdelMap.addAttribute("list", list);
     System.out.println("測試結果size:" + list.size());
     }
    }

修改 testVelocity.vm :

$!test

#foreach($userInfo in $!list)
 </br>
 $!{velocityCount}. $!userInfo.userName 
#end

啟動romcat,輸入 http://localhost:8080/baseweb/test.htm ,測試結果:

整合Mybatis測試結果

成功訪問數據庫!

</div> </div>

 本文由用戶 MelEQQL 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!