spring mvc 与JPA/Hibernate的整合示例

简介:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
一、首先通过maven加入spring、jpa和hibernate相关的jar包。如pom.xml:
Java代码  收藏代码
     <project xmlns= "http://maven.apache.org/POM/4.0.0"  xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation= "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd" >
       <modelVersion> 4.0 . 0 </modelVersion>
       <groupId> cn.ibeans</groupId>
       <artifactId>ibeans</artifactId>
       <packaging>war</packaging>
       <version> 0.0 . 1 -SNAPSHOT</version>
       <name>myweb Maven Webapp</name>
       <url>http: //maven.apache.org</url>
                    
       <!-- 定义相关属性 -->
       <properties>
         <jdk-version> 1.6 </jdk-version>
         <junit-version> 4.11 </junit-version>
         <spring-version> 3.2 . 2 .RELEASE</spring-version>
       </properties>
                    
       <!-- 定义依赖包 -->
       <dependencies>
         <!-- spring begin-->
         <dependency>
             <groupId>org.springframework</groupId>
             <artifactId>spring-core</artifactId>
             <version>${spring-version}</version>
         </dependency>
         <dependency>
             <groupId>org.springframework</groupId>
             <artifactId>spring-beans</artifactId>
             <version>${spring-version}</version>
         </dependency>
         <dependency>
             <groupId>org.springframework</groupId>
             <artifactId>spring-web</artifactId>
             <version>${spring-version}</version>
         </dependency>
         <dependency>
             <groupId>org.springframework</groupId>
             <artifactId>spring-webmvc</artifactId>
             <version>${spring-version}</version>
         </dependency>
         <dependency>
             <groupId>org.springframework</groupId>
             <artifactId>spring-context</artifactId>
             <version>${spring-version}</version>
         </dependency>
         <dependency>
             <groupId>org.springframework.data</groupId>
             <artifactId>spring-data-jpa</artifactId>
             <version> 1.3 . 2 .RELEASE</version>
         </dependency>
         <!-- spring end -->
                      
                      
         <!-- servlet begin -->
         <dependency>
             <groupId>javax.servlet</groupId>
             <artifactId>servlet-api</artifactId>
             <version> 3.0 -alpha- 1 </version>
             <scope>provided</scope>
         </dependency>
         <!-- servlet end -->
                      
                      
         <!-- junit begin -->
         <dependency>
             <groupId>junit</groupId>
             <artifactId>junit</artifactId>
             <version>${junit-version}</version>
             <scope>test</scope>
         </dependency>
         <!-- junit end -->
                      
                      
         <!-- hibernate begin -->
         <dependency>
             <groupId>org.hibernate</groupId>
             <artifactId>hibernate-core</artifactId>
             <version> 4.2 . 1 .Final</version>
         </dependency>
             <dependency>
             <groupId>org.hibernate</groupId>
             <artifactId>hibernate-entitymanager</artifactId>
             <version> 4.2 . 1 .Final</version>
         </dependency>
         <dependency>
             <groupId>org.hibernate.common</groupId>
             <artifactId>hibernate-commons-annotations</artifactId>
             <version> 4.0 . 1 .Final</version>
         </dependency>
         <dependency>
             <groupId>org.hibernate</groupId>
             <artifactId>hibernate-validator</artifactId>
             <version> 5.0 . 0 .Final</version>
         </dependency>
         <!-- hibernate end -->
                      
                      
         <!--logger begin -->
         <dependency>
             <groupId>org.slf4j</groupId>
             <artifactId>slf4j-api</artifactId>
             <version> 1.7 . 5 </version>
         </dependency>
         <dependency>
             <groupId>org.slf4j</groupId>
             <artifactId>jcl-over-slf4j</artifactId>
             <version> 1.7 . 5 </version>
         </dependency>
         <dependency>
             <groupId>org.slf4j</groupId>
             <artifactId>slf4j-log4j12</artifactId>
             <version> 1.7 . 5 </version>
         </dependency>
         <!-- logger end -->
                      
                      
         <!-- database begin -->
         <dependency>
             <groupId>mysql</groupId>
             <artifactId>mysql-connector-java</artifactId>
             <version> 5.1 . 25 </version>
         </dependency>
         <!-- database end -->
                      
                      
         <!-- apache commons begin -->
         <dependency>
             <groupId>commons-dbcp</groupId>
             <artifactId>commons-dbcp</artifactId>
             <version> 20030825.184428 </version>
         </dependency>
         <dependency>
             <groupId>commons-pool</groupId>
             <artifactId>commons-pool</artifactId>
             <version> 20030825.183949 </version>
         </dependency>
         <dependency>
             <groupId>commons-collections</groupId>
             <artifactId>commons-collections</artifactId>
             <version> 2.1 </version>
         </dependency>
         <!-- apache commons end -->
       </dependencies>
                    
       <!-- 配置构建 -->
       <build>
         <finalName>ibeans</finalName>
       </build>
     </project>
