文档章节

struts2+spring+mybatis整合之路

苏叶晚晚
 苏叶晚晚
发布于 2017/03/24 10:51
字数 1477
阅读 307
收藏 1

1.导入相关的包 pom.xml

struts2、spring、mybatis、mybatis-spring整合的、struts2-spring整合的、mysql、c3p0连接池、spring-jdbc,还有日志包和jstl的包

   <dependency>
    <groupId>org.apache.struts</groupId>
    <artifactId>struts2-core</artifactId>
    <version>2.5.10.1</version>
  </dependency>
  <dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.4.2</version>
  </dependency>
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>4.3.7.RELEASE</version>
  </dependency>
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-web</artifactId>
    <version>4.3.4.RELEASE</version>
  </dependency>
  <dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>1.3.0</version>
  </dependency>
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jdbc</artifactId>
    <version>4.3.3.RELEASE</version>
  </dependency>
  <dependency>
    <groupId>org.apache.struts</groupId>
    <artifactId>struts2-spring-plugin</artifactId>
    <version>2.5.10.1</version>
  </dependency>
  <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.34</version>
  </dependency>
  <dependency>
    <groupId>c3p0</groupId>
    <artifactId>c3p0</artifactId>
    <version>0.9.1.2</version>
  </dependency>
  <dependency>
    <groupId>jstl</groupId>
    <artifactId>jstl</artifactId>
    <version>1.2</version>
  </dependency>
  <dependency>
    <groupId>taglibs</groupId>
    <artifactId>standard</artifactId>
    <version>1.1.2</version>
  </dependency>
  <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.21</version>
  </dependency>
  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.12</version>
    <scope>test</scope>
  </dependency>
</dependencies>

最开始忘记导入struts2-spring的包,结果报空指针错:Action代码中的dao对象是空的,dao对象没有注入成功。加了这个包就正常了。现在仍然觉得很奇怪:缺struts2-spring的包,action生成了dao没生成?

##2.配置applicationContext.xml文件,参考代码注释 <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:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.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"> <!--启动annotation注解,当component-scan开启的时候,这个配置默认就会开启了,可以省略--> context:annotation-config</context:annotation-config> <!--启动包扫描,它会扫描com.doris下的所有子包--> <context:component-scan base-package="com.doris"></context:component-scan> <!--引入外部的配置文件--> <context:property-placeholder location="classpath:db.properties"/> <!--我用的c3p0,所以通过c3p0配置dabaSource。如果你用的其他数据源,更换class即可--> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <property name="driverClass" value="${driver}"/> <property name="jdbcUrl" value="${url}"/> <property name="user" value="${dbname}"/> <property name="password" value="${password}"/> </bean> <!--配置mybatis的sqlSessionFactory--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="configLocation" value="classpath:mybatis-config.xml"/> <!--自动扫描所有的mapper文件--> <property name="mapperLocations" value="classpath:*Mapper.xml"/> </bean> <!--下面的配置是通过MapperFactoryBean生成指定Mapper接口的实例。 但每个Mapper都配很麻烦,就可以用下面的MapperScannerConfigurer扫描所有的Mapper/Dao文件,不需要单独配置了--> <!--<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">--> <!--<property name="mapperInterface" value="com.doris.dao.UserDAO"/>--> <!--<property name="sqlSessionFactory" ref="sqlSessionFactory"/>--> <!--</bean>--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.doris.dao" /> </bean> <!-- 事务配置 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!-- 使用annotation注解方式配置事务 --> <tx:annotation-driven transaction-manager="transactionManager"/> </beans>

