`
medbricom
  • 浏览: 105355 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

struts2.1.8+mybatis3.0+spring3.0(全注解)小例子

阅读更多
项目截图



所需架包
aopalliance.jar
asm-1.5.3.jar
aspectjrt.jar
aspectjweaver.jar
c3p0-0.9.1.jar
cglib-2.1_3.jar
com.springsource.org.apache.commons.dbcp-1.2.2.osgi.jar
com.springsource.org.apache.commons.logging-1.1.1.jar
com.springsource.org.apache.commons.pool-1.5.3.jar
commons-fileupload-1.2.1.jar
commons-io-1.3.2.jar
freemarker-2.3.15.jar
junit-3.8.1.jar
log4j-1.2.15.jar
mybatis-3.0.3-SNAPSHOT.jar
mybatis-3.0.4.jar
mybatis-spring-1.0.0-RC2.jar
ognl-2.7.3.jar
ojdbc14.jar
org.springframework.aop-3.0.4.RELEASE.jar
org.springframework.asm-3.0.4.RELEASE.jar
org.springframework.context-3.0.4.RELEASE.jar
org.springframework.expression-3.0.4.RELEASE.jar
org.springframework.test-3.0.4.RELEASE.jar
org.springframework.web-3.0.4.RELEASE.jar
slf4j-api-1.5.10.jar
slf4j-log4j12-1.5.10.jar
spring-beans-3.0.4.RELEASE.jar
spring-core-3.0.4.RELEASE.jar
spring-jdbc-3.0.4.RELEASE.jar
spring-tx-3.0.4.RELEASE.jar
struts2-convention-plugin-2.1.8.1.jar
struts2-core-2.1.8.1.jar
struts2-spring-plugin-2.1.8.1.jar
struts-getterAndSetter-plugin.jar
xwork-core-2.1.6.jar


对应的配置文件
applicationContext.xml:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:jee="http://www.springframework.org/schema/jee"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/jee
http://www.springframework.org/schema/jee/spring-jee-2.5.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd"
default-autowire="byName" default-lazy-init="true">

<!-- 定义受环境影响易变的变量 -->
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<!-- 标准配置 -->
<value>classpath:com/medbri/mss/config/jdbc.properties</value>
</list>
</property>
</bean>

<!-- 使用annotation 自动注册bean,并保证@Required,@Autowired的属性被注入 -->
<context:component-scan base-package="com.medbri.mss" />

<!-- 数据源配置,使用应用内的DBCP数据库连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<!-- Connection Info -->
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />

<!-- Connection Pooling Info -->
<property name="initialSize" value="5" />
<property name="maxActive" value="100" />
<property name="maxIdle" value="30" />
<property name="maxWait" value="500" />
<property name="defaultAutoCommit" value="false" />
</bean>

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:com/medbri/mss/config/mybatis-config.xml" />
<property name="dataSource" ref="dataSource" />
</bean>

<!-- 事务管理器配置,单数据源事务 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>

<bean id="iUsers" class="org.mybatis.spring.MapperFactoryBean">
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
<property name="mapperInterface" value="com.medbri.mss.dao.IUsers" />
</bean>

<!-- 使用annotation定义事务 -->
<!-- <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/> -->

<aop:config proxy-target-class="true">
<aop:advisor pointcut="execution(* com.medbri.mss.service..*Service.*(..))"
advice-ref="txAdvice" />
</aop:config>

<tx:advice id="txAdvice">
<tx:attributes>
<tx:method name="get*" read-only="true" />
<tx:method name="find*" read-only="true" />
<tx:method name="query*" read-only="true" />
<tx:method name="is*" read-only="true" />
<tx:method name="*" propagation="REQUIRED" />
</tx:attributes>
</tx:advice>
</beans>

struts.xml
<?xml version="1.0" encoding="GBK" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<!-- 设置 编码 -->
<constant name="struts.i18n.encoding" value="GBK" />
<!-- 与spring集成 -->
<constant name="struts.objectFactory" value="spring" />
<!-- 指定默认的父包 -->
<constant name="struts.convention.default.parent.package"
value="medbri-default" />
<!-- 设置convention插件默认的根包 -->
<constant name="struts.convention.package.locators" value="web" />
<!-- 搜索此配置下的所有包 -->
<constant name="struts.convention.package.locators.medbriPackage"
value="com.medbri.mss" />
<!-- 继承convention-default包,定义一个默认的拦截器,根据需要还可扩展 -->
<package name="medbri-default" extends="convention-default">
<interceptors>
<interceptor-stack name="medbriStack">
<interceptor-ref name="paramsPrepareParamsStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="medbriStack" />
<global-results>
<result name="suc">/common/sucess.jsp</result>
<result name="error">/common/error.jsp</result>
</global-results>
</package>
</struts>


mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<typeAliases>
<typeAlias alias="Users" type="com.medbri.mss.model.Users" />
</typeAliases>
<mappers>
<mapper resource="com/medbri/mss/dao/IUsers.xml" />
</mappers>
</configuration>

代码
action
@Results({
@Result(name = "userListWindow", type = UserAction.DISPATHCER, location = "/userList.jsp"),
@Result(name = "userUpdateWindow", type = UserAction.DISPATHCER, location = "/updateUser.jsp")
})
public class UserAction extends BaseAction<Users> {
@Autowired
private IUserService userService;
private Users users;

public Users getUsers() {
return users;
}

public void setUsers(Users users) {
this.users = users;
}

/**
*
*/
private static final long serialVersionUID = 1L;

/**
* 用户添加
*
* @return 返回转向信息
* @throws Exception
*             采用struts2异常处理抛出所有异常
*/
public String addUser() throws Exception {
userService.addUser(users);
getRequest().setAttribute("url","user!queryPageUser.action");
return "suc";

}


/**
* 用户修改
*
* @return 返回转向信息
* @throws Exception
*             采用struts2异常处理抛出所有异常
*/
public String updateUser() throws Exception {
userService.updateUser(users);
getRequest().setAttribute("url","user!queryPageUser.action");
return "suc";

}

/**
* 用户删除
*
* @return 返回转向信息
* @throws Exception
*             采用struts2异常处理抛出所有异常
*/
public String deleteUser() throws Exception {
userService.deleteUser(id);
getRequest().setAttribute("url","user!queryPageUser.action");
return "suc";
}

/**
* 用户修改查询
*
* @return 返回转向信息
* @throws Exception
*             采用struts2异常处理抛出所有异常
*/
public String findById() throws Exception {
users= userService.findById(id);
return "userUpdateWindow";
}

/**
* 用户分页查询
*
* @return 返回转向信息
* @throws Exception
*             采用struts2异常处理抛出所有异常
*/
public String queryPageUser() throws Exception {
pagenation= userService.queryPage(pageNum,PAGE_SIZE);
return "userListWindow";
}

}


dao
public interface IUsers {
/**
* 添加用户
*
* @param users
*            用户model
*/
public void addUser(Users users);

/**
* 删除用户
*
* @param userId
*            用户id
*/
public void deleteUser(Long userId);

/**
* 分页时获取总记录数
* @param map 查询条件
* @return 返回总记录数
*/
public int getCount(Map map);

/**
* 用户分页查询
* @param map 查询条件
* @return 返回用户列表
*/
public List<Users> queryPage(Map map);

/**
* 修改用户信息
* @param users
*/
    public void updateUser(Users users);
   
    /**
     * 根据id查找用户
     * @param id 用户id
     * @return 返回指定用户
     */
    public Users findById(Long id);
}

mybatis配置文件
<?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="com.medbri.mss.dao.IUsers">

<resultMap type="Users" id="sUsersResultMap">
<id property="userId" column="userId" />
<result property="userName" column="userName" />
<result property="userPassword" column="userPassword" />
</resultMap>
<insert id="addUser" parameterType="Users">
insert into users values(seq_user_id.nextval,#{userName},#{userPassword})
</insert>

<delete id="deleteUser" parameterType="Long">
delete from users where userId=#{userId}
</delete>
<update id="updateUser" parameterType="Users">
update users set userName=#{userName},userPassword=#{userPassword} where
userId=#{userId}
    </update>

<select id="getCount" parameterType="map" resultType="int">
select count(1)from users
    </select>
<select id="queryPage" resultType="Users" parameterType="map">
select * from(select a.*,rownum r from(select
t.userId,t.userName,t.userPassword from users t)
a ) where r &gt; #{startRow} and rownum &lt;= #{pageSize}
    
    </select>
<select id="findById" resultType="Users" parameterType="Long">
select t.userId,t.userName,t.userPassword from users t where
t.userId=#{userId}
    </select>
</mapper>


service

service接口省略(版面有限)

@Service
public class UserServiceImpl implements IUserService {
@Autowired
private IUsers iUsers;

/**
* 用户管理添加
*
* @param users
*            用户实体
*/
public void addUser(Users users) {
iUsers.addUser(users);
}

/**
* 删除用户
*
* @param userId
*            用户id
*/
public void deleteUser(Long userId) {
iUsers.deleteUser(userId);
}

/**
* 分页时获取总记录数
* @param map 查询条件
* @return 返回总记录数
*/
public int getCount(Map map){
return iUsers.getCount(map);
}

/**
* 用户分页查询
* @param map 查询条件
* @return 返回用户列表
*/
public  Pagenation queryPage(int pageNum,int pageSize){
Map map=new HashMap();
int count=iUsers.getCount(map);
Pagenation p = new Pagenation(pageSize,pageNum, count);
map.put("startRow",p.getStartRow());
map.put("pageSize",pageSize);
List<Users>list=iUsers.queryPage(map);
p.setList(list);
return p;
}

/**
* 修改用户信息
* @param users
*/
    public void updateUser(Users users){
    iUsers.updateUser(users);
    }
   
    /**
     * 根据id查找用户
     * @param id 用户id
     * @return 返回指定用户
     */
    public Users findById(Long id){
    return iUsers.findById(id);
    }

}
  • 大小: 56.1 KB
  • 大小: 56.1 KB
2
1
分享到:
评论
4 楼 medbricom 2012-05-07  
kjj 写道
不是全注解啊,batis那块都是xml!!

哦 这个要换成注解也简单,我另外一个版本sql就是用的注解
@Insert("insert into users values(seq_user_id.nextval,#{userName},#{userPassword})")
public void add(Account account) throws Exception;
org.apache.ibatis.annotations 这个包里面有相应的注解
3 楼 kjj 2012-05-06  
不是全注解啊,batis那块都是xml!!
2 楼 icexuan007 2011-09-19  
jinxuan07@163.com  把demo共享下  谢谢
1 楼 一点粉红 2011-05-24  
能不能把演示DEMO共享下 main_main@163.com

相关推荐

    struts2.1.8+spring3.0+ibatis2.3优雅框架

    Struts2.1.8、Spring3.0和iBatis2.3是经典的Java Web开发框架组合,它们各自承担着不同的职责,协同工作以构建高效、可维护的Web应用程序。接下来,我们将深入探讨这三个框架的核心特性以及它们如何优雅地整合在一起...

    小项目框架改造二:spring3.2.4+struts2.1.8+mybatis3.2.6整合修改

    标题 "小项目框架改造二:spring3.2.4+struts2.1.8+mybatis3.2.6整合修改" 提供了一个关于整合老旧但仍然广泛使用的Java Web开发框架的场景。这个项目涉及了Spring、Struts2和MyBatis三个核心组件的集成与优化。下面...

    小项目框架改造一:spring3.2.4+struts2.1.8+mybatis3.2.6整合

    本文将详细讲解如何将Spring 3.2.4、Struts2.1.8和MyBatis3.2.6这三个流行的技术进行整合,形成一个小型项目框架,以提高开发效率和代码的可维护性。 首先,Spring是一个全面的Java企业级应用框架,提供了依赖注入...

    spring 3.0.4 +hibernate3.6+mybatis3.0.4+struts 2.1.8+freemark整合

    标题 "spring 3.0.4 + hibernate3.6 + mybatis3.0.4 + struts 2.1.8 + freemarker 整合" 描述了一个经典的Java Web开发集成框架,用于构建高效、可扩展的Web应用程序。这个组合在过去的几年里非常流行,因为它将多个...

    WEB项目-集成Flex3_BlazeDS3[1].2_Spring2.5.6_iBatis2.3.4_Struts2.1.8

    这是一个关于Web项目集成的技术组合,涉及了Flex 3、BlazeDS 3、Spring 2.5.6、iBatis 2.3.4和Struts 2.1.8等多个关键组件。这些技术在现代企业级应用程序开发中扮演着重要角色,尤其在构建富互联网应用程序(RIA)...

    传智播客巴巴运动网后台管理

    Struts2.1.8是其中的一个稳定版本,它支持多种结果类型,包括JSP、FreeMarker、Velocity等,并且可以方便地与其他框架如Spring进行集成。 2. **Hibernate**:Hibernate是一个对象关系映射(ORM)框架,简化了数据库...

    ssh整合----annotation

    SSH整合中的Struts2版本为2.1.8,Spring版本为2.5,Hibernate版本为3.2。 **1. 新建Web Project并配置JDK** 在Myeclipse中创建一个新的Web项目,设置项目的JDK版本为1.6,确保所有框架能够正常工作。 **2. 构建...

Global site tag (gtag.js) - Google Analytics