整合第二次(SSM第一次)------------>spring+struts2+mybatis
今天我们来讲解一下SSM整合,感觉整合这个比上一篇整合更费时,原因在于自己不太熟悉MyBatis了,下午的时候恶补了一下,看了一下相关的文档和PDF电子书,知识真的是你不用就会忘记的,以后还是不能懈怠了,把自己不擅长的领域抓一下。
为什么?怎么做?去做?我们今天围绕着三个问题来展开话题的讨论与内容的解说。
1.0我们为什么需要整合呢?
解答:一个良好的框架可以让开发人员减轻重新建立解决复杂问题方案的负担和精力;它可以被扩展以进行内部的定制化;并且有强大的用户社区来支持它。框架通常能很好的解决一个问题。然而,你的应用是分层的,可能每一个层都需要各自的框架。
比如:
Web层,就是MVC模式里面的“C”(controller),负责控制业务逻辑层与表现层的交互,调用业务逻辑层,并将业务数据返回给表现层作组织表现。
Service层(就是业务逻辑层),负责实现业务逻辑。业务逻辑层以DAO层为基础,通过对DAO组件的正面模式包装,完成系统所要求的业务逻辑。
DAO层,负责与持久化对象交互。该层封装了数据的增、删、查、改的操作。
PO,持久化对象。通过实体关系映射工具将关系型数据库的数据映射成对象,很方便地实现以面向对象方式操作数据库。
Spring的作用贯穿了整个中间层,将Web层、Service层、DAO层及PO无缝整合,其数据服务层用来存放数据。
同时给你们恶补一下,MyBatis的背景:
<dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.3</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.3.3.RELEASE</version> </dependency> <!--spring web jar 包--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>4.3.3.RELEASE</version> </dependency> <!--spring-tx jar 包--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>4.3.3.RELEASE</version> </dependency> <!--spring-ormjar 包--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> <version>4.3.3.RELEASE</version> </dependency> <!--spring-jdbcjar 包--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.3.3.RELEASE</version> </dependency> <!--spring mvc jar 包--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>4.3.3.RELEASE</version> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.8.7</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> <!--commons-dncpjar 包--> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-dbcp2</artifactId> <version>2.1.1</version> </dependency> <!--c3p0jar 包--> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <version>0.9.1.2</version> </dependency> <!--struts2-spring-plugin jar 包--> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-spring-plugin</artifactId> <version>2.5.10</version> </dependency> <!--struts2 core 包--> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-core</artifactId> <version>2.5.10</version> </dependency> <!--使用注解action--> <dependency> <groupId>org.apache.struts</groupId> <artifactId>struts2-convention-plugin</artifactId> <version>2.5.10</version> </dependency> <!--hibernate-core jar 包--> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-core</artifactId> <version>5.0.6.Final</version> </dependency> <!--jtajar 包--> <dependency> <groupId>javax.transaction</groupId> <artifactId>jta</artifactId> <version>1.1</version> </dependency> <!--mysql数据库驱动--> <dependency> <groupId>org.wisdom-framework</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.34_1</version> </dependency> <!--oraclejar 包--> <!--<dependency> <groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <version>11.2.0.1.0</version> </dependency>--> <!--jstl jar包--> <dependency> <groupId>org.apache.taglibs</groupId> <artifactId>taglibs-standard-spec</artifactId> <version>1.2.1</version> </dependency> <dependency> <groupId>org.apache.taglibs</groupId> <artifactId>taglibs-standard-impl</artifactId> <version>1.2.1</version> </dependency> <!--mybatis jar包--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.2</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.3.0</version> </dependency> <!--servlet api包--> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> </dependency> </dependencies> <build> <resources> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> <include>**/*.properties</include> </includes> </resource> </resources> </build>
项目的架构图:
大致上就是这样的一个层次体系,养好一个好的习惯,你会在以后的日子里轻松许多。
beans:
package cn.mybatis.beans; import javax.persistence.Column; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.Table; /** * Created by accp on 2017/4/6. */ @Table public class Stock { @Id @GeneratedValue private Integer sid; @Column private String sname; @Column private String count; public Stock() { } public Stock(String sname, String count) { this.sname = sname; this.count = count; } public Integer getSid() { return sid; } public void setSid(Integer sid) { this.sid = sid; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public String getCount() { return count; } public void setCount(String count) { this.count = count; } }
在这里使用注解比较简单一些,不用再创建一个xml文件了,前提是你懂得怎么样使用注解,分情况使用。
实现类:StockDaoImpl
public class StockDaoImpl implements IStockDao { private SqlSessionFactory sqlSessionFactory; @Transactional public int login(Stock stock) { return sqlSessionFactory.openSession().getMapper(IStockDao.class).login(stock); } @Transactional public List<Stock> selectAll() { return sqlSessionFactory.openSession().getMapper(IStockDao.class).selectAll(); } public SqlSessionFactory getSqlSessionFactory() { return sqlSessionFactory; } public void setSqlSessionFactory(SqlSessionFactory sqlSessionFactory) { this.sqlSessionFactory = sqlSessionFactory; } }
dao层:IStockDao
public interface IStockDao { /*登录*/ int login(Stock stock); /*查询全部*/ List<Stock> selectAll(); }
biz层:
package cn.mybatis.biz; import cn.mybatis.beans.Stock; import java.util.List; /** * Created by accp on 2017/4/6. */ public interface IStockBiz { /*登录*/ int login(Stock stock); /*查询全部*/ List<Stock> selectAll(); }
biz层的实现类:
package cn.mybatis.biz.impl; import cn.mybatis.beans.Stock; import cn.mybatis.biz.IStockBiz; import cn.mybatis.dao.IStockDao; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.List; /** * Created by accp on 2017/4/6. */ public class StockBizImpl implements IStockBiz { private IStockDao dao; @Transactional public int login(Stock stock) { return dao.login(stock); } @Transactional public List<Stock> selectAll() { return dao.selectAll(); } public IStockDao getDao() { return dao; } public void setDao(IStockDao dao) { this.dao = dao; } }
接下来就是action类:
package cn.mybatis.action; import cn.mybatis.beans.Stock; import cn.mybatis.biz.IStockBiz; import com.opensymphony.xwork2.ActionSupport; import org.apache.struts2.ServletActionContext; import javax.servlet.http.HttpServletRequest; import java.util.List; public class LoginAction extends ActionSupport { //植入biz层的对象 private IStockBiz biz; //植入一个List<Stock>集合保存返回的数据 private List<Stock> list; @Override public String execute() throws Exception { HttpServletRequest request = ServletActionContext.getRequest(); String name = request.getParameter("name"); String count1 = request.getParameter("count"); Stock stock=new Stock(name,count1); int count = biz.login(stock); if(count>0){ list = biz.selectAll(); return SUCCESS; } return INPUT; } public List<Stock> getList() { return list; } public void setList(List<Stock> list) { this.list = list; } public IStockBiz getBiz() { return biz; } public void setBiz(IStockBiz biz) { this.biz = biz; } }
简简单单的几个步骤我们就把分层架构给搭建出来了,这也就进入了我们项目的上升期,开始编写xml文件了。
配置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 type="cn.mybatis.beans.Stock" alias="stock"></typeAlias> </typeAliases> <!--映射文件指定--> <mappers> <mapper resource="cn/mybatis/dao/IStockDao.xml"></mapper> </mappers> </configuration>
配置applicationContextmybatis.xml里面的内容
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" 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.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd "> <!--配置包扫描器--> <context:component-scan base-package="cn.mybatis"></context:component-scan> <!--配置数据源--> <bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"> <property name="driverClassName" value="${jdbc.driver}"></property> <property name="url" value="${jdbc.url}"></property> <property name="username" value="${jdbc.username}"></property> <property name="password" value="${jdbc.password}"></property> </bean> <!--注入jdbc--> <context:property-placeholder location="classpath:jdbc.properties"></context:property-placeholder> <!--配置sqlSessionFactory--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"></property> <property name="configLocation" value="classpath:mybatis-config.xml"></property> </bean> <!--dao--> <bean id="stockDao" class="cn.mybatis.dao.impl.StockDaoImpl"> <property name="sqlSessionFactory" ref="sqlSessionFactory"></property> </bean> <!--biz--> <bean id="service" class="cn.mybatis.biz.impl.StockBizImpl"> <property name="dao" ref="stockDao"></property> </bean> <!--action--> <bean id="loginAction" class="cn.mybatis.action.LoginAction"> <property name="biz" ref="service"></property> </bean> <!--事务管理器--> <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"></property> </bean> <!--注解驱动--> <tx:annotation-driven transaction-manager="txManager"></tx:annotation-driven> </beans>
配置IStockDao.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="cn.mybatis.dao.IStockDao"> <select id="login" resultType="int"> select count(*) from stock where sname=#{sname} and count=#{count} </select> <select id="selectAll" resultType="stock"> select * from stock </select> </mapper>
千万不要忘了配置web.xml文件呦。
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <display-name>Archetype Created Web Application</display-name> <!--设置读取路径--> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContextmybatis.xml</param-value> </context-param> <!--配置监听器--> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!--配置filter--> <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <welcome-file-list> <welcome-file>login.jsp</welcome-file> </welcome-file-list> </web-app>
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.i18n.encoding" value="utf-8"></constant> <constant name="struts.devMode" value="false"></constant> <package name="default" extends="struts-default" namespace="/"> <action name="login" class="loginAction"> <result name="success">/success.jsp</result> <result name="input">/login.jsp</result> </action> </package> </struts>
写到这里,我们先测试一下,防止有什么差错。
测试登录是否成功:
@Test public void login(){ ApplicationContext ctx=new ClassPathXmlApplicationContext("applicationContextmybatis.xml"); IStockBiz biz=(IStockBiz)ctx.getBean("service"); int count = biz.login(new Stock("北大", "10")); System.out.println(count); }
这就说明你的登录通道没有问题,我们再来测试一下查询的
@Test public void select(){ ApplicationContext ctx=new ClassPathXmlApplicationContext("applicationContextmybatis.xml"); IStockBiz biz=(IStockBiz)ctx.getBean("service"); List<Stock> list = biz.selectAll(); System.out.println(list.size()); }
我们来看一下数据库是否是两条记录:
数据库的数据也是两条,就说明我们得到的结果没错,现在我们的登录和查询全部都没有错误,接下来我们就可以把项目加到Tomcat里了,
看看我们使用页面登录和查询有没有什么错误。
login.jsp页面
<%@ taglib prefix="s" uri="/struts-tags" %> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>登录页面</title> </head> <body> <form action="login" method="POST"> <input name="name"/> <input name="count"> <input type="submit" value="登录"> </form> </body> </html>
success.jsp
<%@ taglib prefix="s" uri="/struts-tags" %> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %> <html> <head> <title>成功页面</title> </head> <body> 欢迎登录<br> 以下是查询的内容: <c:forEach var="item" items="${list}"> ${item.sname} </c:forEach> </body> </html>
在这里经常忘了少配置xml文件而出现各种各样的问题,再加上不熟悉mybatis的书写,写这篇文章给我最大感触就是,一定要塌下心来学习,有许多细节上的问题需要我们注意,知识点的熟悉程度也要好,会解决问题。
其实写这个项目过程中一直报着一个空指针的错误,我看了好久,把代码从上到下都看了一遍,可能是觉得自己不会再小问题上犯错误就没看创建实体类中的代码检查的那么仔细,其实最后错误的引发点就是在我创建的一个构造上了,想省时间用快捷键生成的,反而给自己埋下了大坑,这个亏吃的不亏,我是这样觉得的,这样就会给自己提了个醒,小事要认真,我想我会一直记得。
不好意思,啰嗦了一下,接下来让我们把项目给启动起来吧,看看效果。
效果出来了就放心了,这就说明我们配置的没有问题。
-----------------初学者自己的记录