3.配置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>
  <!--引入外部配置文件-->
  <!--<properties resource="db.properties"></properties>-->
  <typeAliases>
    <!--<typeAlias type="com.doris.entity.User" alias="User"></typeAlias>-->
    <!--启用别名包扫描,路径到包即可-->
    <package name="com.doris.entity"></package>
  </typeAliases>
  <!--环境 被spring的配置代替了
  <environments default="development">
    <environment id="development">
      <transactionManager type="JDBC"/>
      <dataSource type="POOLED">
        <property name="driver" value="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${username}"/>
        <property name="password" value="${password}"/>
      </dataSource>
    </environment>
  </environments>
  mapper也不要再配了,因为spring已经配置了自动扫描所有的mapper文件 mapperLocations classpath:*Mapper.xml
  <mappers>
    <mapper resource="UserDAOMapper.xml"/>
    <mapper resource="NoteDAOMapper.xml"/>
  </mappers>-->
</configuration>

上述配置大量内容都被注释了。保留注释只是为了让大家更清楚看到省略了哪些配置。

4.配置ApplicationContext.xml中引入的db.properties文件

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/notesystem?useUnicode=true&characterEncoding=UTF-8
dbname=root
password=root

这里遇到的一个大坑是我把dbname写成username。结果控制台报错access denied for Administrator@localhost,页面报错Connections could not be acquired from the underlying database! 看来username在配置文件中有特殊含义,被解析成了Administrator。

5.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>
  <constant name="struts.devMode" value="true"></constant>
  <constant name="struts.i18n.encoding" value="UTF-8"></constant>

  <package name="user" namespace="/user" extends="struts-default">
    <!--struts2.5的新版本默认不支持通配符了,要加上这个配置才行。我踩过的坑呐!-->
    <global-allowed-methods>regex:.*</global-allowed-methods>
    <action name="*_*" class="com.doris.action.{1}Action" method="{2}">
      <result name="list">/list.jsp</result>
      <result name="success">/success.jsp</result>
      <result name="login">/index.jsp</result>
    </action>
  </package>
</struts>

6.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>Archetype Created Web Application</display-name>
  <!--指定applicationContext.xml的文件位置。默认去WEB-INF下寻找。
  我放在resources目录,在classpath中-->
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
  </context-param>  
  <filter>
    <filter-name>struts2</filter-name>
    <filter-class>
      <!--struts2.5的filter-class不是dispatcher.ng.filter了-->
      org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter
    </filter-class>
  </filter>
  <filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
  <!--配置spring监听器-->
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
</web-app>

至此所有的框架配置文件就结束啦,接下里是代码部分和Mapper的配置