2 、配置applicationContext.xml中的实体管理工厂和事务机制:
Java代码  收藏代码
     <?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:jdbc= "http://www.springframework.org/schema/jdbc"  
         xmlns:jee= "http://www.springframework.org/schema/jee" 
         xmlns:tx= "http://www.springframework.org/schema/tx"
         xmlns:jpa= "http://www.springframework.org/schema/data/jpa"
         xsi:schemaLocation="
             http: //www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
             http: //www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd
             http: //www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd
             http: //www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.2.xsd
             http: //www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
             http: //www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa.xsd"
         default -lazy-init= "true" >
                  
         <description>Spring公共配置 </description>
                  
         <!-- 使用annotation 自动注册bean, 并保证 @Required @Autowired 的属性被注入 -->
         <context:component-scan base- package = "cn.ibeans" >
             <context:exclude-filter type= "annotation"  expression= "org.springframework.stereotype.Controller" />
         </context:component-scan>
                  
         <!-- JPA实体管理工厂的配置 -->
         <bean id= "entityManagerFactory"  class = "org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
             <property name= "dataSource"  ref= "dataSource" />
             <property name= "jpaVendorAdapter"  ref= "hibernateJpaVendorAdapter" />
             <property name= "packagesToScan"  value= "cn.ibeans" /><!--待扫描的实体类包,不再需要persistence.xml了-->
             <property name= "jpaProperties" >
                 <props>
                     <prop key= "hibernate.ejb.naming_strategy" >org.hibernate.cfg.ImprovedNamingStrategy</prop>
                     <prop key= "hibernate.show_sql" > true </prop>
                     <prop key= "hibernate.hbm2ddl.auto" >update</prop>
                 </props>
             </property>
         </bean>
                      
         <!--指定实现JPA的适配器-->
         <bean id= "hibernateJpaVendorAdapter"  class = "org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" >
             <property name= "databasePlatform"  value= "org.hibernate.dialect.MySQLDialect"  />
         </bean>
                      
         <!-- Jpa 事务配置 -->
         <bean id= "transactionManager"  class = "org.springframework.orm.jpa.JpaTransactionManager" >
             <property name= "entityManagerFactory"  ref= "entityManagerFactory" />
         </bean>
                      
         <!-- Spring Data Jpa配置 -->
         <!--
         <jpa:repositories base- package = "cn.ibeans"   transaction-manager-ref= "transactionManager"  entity-manager-factory-ref= "entityManagerFactory" />
         -->
         <!-- 使用annotation定义事务 -->
         <tx:annotation-driven transaction-manager= "transactionManager"  proxy-target- class = "true"  />
                  
         <!-- JSR303 Validator定义 -->
         <bean id= "validator"  class = "org.springframework.validation.beanvalidation.LocalValidatorFactoryBean"  />
                      
         <!-- production环境 -->
         <beans profile= "production" >
             <context:property-placeholder ignore-unresolvable= "true"  location= "classpath*:/db.properties"  />  
                          
             <!-- 数据源配置, 使用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= "maxActive"  value= "${dbcp.maxActive}"  />
                 <property name= "maxIdle"  value= "${dbcp.maxIdle}"  />
                 <property name= "defaultAutoCommit"  value= "false"  />
                 <!-- 连接Idle一个小时后超时 -->
                 <property name= "timeBetweenEvictionRunsMillis"  value= "3600000"  />
                 <property name= "minEvictableIdleTimeMillis"  value= "3600000"  />
             </bean>
                          
             <!-- 数据源配置,使用应用服务器的数据库连接池 -->
             <!--<jee:jndi-lookup id= "dataSource"  jndi-name= "java:comp/env/jdbc/ExampleDB"  />-->
         </beans>
                      
         <!-- local development环境 -->
         <beans profile= "development" >
             <context:property-placeholder ignore-resource-not-found= "true"
                 location="classpath*:/db.properties,
                           classpath*:/db_dev.properties" />  
                  
             <!-- DBCP连接池 -->
             <bean id= "dataSource"  class = "org.apache.commons.dbcp.BasicDataSource"  destroy-method= "close" >
                 <property name= "driverClassName"  value= "${jdbc.driver}"  />
                 <property name= "url"  value= "${jdbc.url}"  />
                 <property name= "username"  value= "${jdbc.username}"  />
                 <property name= "password"  value= "${jdbc.password}"  />
                 <property name= "defaultAutoCommit"  value= "false"  />
             </bean>
         </beans>
                      
         <!-- unit test环境 -->
         <beans profile= "test" >
             <context:property-placeholder ignore-resource-not-found= "true"
                 location= "classpath*:/db_test.properties"  /> 
                          
             <!-- Simple连接池 -->
             <bean id= "dataSource"  class = "org.springframework.jdbc.datasource.SimpleDriverDataSource" >
                 <property name= "driverClass"  value= "${jdbc.driver}"  />
                 <property name= "url"  value= "${jdbc.url}"  />
                 <property name= "username"  value= "${jdbc.username}"  />
                 <property name= "password"  value= "${jdbc.password}"  />
             </bean>
                  
             <!-- 初始化数据表结构 与默认数据-->
             <jdbc:initialize-database data-source= "dataSource"  ignore-failures= "ALL" >
                 <jdbc:script location= "classpath:sql/h2/schema.sql"  />
                 <jdbc:script location= "classpath:data/import-data.sql"  encoding= "UTF-8" />
             </jdbc:initialize-database>
         </beans>
     </beans>
