这段时间没更博,找房去了。。。 吐槽一下,自如太坑了。。。承诺的三年不涨房租,结果今年一看北京房租都在涨也跟着涨了。。。 而且自如太贵了,租不起了。。 突然有点理解女生找对象要房了。。 搬家太受罪了。。。
今天更一下springMVC整合mybits形成最简单的网站demo。
大概效果就是这样的:左边是数据库查询结果,右边是页面访问结果。
首先,一个简单的springMVC小例子可以看这个http://709002341.iteye.com/admin/blogs/2280103
这是在这个基础上增加了mybits的配置和对数据库的访问。
在pom文件里增加对mybits的支持和druid数据源包:
<!-- mybits的基本依赖开始 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.2.1</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.2.0</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.26</version> </dependency> <!-- mybits的基本依赖结束 --> <!--第三方依赖包开始 --> <!-- 这是阿里巴巴的druid数据源依赖 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>0.2.20</version> </dependency>
配置mybits的配置文件
<?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:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop" 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-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd "> <context:component-scan base-package="controller"></context:component-scan> <context:component-scan base-package="com.cainiaojava"></context:component-scan> <!-- 引入属性文件 --> <context:property-placeholder location="classpath:jdbc.properties" /> <!-- 配置数据源 --> <bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close"> <property name="url" value="${url}" /> <property name="username" value="${username}" /> <property name="password" value="${password}" /> <property name="initialSize" value="1" /> <property name="maxActive" value="20" /> <property name="minIdle" value="1" /> <property name="maxWait" value="60000" /> <property name="validationQuery" value="${validationQuery}" /> <property name="testOnBorrow" value="true" /> <property name="testOnReturn" value="false" /> <property name="testWhileIdle" value="true" /> <property name="timeBetweenEvictionRunsMillis" value="60000" /> <property name="minEvictableIdleTimeMillis" value="25200000" /> <property name="removeAbandoned" value="true" /> <property name="removeAbandonedTimeout" value="1800" /> <property name="logAbandoned" value="true" /> <property name="filters" value="mergeStat" /> </bean> <!-- myBatis文件 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="mapperLocations" value="classpath:/sqlMapper/*Mapper.xml" /> </bean> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.cainiaojava.dao.iface" /> <!-- <property name="basePackage" value="druid-stat-interceptor" /> --> <!-- <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" /> --> </bean> </beans>
在dispatcher_cainiao.xml中引用一下这个配置文件:
<!-- 加载其他两个配置文件 --> <import resource="classpath:spring-mybits.xml" />
数据库的配置信息
#mysql连接配置参数 url=jdbc:mysql://localhost:3306/cainiao username=cainiao password=cainiao validationQuery=select 1 from dual
mybits的mapper文件:
<?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.cainiaojava.dao.iface.IUserManageDao"> <!-- 查询所有用户--> <select id="getUsers" resultType="com.cainiaojava.beans.User"> select * from user </select> </mapper>
然后就是修改一下控制类:
@Controller @RequestMapping("demo") public class DispatcherController { @Autowired private IUserManage userManage; @RequestMapping(method=RequestMethod.GET) public String printWelcome(ModelMap model) { model.addAttribute("list", userManage.getUsers()); // System.out.println("index.jsp"); return "index"; } }
然后就是后台的逻辑跳转了。
首先,在控制类里注册了用户管理接口IUserManage:
/** * IUserManage : 用户管理接口 * @author xuejupo [email protected] * create in 2016-3-7 7:04:02 */ public interface IUserManage { List<User> getUsers(); }
通过spring的注解,实现bean交给spring管理,注册的接口可以找到实现bean:UserManager:
/** * UserManage : 用户管理具体实现类,负责具体的代码逻辑,调用dao层执行sql语句 * @author xuejupo [email protected] * create in 2016-3-7 7:04:43 */ @Service("userManage") public class UserManage implements IUserManage{ @Autowired private IUserManageDao userManageDao; @Override public List<User> getUsers() { // TODO Auto-generated method stub return userManageDao.getUsers(); } }
然后,在用户管理类的实现类里,注册了dao文件IUserManageDao:
/** * UserManageDao : mybits中的mapper文件实现sql的细节,此接口不用实现(dao只负责执行sql) * @author xuejupo [email protected] * create in 2016-3-7 7:13:14 */ @Component("userManageDao") public interface IUserManageDao { /** * getUsers: 获取所有的用户,获取用户接口 * @return * List<User> */ public List<User> getUsers(); }
在dao层接口中,接口的方法是不用实现的,dao类只负责执行sql(根据mapper文件中的namespace找到接口,然后找跟方法名对应的id执行)。
执行效果就是这样:
PS: 附件是我的整个工程的压缩文件(里面还有redis,不过暂时没用到)。
如果需要下载我的工程然后执行的话,需要修改的地方就是需要自己新建一个数据库表(mysql)user,然后里面4个字段userId,userName,passwd,info。当然,也可以修改一下bean文件。
需要修改一下数据库配置文件jdbc.properties。
以后更新得可能会慢很多了。it这行,最好的学习方法永远是多用。 所以我想从零开始,利用spring和springMVC和mybits(可能会用到redis)造一个网站出来(初步打算是论坛)。不过因为公司也有工作,而且我的前端基础薄弱。。 所以进度可能无法掌握。。。 我会在iteye和我的博客园实时更新网站的进度,也会把我遇到的问题和解决方法更新到这里。
如果你有什么问题和建议,欢迎http://709002341.iteye.com/admin/blogs/2283664留言讨论。