UserAction.java

  [@Controller](https://my.oschina.net/u/1774615)
  public class UserAction extends ActionSupport implements RequestAware {

    private UserDAO userDAO;
    private Map<String, Object> request;

    public String list() {
    List<User> users = userDAO.queryAll();
      request.put("users", users);
      return "list";
    }
      
    public void setRequest(Map<String, Object> request) {
      this.request = request;
    }
      
    @Resource(name = "userDAO")
    public void setUserDAO(UserDAO userDAO) {
      this.userDAO = userDAO;
    }
  }

UserDAO.java

@Repository("userDAO")
@Transactional
public interface UserDAO {
    public List<User> queryAll();
    public User queryById(int id);
    public int save(User user);
    public void delete(int id);
    public void update(User user);
    //模糊查询
    public List<User> queryByName(@Param("name")String name);
}

UserDAOMapper.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="com.doris.dao.UserDAO">
  <select id="queryAll" resultType="User">
    select * from user
  </select>
  <select id="queryById" resultType="User" parameterType="int">
    select * from user where id = #{id}
  </select>
  <update id="update">
    update user set username=#{username},password=#{password} where id=#{id}
  </update>
  <delete id="delete" parameterType="int">
    DELETE FROM user where id=#{id}
  </delete>
  <!--userGeneratedKeys 采用主键自增策略
  keyProperty java对象中的id属性名
  keyColumn sql中的id属性名
  当keyProperty == keyColumn时,keyColumn可以省略-->
  <insert id="save" useGeneratedKeys="true" parameterType="User" keyProperty="id" keyColumn="id">
    INSERT into user(username,password) values( #{username},#{password})
  </insert>
  <select id="queryByName" resultType="User" >
    select * from user where username like '%${username}%'
  </select>
</mapper>

User.java

public class User {
    private int id;
    private String username;
    private String password;
    public User() {
    }

    public User(int id, String name, String password) {
        this.id = id;
        this.username = name;
        this.password = password;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}

index.jsp

<html>
<body>
<a href="user/User_list">查询所有学员</a>
</body>
</html>

list.jsp

<%@ page contentType="text/html;charset=UTF-8" isELIgnored="false" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
   <c:forEach items="${requestScope.users}" var="user">
       ${user.username}====${user.password}<br>
   </c:forEach>
</body>
</html>

© 著作权归作者所有

苏叶晚晚
粉丝 75
博文 76
码字总数 35972
作品 0
徐汇
程序员
私信 提问
x-fire调用webservice的问题

这里是调用webService的方法,项目用的SpringMVC,这个是service实现: webService的地址是: webService实现: webService用的是struts2+Spring+mybatis 错误信息如下: webService配置没错,...

Class_one
2014/10/07
725
1
从菜鸟到架构师(十三)

随着我经验的增长和技术的提高,我已经不满足于现在的工资,公司的工资在业界算是比较低的。 我向伟哥提出过离职的申请,当时想的是跳槽随便都能涨工资。当时和伟哥谈了很久,他说:“我们公...

lynnlovemin
2017/04/19
0
0
第二篇:第三方Library的引入和刪除

前言 在做項目的的時候,不免會用到第三方的Library,那麽怎麽引入第三方的Library,又怎麽刪除第三方Library的引用呢? 正文 這個問題我之前已經寫過了,爲了整合我的《Android組件化之路》...

奔跑的佩恩
2017/12/30
0
0
KeyMob移动广告聚合平台帮助应用开发者实现最大盈利

KeyMob移动广告聚合平台(www.keymob.com)在2014年正式上线。整合了近多家国内外主流移动广告平台的KeyMob,在长达四个月的内测和公测期间获得了近千名IOS和Android开发者的支持。据参加测试...

bbk122
2016/03/11
10
0
学习之路/免费的图库推荐

免费的图库推荐 欢迎阅读我所有的学习之路系列文章: 学习之路系类文章目录 本文会根据我在实际使用中,用到的一些免费图库,推荐给大家 推荐一: 贴图库(http://tietuku.com) ` 关于贴图库无...

DennisGuo
2015/11/23
127
0

没有更多内容

加载失败,请刷新页面

加载更多

关于AsyncTask的onPostExcute方法是否会在Activity重建过程中调用的问题

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接:https://blog.csdn.net/XG1057415595/article/details/86774575 假设下面一种情况...

shzwork
今天
6
0
object 类中有哪些方法?

getClass(): 获取运行时类的对象 equals():判断其他对象是否与此对象相等 hashcode():返回该对象的哈希码值 toString():返回该对象的字符串表示 clone(): 创建并返此对象的一个副本 wait...

happywe
今天
6
0
Docker容器实战(七) - 容器中进程视野下的文件系统

前两文中,讲了Linux容器最基础的两种技术 Namespace 作用是“隔离”,它让应用进程只能看到该Namespace内的“世界” Cgroups 作用是“限制”,它给这个“世界”围上了一圈看不见的墙 这么一...

JavaEdge
今天
8
0
文件访问和共享的方法介绍

在上一篇文章中,你了解到文件有三个不同的权限集。拥有该文件的用户有一个集合,拥有该文件的组的成员有一个集合,然后最终一个集合适用于其他所有人。在长列表(ls -l)中这些权限使用符号...

老孟的Linux私房菜
今天
7
0
面试套路题目

作者:抱紧超越小姐姐 链接:https://www.nowcoder.com/discuss/309292?type=3 来源:牛客网 面试时候的潜台词 抱紧超越小姐姐 编辑于 2019-10-15 16:14:56APP内打开赞 3 | 收藏 4 | 回复24 ...

MtrS
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部