定义实体类:User.java
Java代码  收藏代码
     package  cn.ibeans.web.model;
                  
     import  java.io.Serializable;
                  
     import  javax.persistence.Column;
     import  javax.persistence.Entity;
     import  javax.persistence.GeneratedValue;
     import  javax.persistence.Id;
     import  javax.persistence.Table;
                  
     import  org.hibernate.annotations.GenericGenerator;
                  
     @Entity
     @Table (name= "i_user" )
     public  class  User  implements  Serializable{
         private  String id;
         private  String username;
         private  String password;
                      
         @Id
         @GeneratedValue (generator= "system-uuid" )
         @GenericGenerator (name= "system-uuid" ,strategy= "uuid" )
         public  String getId() {
             return  id;
         }
         public  void  setId(String id) {
             this .id = id;
         }
                      
         @Column (name= "username" )
         public  String getUsername() {
             return  username;
         }
         public  void  setUsername(String username) {
             this .username = username;
         }
                      
         @Column (name= "password" )
         public  String getPassword() {
             return  password;
         }
         public  void  setPassword(String password) {
             this .password = password;
         }
                      
     }
3 、定义dao接口,只需定义接口方法即可,不用加任何注解
Java代码  收藏代码
     package  cn.ibeans.dao;
                  
     import  cn.ibeans.web.model.User;
                  
     public  interface  UserDao {
                  
         User findByName(String name);
                  
         User findByLoginName(String loginName);
                      
         void  saveOrUpdate(User user);
     }
