Struts2+Spring3.0+MyBatis3.0平台搭建

Struts2采用的版本是2.2.3 java

Spring采用的版本是3.0.5 web

MyBatis,便是之前的iBatis。采用的版本是3.0.5 spring

个人习惯呢是一个一个来,先让struts在系统上跑起来,Struts2的文档让偶有点生气了,由于在之前的Struts2版本中 sql

要这5个jar包就能够了,如今在新版中要的jar包更多了,每次更具服务器启动的错误信息去找须要的jar包,不过还好没多久就找全了。将commons-io,commons-lang,commons-fileupload,javassist。加上就差很少能够了。那些个配置文件还都是同样的使用,网上都是不少的,就很少说了。 服务器

 

接着就是加入spring了。这个就先将那些aop,core,orm,jdbc,beans,context,固然还有struts-spring-plugin这个插件jar包加入进来,spring的配置文件固然也不赘述了,启动服务器吧,出了错就通常应该就是没有jar包,挨个挨个找,加进来就能够了。有些人可能就以为烦了,让我本身一个一个试还看这个干啥。我以为凡事都要本身亲自动手去坐坐,如今时几个比较经常使用的框架在网上很容易就能找到,若是是不多人用的呢,又很缺乏文档呢,仍是得靠本身的慢慢摸索。 mybatis

配置spring固然在web.xml中少不了这个监听器 app

有了spring固然能够将struts中配置action时须要的对象在spring容器中管理了。 框架

在struts配置action时以下 ide

在spring中配置这个action实例,可是请注意,action的scope是prototype,可是在这里就不能偷懒不配置action中调用的service实例 this

 

再下来就是在这个平台中加入MyBatis了。我也没有接触过这个框架,只是想试试,可是用了以后感受真得很不错,本身写SQL,可是本身不用去将查询出来的ResultSet封装成对象。

看它官方的文档spring在和它集成是用的是Annotation,可是没看明白,本身比较笨吧,仍是使用的是xml文件去配置的。将mybatis.jar和mybatis-spring.jar加入系统就能够了。spring中配置的数据源使用的是DBPooL。spring的配置文件以下:

 

在Configuration.xml文件中只须要配置<mapper></mapper>就能够了。

在dao层的类里面为了图方便就直接引用了sqlSessionFactory。上面说到的AccountMapper.xml配置以下

<?xml version="1.0" encoding="UTF-8" ?>   
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">   
<mapper namespace="org.entity.Account">   
    <select id="selectAccount" parameterType="String" resultType="org.entity.Account">  
        select * from account where username =#{username}  
    </select>  
    <insert id="insertAccount">  
        insert account (username,password) values (#{username},#{password})  
    </insert>   
</mapper>

而在dao类中的代码以下:

private SqlSessionFactory sqlSessionFactory;  
public final void setSqlSessionFactory(SqlSessionFactory sqlSessionFactory) {  
    this.sqlSessionFactory = sqlSessionFactory;  
}  
  
  
@Override  
public void selectAccount(String username) {  
    SqlSession sqlSession = sqlSessionFactory.openSession();  
    Account account = (Account) sqlSession.selectOne("org.entity.Account.selectAccount", "sanmao");  
    System.out.println(account);  
sqlSession.close();
}

这里还有个很方便的事情就是不用去配置什么对象属性和表结构的映射关系。

整个系统搭建好了,引入的jar包以下图(里面可能会有多余的jar包,由于在缺乏包时往里加包时,肯能往删除了):

 

相关文章
相关标签/搜索