Spring MVC 学习笔记12 —— SpringMVC+Hibernate开发(1)依赖包搭建
用Hibernate帮助建立SpringMVC与数据库之间的联系,通过配置DAO层,Service层,Model层,建立Controller对数据库操作的通道。
这里没有使用maven来管理jar包(依赖库),因为没太多,实际上还是很繁琐的,要有耐心。
原本稍微复杂的工程项目还是应该使用maven来管理依赖库,参见:http://tieba.baidu.com/p/2364606122?pn=1
下面记录一下依赖包搭建过程:
DAO - SERVICE -
1.在eclipse中新建项目:
new-project-Dynamic Web Project(name: spring_user)
2. insert jar packages:
参考如图,导入jar包到目标位置 :Download .jar files from: http://jarfiles.pandaidea.com or http://mvnrepository.com/
1)spring-reamework-release-3.1.3\dist
2)apache-log4j-1.2.16.jar
4)hibernate-distribution-3.6.8 Final\lib\required(hibernate用3、4都可以)
5)jpa
hibernate-jpa-2.0-api-1.0.0.Final.jar
6)hibernate3
hibernate3.jar slf4j-log4j12-1.6.1.jar
7)hlfa/dbcp/aop/jstl
aopalliance.jar aspectjrt.jar aspectjweaver.jar
8)dbcp 数据引导性文件
commons-collections-3.1.jar commons-dbcp.jar commons-pool.jar9)jstl 的标签:
jsf-api.jar jsf-impl.jar jstl-1.2.jar
10)数据库记录:
mysql-connector-java-5.1.17-bin.jar
...
3. 建立model层的Pakage:
New Java Package: zttc.itat.model,如图:4. model下,建立一个类
zttc.itat.model >> New Java Class
Name: User
----------
@Entity @Table(name="t_user") //创建一张表 pulic class User{ private int id; private String username; private String password; private String email; private String nickname; }@GenerateValue @Id public int getId(){ return Id; } …//后面就是其他参数的Get Set 方法
1)add getter & setter增加Get Setter:
Select all >> finish.
2)add @Entity....
此时我们再把分页的class加上: new package at zttc.itat.model >> new >> class >> Pager.java
5. Spring 和Hibernate的整合
打开数据库,新建一个database:spring_user
database charset:utf-8
database collection: utf-8
bean.xml文件的coding:
从别处拷过来一个src\bean.xml:
beans.xml -- 改为zttc.itat...
再改一下jdbc.properties:指定mysql数据库名: jdbc.url = jdbc:mysql://localhost:3306/spring_user
参考(SpringMVC + Spring + SpringJDBC整合):http://www.open-open.com/lib/view/open1349272132291.html
参考: http://www.blogjava.net/yiqi801218/archive/2008/03/16/186670.html
6. 写DAO层: zttc.itat.dao
新建一个package, name: zttc.itat.dao
再建一个Interface:IUserDao.java
//这里面有一些简单的方法: package zttc.itat.dao; public interface IUserDao { public void add(User user); public void update(User user); public void delete(int id); public User load(int id); public List<User> list(); public Pager<User> find(); //分页的method声明 public User loadByUsername(String username);}</pre><br>
如图:
再建立一个类:UserDao - UserDao.java, Add IUserDao里的方法进来:
完了我们要继承DaoSupport, 要注入SessionFactory, 还要自己写一个方法public void setsuperSessionFactory(). 再用Repository来注入一下,名称:("userDao")。
7. 写UserException(zttc.itat.modelpackage下): New -> Class -> UserException (Superclass: java.lang.RuntimeException)
UserException.java : Add default serial version IDRightClick >> Source >> Generate Constructors from Superclass >> select all, 父类构造下来UserException.java完成。
8. 写SystemContext.java支持分页操作
传分页还得传当前页、每页显示多少条这几个数据传过来。所以要创建一个thread local
newClass: Source folder=spring_user/src, Package=zttc.itat.model name=SystemContext
9. 写Dao层各个方法,支持增删改查。文件:UserDao.java
8.1 public void add(User user){ } 方法:
public void add(User user){ this.getHibernateTemplate().save(user); }
在UserDao.java中再写Pager相关操作:
如上图所示,完成add\update\delete\load\list等:
return this.getSession().creatQuery("from User").list(); //下图补充一下上图。
再加一个方法:
接下来我们完成Service层 ===----------
10. 新建一个package: zttc.itat.service Package
10.1 New Interface: IUserService.java/11. UserService.java
新建一个Class:
Coding in UserService.java:
12. 写SystemContextFilter
新建一个Class:SystemContextFilter.java
这里有很多Coding的内容,视频时间:至:
15. 写web.xml
先打开dispatcher:
再写mapping:
再拷字符编码部分:
还有把bean.xml加入监听:
OpenSessionInWiew
SystemContext
Filter(zttc.itat.web.SystemContextFilter)
FilterMapping
15. 创建Spring的Bean文件: user-servlet.xml
beans, context, mvc这三个Desired XSD namespace declaration必须要选。
在这里面要配这几个东西:参考:http://blog.csdn.net/kivenlee/article/details/6284732
- mvc
- context:component-scan
- bean class="...InternalResourceViewResolver"
- 其他异常那些东西就后面慢慢配了
新建Controller投入实际测试
16. 新建UserController.java
17. 写WEB-INF/jsp/user/list.jsp
写入: <h1>用户列表测试页面</h1>
===========至此搞定,测试一下 ===========
Run >> Tomcat ,启动调试,http://localhost:8080/spring_user/user/users无问题。
看看数据库,也建起来了:
好累。。。