4 、定义dao实现类。用 @Repository 注解类,并将EntityManager作为成员变量注入,注入方法是加 @PersistenceContext
Java代码  收藏代码
     package  cn.ibeans.dao.impl;
                  
     import  javax.persistence.EntityManager;
     import  javax.persistence.PersistenceContext;
                  
     import  org.springframework.stereotype.Repository;
                  
     import  cn.ibeans.dao.UserDao;
     import  cn.ibeans.web.model.User;
                  
     @Repository
     public  class  UserDaoImpl  implements  UserDao {
                      
         @PersistenceContext
         private  EntityManager em;
                  
         @Override
         public  User findByName(String name) {
             return  null ;
         }
                  
         @Override
         public  User findByLoginName(String loginName) {
             return  null ;
         }
                  
         @Override
         public  void  saveOrUpdate(User user) {
             em.persist(user);
         }
                  
     }
5 、定义service类。可直接写实现类
@Component @Service 注释类,将dao接口作为成员变量注入,注入方法是加 @Autowired
如果是写方法,需在方法上加 @Transactional (readOnly= false )注解
Java代码  收藏代码
     package  cn.ibeans.service;
                  
     import  javax.annotation.Resource;
                  
     import  org.apache.log4j.Logger;
     import  org.springframework.beans.factory.annotation.Autowired;
     import  org.springframework.stereotype.Component;
     import  org.springframework.transaction.annotation.Transactional;
                  
     import  cn.ibeans.dao.UserDao;
     import  cn.ibeans.web.model.User;
                  
     @Component
     public  class  UserService {
         private  static  Logger logger = Logger.getLogger(UserService. class );
         @Autowired
         private  UserDao userDao;
                      
         @Transactional (readOnly= false )
         public  void  saveUser(User user){
             userDao.saveOrUpdate(user);
             logger.debug(user.getUsername()+ ",保存成功!" );
         }
     }
6 、定义action
@Controller 注释action类,如果需为该action中所有方法指定一个共用的上层路径名,则需用 @RequestMapping (value= "/user" )注释该类。表示该类下的所有访求均要通过/user/**来访问
将service类作为成员变量注入action。注入方法是加 @Autowired
@RequestMapping (value= "/save" )注释action的方法。
Java代码  收藏代码
     package  cn.ibeans.web.controller;
                  
     import  javax.servlet.ServletContext;
     import  javax.servlet.http.HttpServlet;
                  
     import  org.apache.log4j.Logger;
     import  org.springframework.beans.factory.annotation.Autowired;
     import  org.springframework.stereotype.Controller;
     import  org.springframework.ui.Model;
     import  org.springframework.web.bind.annotation.ModelAttribute;
     import  org.springframework.web.bind.annotation.RequestMapping;
     import  org.springframework.web.context.ContextLoader;
     import  org.springframework.web.context.WebApplicationContext;
                  
     import  cn.ibeans.service.UserService;
     import  cn.ibeans.web.model.User;
                  
     @Controller
     @RequestMapping (value= "/user" )
     public  class  LoginController  extends  HttpServlet{
         private  static  Logger log = Logger.getLogger(LoginController. class );
                      
         @Autowired
         private  UserService userService;
                      
                  
         //@RequestMapping(value="/login")   //如果类级别上已有映射地址(/user),此处的完整请求地址是/user/login
         public  String doLogin(Model model,Object loginForm){
             //model.addAttribute("username",username);  //model被用来封装数据,向前台传递
             WebApplicationContext context = ContextLoader.getCurrentWebApplicationContext();
             ServletContext sc = context.getServletContext();
                          
             return  "/welcome" ;
         }
                      
         @RequestMapping (value= "/login" )
         public  String login( @ModelAttribute  User user,Model model){
             log.info(user.getUsername());
             model.addAttribute(user);
             return  "/welcome" ;
         }
                      
         @RequestMapping (value= "/save" )
         public  String save( @ModelAttribute  User user,Model model){
             log.info(user.getUsername());
             userService.saveUser(user);
             model.addAttribute(user);
             return  "/welcome" ;
         }
     }
7 、发起请示的页面
请示的url应该是上下文根路径+action类路径+方法路径
Java代码  收藏代码
     <%@ page language= "java"  contentType= "text/html; charset=utf-8"  pageEncoding= "utf-8" %>
      <!DOCTYPE html PUBLIC  "-//W3C//DTD HTML 4.01 Transitional//EN"  "http://www.w3.org/TR/html4/loose.dtd" >
      <html>
      <head>
      <meta http-equiv= "Content-Type"  content= "text/html; charset=utf-8" >
      <title>Insert title here</title>
      </head>
      <body>
          <div>
              <form action= "/ibeans/user/save"  methed= "post" >
                  <input type= "text"  name= "username" >
                  <input type= "text"  name= "password" >
                  <input type= "submit"  value= "SUBMIT" >
              </form>
          </div>
      </body>
      </html>
8 、转发目的页面
可以通过引用action方法里定义的mode属性来获取相关的数据。
welcome.jsp:
Java代码  收藏代码
     <%@ page language= "java"  contentType= "text/html; charset=utf-8"
         pageEncoding= "utf-8" %>
     <!DOCTYPE html PUBLIC  "-//W3C//DTD HTML 4.01 Transitional//EN"  "http://www.w3.org/TR/html4/loose.dtd" >
     <html>
     <head>
     <meta http-equiv= "Content-Type"  content= "text/html; charset=utf-8" >
     <title>Insert title here</title>
     </head>
     <body>
        ${user.username },你好! 
     </body>
     </html>


















本文转自yunlielai51CTO博客,原文链接:http://blog.51cto.com/4925054/1282960,如需转载请自行联系原作者

相关文章
|
16天前
|
XML JSON Java
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
本文介绍了如何使用IntelliJ IDEA和Maven搭建一个整合了Struts2、Spring4、Hibernate4的J2EE项目,并配置了项目目录结构、web.xml、welcome.jsp以及多个JSP页面,用于刷新和学习传统的SSH框架。
27 0
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
|
16天前
|
安全 Java 数据安全/隐私保护
基于SpringBoot+Spring Security+Jpa的校园图书管理系统
本文介绍了一个基于SpringBoot、Spring Security和JPA开发的校园图书管理系统,包括系统的核心控制器`LoginController`的代码实现,该控制器处理用户登录、注销、密码更新、角色管理等功能,并提供了系统初始化测试数据的方法。
23 0
基于SpringBoot+Spring Security+Jpa的校园图书管理系统
|
18天前
|
Java 关系型数据库 MySQL
|
10天前
|
存储 Java 数据库
|
10天前
|
存储 Java API
|
10天前
|
Java 数据库连接 数据库
Spring Data JPA 与 Hibernate 之区别
【8月更文挑战第21天】
9 0
|
10天前
|
SQL Java 数据库连接
Hibernate 和 JPA 有什么区别?
【8月更文挑战第21天】
29 0
|
3月前
|
缓存 Java 数据库连接
深入理解Java中的JPA与Hibernate
深入理解Java中的JPA与Hibernate
|
3月前
|
SQL Java 数据库连接
从理论到实践:Hibernate与JPA在Java项目中的实际应用
【6月更文挑战第25天】在Java持久层,Hibernate与JPA提供ORM及数据库操作简化。JPA是EE规范,定义ORM接口;Hibernate是其实现,功能丰富。在一个在线书店项目中,使用@Entity标注实体类如Book,通过JpaRepository接口(如BookRepository)进行数据访问。服务层调用仓库接口方法,如搜索书籍。当需自定义查询时,可使用JPQL或SQL。Spring的@Transactional注解处理事务管理,展示出高效开发流程。
26 0
|
3月前
|
SQL 缓存 Java
Java持久化新篇章:Hibernate与JPA的进阶探索
【6月更文挑战第25天】在Java持久化技术中,Hibernate和JPA日益发展,本文以电商系统为例,展示它们的新特性和进阶应用。JPA通过注解如@Entity实现对象-关系映射,EntityManager处理CRUD操作。Hibernate则扩展了JPA,提供二级缓存、自定义HQL/SQL查询及批量操作,如批量更新商品价格,显示了其在性能优化和复杂需求上的灵活性。两者在现代Java开发中不可或缺。
20 0
下一篇
云函数