轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发(含CD光盘1张)(国家级奖项获奖作品升级版,四版累计印刷27次发行量超10万册的轻量级Java EE经典著作)
李刚 编著
ISBN 978-7-121-24253-3
2014年10月出版
定价:108.00元
824页
16开
编辑推荐
国内知名IT图书作家李刚老师基于曾荣获中国书刊发行业协会“年度全行业优秀畅销品种”大奖的《轻量级Java EE企业应用实战(第3版)》全新升级;
本书内容升级到Struts 2.3、Spring 4.0、Hibernate 4.3;全书所有示例基于Java 8、Hibernate注解进行全面升级;
《轻量级Java EE企业应用实战》新增Maven、SVN、Tomcat 8.0、Eclipse luna(4.4)等知识;
数百个小型案例及完整的工作流系统综合案例帮读者领略S2SH开发精髓;
《轻量级Java EE企业应用实战》被多所“985”“211”院校选作教材;
最受程序员欢迎、影响力最大的国人原创S2SH应用开发必读经典。
内容提要
《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》是《轻量级 Java EE 企业应用实战》的第4 版,第4 版保持了前几版内容全面、深入的特点,主要完成全部知识的升级。
《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》介绍了 Java EE 领域的三个开源框架:Struts 2、Spring 和Hibernate。其中Struts 2 升级到2.3.16.3,Spring 升级到4.0.4,Hibernate 升级到4.3.5。《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》还全面介绍了Servlet 3.1 的新特性,以及Tomcat 8.0 的配置和用法,《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》的示例也应该在Tomcat 8.0 上运行。
《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》重点介绍如何整合 Struts 2.3+Spring 4.0+Hibernate 4.3 进行Java EE 开发,主要包括三部分。第一部分介绍了Java EE 开发的基础知识,以及如何搭建开发环境。第二部分详细讲解了Struts 2.3、Spring 4.0 和Hibernate 4.3 三个框架的用法,介绍三个框架时,以Eclipse IDE 的使用来上手,一步步带领读者深入三个框架的核心。这部分内容是笔者讲授“疯狂Java 实训”的培训讲义,因此是《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》的重点部分。这部分内容既包含了笔者多年开发经历的领悟,也融入了丰富的授课经验。第三部分示范开发了一个包含7 个表,表之间具有复杂的关联映射、继承映射等关系,且业务也相对复杂的工作流案例,希望让读者理论联系实际,将三个框架真正运用到实际开发中去。该案例采用目前最流行、最规范的Java EE架构,整个应用分为领域对象层、DAO 层、业务逻辑层、MVC 层和视图层,各层之间分层清晰,层与层之间以松耦合的方法组织在一起。该案例既提供了IDE 无关的、基于Ant 管理的项目源码,也提供了基于Eclipse IDE 的项目源码,最大限度地满足读者的需求。
《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》不再介绍 Struts 1.x 相关内容,如果读者希望获取《轻量级J2EE 企业应用实战》第1 版中关于Struts 1.x 的知识,请登录http://www.crazyit.org 下载。当读者阅读此书遇到技术难题时,也可登录http://www.crazyit.org 发帖,笔者将会及时予以解答。
阅读《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》之前,建议先认真阅读笔者所著的《疯狂 Java 讲义》一书。《轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发》适合于有较好的Java 编程基础,或有初步JSP、Servlet 基础的读者,尤其适合于对Struts 2、Spring、Hibernate 了解不够深入,或对Struts 2+Spring+Hibernate 整合开发不太熟悉的开发人员阅读。
目录
第1章 Java EE应用和开发环境 1
1.1 Java EE应用概述 2
1.1.1 Java EE应用的分层模型 2
1.1.2 Java EE应用的组件 3
1.1.3 Java EE应用的结构和优势 4
1.1.4 常用的Java EE服务器 4
1.2 轻量级Java EE应用相关技术 5
1.2.1 JSP、Servlet 3.x和JavaBean及替代技术 5
1.2.2 Struts 2.3及替代技术 5
1.2.3 Hibernate 4.3及替代技术 6
1.2.4 Spring 4.0及替代技术 6
1.3 Tomcat的下载和安装 7
1.3.1 安装Tomcat服务器 7
1.3.2 配置Tomcat的服务端口 9
1.3.3 进入控制台 9
1.3.4 部署Web应用 12
1.3.5 配置Tomcat的数据源 12
1.4 Eclipse的安装和使用 14
1.4.1 Eclipse的下载和安装 14
1.4.2 在线安装Eclipse插件 14
1.4.3 从本地压缩包安装插件 16
1.4.4 手动安装Eclipse插件 17
1.4.5 使用Eclipse开发Java EE应用 17
1.4.6 导入Eclipse项目 20
1.4.7 导入非Eclipse项目 21
1.5 Ant的安装和使用 22
1.5.1 Ant的下载和安装 22
1.5.2 使用Ant工具 23
1.5.3 定义生成文件 24
1.5.4 Ant的任务(task) 29
1.6 Maven的安装和使用 31
1.6.1 下载和安装Maven 31
1.6.2 设置Maven 32
1.6.3 创建、构建简单的项目 33
1.6.4 Maven的核心概念 36
1.6.5 依赖管理 41
1.6.6 POM文件的元素 44
1.7 使用SVN进行协作开发 44
1.7.1 下载和安装SVN服务器 45
1.7.2 配置SVN资源库 46
1.7.3 下载和安装SVN客户端 47
1.7.4 将项目发布到服务器 48
1.7.5 从服务器下载项目 48
1.7.6 提交(Commit)修改 49
1.7.7 同步(Update)本地文件 49
1.7.8 添加文件和目录 50
1.7.9 删除文件和目录 50
1.7.10 查看文件或目录的版本变革 51
1.7.11 从以前版本重新开始 51
1.7.12 创建分支 52
1.7.13 沿着分支开发 52
1.7.14 合并分支 53
1.7.15 使用Eclipse作为SVN客户端 54
1.8 本章小结 57
第2章 JSP/Servlet及相关技术详解 58
2.1 Web应用和web.xml文件 59
2.1.1 构建Web应用 59
2.1.2 配置描述符web.xml 60
2.2 JSP的基本原理 61
2.3 JSP的4种基本语法 65
2.3.1 JSP注释 65
2.3.2 JSP声明 66
2.3.3 输出JSP表达式 67
2.3.4 JSP脚本 68
2.4 JSP的3个编译指令 70
2.4.1 page指令 70
2.4.2 include指令 74
2.5 JSP的7个动作指令 75
2.5.1 forward指令 75
2.5.2 include指令 77
2.5.3 useBean、setProperty、getProperty指令 79
2.5.4 plugin指令 81
2.5.5 param指令 81
2.6 JSP脚本中的9个内置对象 82
2.6.1 application对象 83
2.6.2 config对象 88
2.6.3 exception对象 90
2.6.4 out对象 92
2.6.5 pageContext对象 93
2.6.6 request对象 95
2.6.7 response对象 102
2.6.8 session对象 106
2.7 Servlet介绍 108
2.7.1 Servlet的开发 108
2.7.2 Servlet的配置 110
2.7.3 JSP/Servlet的生命周期 111
2.7.4 load-on-startup Servlet 112
2.7.5 访问Servlet的配置参数 113
2.7.6 使用Servlet作为控制器 115
2.8 JSP 2的自定义标签 119
2.8.1 开发自定义标签类 120
2.8.2 建立TLD文件 120
2.8.3 使用标签库 121
2.8.4 带属性的标签 122
2.8.5 带标签体的标签 125
2.8.6 以页面片段作为属性的标签 128
2.8.7 动态属性的标签 129
2.9 Filter介绍 131
2.9.1 创建Filter类 132
2.9.2 配置Filter 133
2.9.3 使用URL Rewrite实现网站伪静态 136
2.10 Listener介绍 137
2.10.1 实现Listener类 138
2.10.2 配置Listener 139
2.10.3 使用ServletContextAttributeListener 140
2.10.4 使用ServletRequestListener和ServletRequestAttributeListener 141
2.10.5 使用HttpSessionListener和HttpSessionAttributeListener 142
2.11 JSP 2特性 147
2.11.1 配置JSP属性 147
2.11.2 表达式语言 149
2.11.3 Tag File支持 157
2.12 Servlet 3.0新特性 159
2.12.1 Servlet 3.0的注解 159
2.12.2 Servlet 3.0的Web模块支持 160
2.12.3 Servlet 3.0提供的异步处理 162
2.12.4改进的Servlet API 165
2.13 Servlet 3.1新增的非阻塞式IO 167
2.14 Tomcat 8的WebSocket支持 170
2.15 本章小结 174
第3章 Struts 2的基本用法 175
3.1 MVC思想概述 176
3.1.1 传统Model 1和Model 2 176
3.1.2 MVC思想及其优势 177
3.2 Struts 2的下载和安装 178
3.2.1 为Web应用增加Struts 2支持 178
3.2.2 在Eclipse中使用Struts 2 179
3.2.3 增加登录处理 180
3.3 Struts 2的流程 183
3.3.1 Struts 2应用的开发步骤 183
3.3.2 Struts 2的流程 184
3.4 Struts 2的常规配置 185
3.4.1 常量配置 185
3.4.2 包含其他配置文件 191
3.5 实现Action 191
3.5.1 Action接口和ActionSupport基类 193
3.5.2 Action访问Servlet API 195
3.5.3 Action直接访问Servlet API 197
3.5.4 使用ServletActionContext访问Servlet API 199
3.6 配置Action 200
3.6.1 包和命名空间 200
3.6.2 Action的基本配置 203
3.6.3 使用Action的动态方法调用 204
3.6.4 指定method属性及使用通配符 205
3.6.5 配置默认Action 211
3.6.6 配置Action的默认处理类 211
3.7 配置处理结果 212
3.7.1 理解处理结果 212
3.7.2 配置结果 213
3.7.3 Struts 2支持的结果类型 214
3.7.4 plainText结果类型 215
3.7.5 redirect结果类型 217
3.7.6 redirectAction结果类型 218
3.7.7 动态结果 219
3.7.8 Action属性值决定物理视图资源 219
3.7.9 全局结果 221
3.7.10 使用PreResultListener 222
3.8 配置Struts 2的异常处理 223
3.8.1 Struts 2的异常处理机制 223
3.8.2 声明式异常捕捉 225
3.8.3 输出异常信息 226
3.9 Convention插件与“约定”支持 227
3.9.1 Action的搜索和映射约定 228
3.9.2 按约定映射Result 230
3.9.3 Action链的约定 233
3.9.4 自动重加载映射 234
3.9.5 Convention插件的相关常量 234
3.9.6 Convention插件相关Annotation 235
3.10 使用Struts 2的国际化 235
3.10.1 视图页面的国际化 235
3.10.2 Action的国际化 236
3.10.3 使用包范围的国际化资源 238
3.10.4 使用全局国际化资源 239
3.10.5 输出带占位符的国际化消息 241
3.10.6 加载资源文件的顺序 243
3.11 使用Struts 2的标签库 243
3.11.1 Struts 2标签库概述 243
3.11.2 使用Struts 2标签 244
3.11.3 Struts 2的OGNL表达式语言 245
3.11.4 OGNL中的集合操作 247
3.11.5 访问静态成员 248
3.11.6 Lambda()表达式 248
3.11.7 控制标签 249
3.11.8 数据标签 259
3.11.9 主题和模板 268
3.11.10 自定义主题 270
3.11.11 表单标签 271
3.11.12 非表单标签 284
3.12 本章小结 287
第4章 深入使用Struts 2 288
4.1 详解Struts 2的类型转换 289
4.1.1 Struts 2内建的类型转换器 290
4.1.2 基于OGNL的类型转换 290
4.1.3 指定集合元素的类型 292
4.1.4 自定义类型转换器 294
4.1.5 注册类型转换器 297
4.1.6 基于Struts 2的自定义类型转换器 298
4.1.7 处理Set集合 299
4.1.8 类型转换中的错误处理 301
4.2 使用Struts 2的输入校验 307
4.2.1 编写校验规则文件 307
4.2.2 国际化提示信息 310
4.2.3 使用客户端校验 311
4.2.4 字段校验器配置风格 312
4.2.5 非字段校验器配置风格 313
4.2.6 短路校验器 315
4.2.7 校验文件的搜索规则 316
4.2.8 校验顺序和短路 318
4.2.9 内建校验器 318
4.2.10 基于注解的输入校验 329
4.2.11 手动完成输入校验 330
4.3 使用Struts 2控制文件上传 334
4.3.1 Struts 2的文件上传 334
4.3.2 实现文件上传的Action 335
4.3.3 配置文件上传的Action 337
4.3.4 手动实现文件过滤 338
4.3.5 拦截器实现文件过滤 340
4.3.6 输出错误提示 341
4.3.7 文件上传的常量配置 342
4.4 使用Struts 2控制文件下载 343
4.4.1 实现文件下载的Action 343
4.4.2 配置Action 343
4.4.3 下载前的授权控制 344
4.5 详解Struts 2的拦截器机制 345
4.5.1 拦截器在Struts 2中的作用 346
4.5.2 Struts 2内建的拦截器 346
4.5.3 配置拦截器 348
4.5.4 使用拦截器的配置语法 349
4.5.5 配置默认拦截器 350
4.5.6 实现拦截器类 351
4.5.7 使用拦截器 353
4.5.8 拦截方法的拦截器 354
4.5.9 拦截器的执行顺序 356
4.5.10 拦截结果的监听器 358
4.5.11 覆盖拦截器栈里特定拦截器的参数 359
4.5.12 使用拦截器完成权限控制 360
4.6 使用Struts 2的Ajax支持 362
4.6.1 使用stream类型的Result实现Ajax 363
4.6.2 JSON的基本知识 365
4.6.3 实现Action逻辑 367
4.6.4 JSON插件与json类型的Result 368
4.6.5 实现JSP页面 370
4.7 本章小结 371
第5章 Hibernate的基本用法 372
5.1 ORM和Hibernate 373
5.1.1 对象/关系数据库映射(ORM) 373
5.1.2 基本映射方式 374
5.1.3 流行的ORM框架简介 375
5.1.4 Hibernate概述 376
5.2 Hibernate入门 376
5.2.1 Hibernate下载和安装 376
5.2.2 Hibernate的数据库操作 377
5.2.3 在Eclipse中使用Hibernate 381
5.3 Hibernate的体系结构 386
5.4 深入Hibernate配置文件 388
5.4.1 创建Configuration对象 388
5.4.2 hibernate.properties文件与hibernate.cfg.xml文件 390
5.4.3 JDBC连接属性 390
5.4.4 数据库方言 391
5.4.5 JNDI数据源的连接属性 393
5.4.6 Hibernate事务属性 393
5.4.7 二级缓存相关属性 393
5.4.8 外连接抓取属性 394
5.4.9 其他常用的配置属性 394
5.5 深入理解持久化对象 394
5.5.1 持久化类的要求 395
5.5.2 持久化对象的状态 396
5.5.3 改变持久化对象状态的方法 397
5.6 深入Hibernate映射 399
5.6.1 映射属性 402
5.6.2 映射主键 409
5.6.3 使用Hibernate的主键生成策略 411
5.6.4 映射集合属性 412
5.6.5 集合属性的性能分析 419
5.6.6 有序集合映射 420
5.6.7 映射数据库对象 422
5.7 映射组件属性 424
5.7.1 组件属性为集合 426
5.7.2 集合属性的元素为组件 427
5.7.3 组件作为Map的索引 429
5.7.4 组件作为复合主键 430
5.7.5 多列作为联合主键 432
5.8 使用传统的映射文件 433
5.8.1 增加XML映射文件 433
5.8.2 注解,还是XML映射文件 436
5.9 本章小结 436
第6章 深入使用Hibernate 437
6.1 Hibernate的关联映射 438
6.1.1 单向N-1关联 438
6.1.2 单向1-1关联 443
6.1.3 单向1-N关联 444
6.1.4 单向N-N关联 448
6.1.5 双向1-N关联 449
6.1.6 双向N-N关联 452
6.1.7 双向1-1关联 454
6.1.8 组件属性包含的关联实体 456
6.1.9 基于复合主键的关联关系 458
6.1.10 复合主键的成员属性为关联实体 460
6.1.11 持久化的传播性 463
6.2 继承映射 464
6.2.1 整个类层次对应一个表的映射策略 466
6.2.2 连接子类的映射策略 468
6.2.3 每个具体类对应一个表的映射策略 471
6.3 Hibernate的批量处理 473
6.3.1 批量插入 473
6.3.2 批量更新 474
6.3.3 DML风格的批量更新/删除 475
6.4 使用HQL查询 476
6.4.1 HQL查询 476
6.4.2 HQL查询的from子句 478
6.4.3 关联和连接 479
6.4.4 HQL查询的select子句 482
6.4.5 HQL查询的聚集函数 482
6.4.6 多态查询 483
6.4.7 HQL查询的where子句 483
6.4.8 表达式 484
6.4.9 order by子句 486
6.4.10 group by子句 486
6.4.11 子查询 487
6.4.12 命名查询 487
6.5 条件查询 489
6.5.1 关联和动态关联 491
6.5.2 投影、聚合和分组 493
6.5.3 离线查询和子查询 496
6.6 SQL查询 497
6.6.1 标量查询 497
6.6.2 实体查询 499
6.6.3 处理关联和继承 501
6.6.4 命名SQL查询 502
6.6.5 调用存储过程 504
6.6.6 使用定制SQL 505
6.7 数据过滤 507
6.8 事务控制 510
6.8.1 事务的概念 510
6.8.2 Session与事务 511
6.8.3 上下文相关的Session 513
6.9 二级缓存和查询缓存 514
6.9.1 开启二级缓存 514
6.9.2 管理缓存和统计缓存 517
6.9.3 使用查询缓存 518
6.10 事件机制 520
6.10.1 拦截器 521
6.10.2 事件系统 523
6.11 本章小结 525
第7章 Spring的基本用法 526
7.1 Spring简介和Spring 4.0的变化 527
7.1.1 Spring简介 527
7.1.2 Spring 4.0的变化 528
7.2 Spring入门 528
7.2.1 Spring下载和安装 528
7.2.2 使用Spring管理Bean 529
7.2.3 在Eclipse中使用Spring 532
7.3 Spring的核心机制:依赖注入 535
7.3.1 理解依赖注入 536
7.3.2 设值注入 538
7.3.3 构造注入 541
7.3.4 两种注入方式的对比 543
7.4 使用Spring容器 543
7.4.1 Spring容器 544
7.4.2 使用ApplicationContext 545
7.4.3 ApplicationContext的国际化支持 546
7.4.4 ApplicationContext的事件机制 548
7.4.5 让Bean获取Spring容器 551
7.5 Spring容器中的Bean 552
7.5.1 Bean的基本定义和Bean别名 553
7.5.2 容器中Bean的作用域 554
7.5.3 配置依赖 557
7.5.4 设置普通属性值 559
7.5.5 配置合作者Bean 560
7.5.6 使用自动装配注入合作者Bean 561
7.5.7 注入嵌套Bean 563
7.5.8 注入集合值 564
7.5.9 组合属性 568
7.5.10 Spring的Bean和JavaBean 569
7.6 Spring 3.0提供的Java配置管理 571
7.7 创建Bean的3种方式 573
7.7.1 使用构造器创建Bean实例 574
7.7.2 使用静态工厂方法创建Bean 574
7.7.3 调用实例工厂方法创建Bean 576
7.8 深入理解容器中的Bean 578
7.8.1 抽象Bean与子Bean 578
7.8.2 Bean继承与Java继承的区别 580
7.8.3 容器中的工厂Bean 580
7.8.4 获得Bean本身的id 582
7.8.5 强制初始化Bean 583
7.9 容器中Bean的生命周期 584
7.9.1 依赖关系注入之后的行为 584
7.9.2 Bean销毁之前的行为 586
7.9.3 协调作用域不同步的Bean 589
7.10 高级依赖关系配置 592
7.10.1 获取其他Bean的属性值 592
7.10.2 获取Field值 595
7.10.3 获取方法返回值 596
7.11 基于XML Schema的简化配置方式 599
7.11.1 使用p:命名空间简化配置 599
7.11.2 使用c:命名空间简化配置 601
7.11.3 使用util:命名空间简化配置 602
7.12 Spring 3.0提供的表达式语言(SpEL) 604
7.12.1 使用Expression接口进行表达式求值 604
7.12.2 Bean定义中的表达式语言支持 606
7.12.3 SpEL语法详述 607
7.13 本章小结 612
第8章 深入使用Spring 613
8.1 两种后处理器 614
8.1.1 Bean后处理器 614
8.1.2 Bean后处理器的用处 617
8.1.3 容器后处理器 618
8.1.4 属性占位符配置器 619
8.1.5 重写占位符配置器 620
8.2 Spring的“零配置”支持 622
8.2.1 搜索Bean类 622
8.2.2 指定Bean的作用域 625
8.2.3 使用@Resource配置依赖 625
8.2.4 使用@PostConstruct和@PreDestroy定制生命周期行为 626
8.2.5 Spring 3.0新增的注解 627
8.2.6 Spring 4.0增强的自动装配和精确装配 627
8.3 资源访问 631
8.3.1 Resource实现类 632
8.3.2 ResourceLoader接口和ResourceLoaderAware接口 636
8.3.3 使用Resource作为属性 639
8.3.4 在ApplicationContext中使用资源 640
8.4 Spring的AOP 643
8.4.1 为什么需要AOP 643
8.4.2 使用AspectJ实现AOP 644
8.4.3 AOP的基本概念 651
8.4.4 Spring的AOP支持 652
8.4.5 基于注解的“零配置”方式 653
8.4.6 基于XML配置文件的管理方式 667
8.5 Spring 3.1新增的缓存机制 673
8.5.1 启用Spring缓存 674
8.5.2 使用@Cacheable执行缓存 676
8.5.3 使用@CacheEvict清除缓存 680
8.6 Spring的事务 681
8.6.1 Spring支持的事务策略 681
8.6.2 使用XML Schema配置事务策略 686
8.6.3 使用@Transactional 692
8.7 Spring整合Struts 2 693
8.7.1 启动Spring容器 693
8.7.2 MVC框架与Spring整合的思考 694
8.7.3 让Spring管理控制器 695
8.7.4 使用自动装配 699
8.8 Spring整合Hibernate 701
8.8.1 Spring提供的DAO支持 701
8.8.2 管理Hibernate的SessionFactory 702
8.8.3 实现DAO组件的基类 703
8.8.4 传统的HibernateTemplate和HibernateDaoSupport 706
8.8.5 实现DAO组件 709
8.8.6 使用IoC容器组装各种组件 709
8.8.7 使用声明式事务 712
8.9 Spring整合JPA 713
8.9.1 管理EntityManagerFactory 713
8.9.2 实现DAO组件基类 715
8.9.3 使用声明式事务 718
8.10 本章小结 719
第9章 企业应用开发的思考和策略 720
9.1 企业应用开发面临的挑战 721
9.1.1 可扩展性、可伸缩性 721
9.1.2 快捷、可控的开发 722
9.1.3 稳定性、高效性 722
9.1.4 花费最小化,利益最大化 723
9.2 如何面对挑战 723
9.2.1 使用建模工具 723
9.2.2 利用优秀的框架 723
9.2.3 选择性地扩展 725
9.2.4 使用代码生成器 726
9.3 常见设计模式精讲 726
9.3.1 单例模式 727
9.3.2 简单工厂 728
9.3.3 工厂方法和抽象工厂 734
9.3.4 代理模式 737
9.3.5 命令模式 742
9.3.6 策略模式 745
9.3.7 门面模式 748
9.3.8 桥接模式 750
9.3.9 观察者模式 754
9.4 常见的架构设计策略 757
9.4.1 贫血模型 757
9.4.2 领域对象模型 760
9.4.3 合并业务逻辑对象与DAO对象 762
9.4.4 合并业务逻辑对象和Domain Object 763
9.4.5 抛弃业务逻辑层 764
9.5 本章小结 765
第10章 简单工作流系统 766
10.1 项目背景及系统结构 767
10.1.1 应用背景 767
10.1.2 系统功能介绍 767
10.1.3 相关技术介绍 768
10.1.4 系统结构 768
10.1.5 系统的功能模块 769
10.2 Hibernate持久层 770
10.2.1 设计持久化实体 770
10.2.2 创建持久化实体类 771
10.3 实现DAO层 777
10.3.1 DAO组件的定义 778
10.3.2 实现DAO组件 780
10.3.3 部署DAO层 783
10.4 实现Service层 784
10.4.1 业务逻辑组件的设计 785
10.4.2 实现业务逻辑组件 785
10.4.3 事务管理 790
10.4.4 部署业务逻辑组件 791
10.5 实现任务的自动调度 791
10.5.1 使用Quartz 791
10.5.2 在Spring中使用Quartz 795
10.6 实现系统Web层 798
10.6.1 Struts 2和Spring的整合 798
10.6.2 控制器的处理顺序图 799
10.6.3 员工登录 799
10.6.4 进入打卡 802
10.6.5 处理打卡 803
10.6.6 进入申请 805
10.6.7 提交申请 806
10.6.8 使用拦截器完成权限管理 808
10.7 本章小结 809
作者简介
李刚,十多年软件行业开发从业经验,疯狂软件教育中心教学总监。
疯狂Java实训营创始人,疯狂Java体系原创图书作者。
广东技术师范学院计算机科学系兼职副教授,51CTO专家门诊特邀嘉宾。
培训的学生已在华为、IBM、阿里软件、网易、电信盈科等名企就职。
国内著名高端IT技术作家,已出版《疯狂Java讲义》《疯狂Android讲义》《轻量级Java EE企业应用实战》《疯狂iOS讲义》《疯狂Ajax讲义》《疯狂XML讲义》《经典Java EE企业应用实战》《疯狂HTML 5/CSS 3/JavaScript讲义》《Struts 2.x权威指南》等著作。其中疯狂Java体系图书经多年沉淀,赢得极高的市场认同,多次重印成为超级畅销书,并被多所“985”“211”院校选作教材。部分图书已被翻译成繁体中文版,授权到台湾地区。
前言
经过多年沉淀,Java EE平台已经成为电信、金融、电子商务、保险、证券等各行业的大型应用系统的首选开发平台。目前Java行业的软件开发已经基本稳定,这两三年内基本没有出现什么具有广泛影响力的新技术。Java EE开发大致可分为两种方式:以Spring为核心的轻量级Java EE企业开发平台;以EJB 3+JPA为核心的经典Java EE开发平台。无论使用哪种平台进行开发,应用的性能、稳定性都有很好的保证,开发人群也有很稳定的保证。
本书介绍的开发平台,就是以Struts 2.3+Spring 4.0+Hibernate 4.3(实际项目中可能以JPA来代替Hibernate)为核心的轻量级Java EE,这种组合在保留经典Java EE应用架构、高度可扩展性、高度可维护性的基础上,降低了Java EE应用的开发、部署成本,对于大部分中小型企业应用是第一首选。在一些需要具有高度伸缩性、高度稳定性的企业应用(比如银行系统、保险系统)里,以EJB 3+JPA为核心的经典Java EE应用则具有一定的占有率。本书姊妹篇《经典Java EE企业应用实战》主要介绍了后一种Java EE开发平台。
本书主要升级了《轻量级Java EE企业应用实战》的知识,本书采用最新的Tomcat 8作为Web服务器,全面而细致地介绍了Servlet 3.1的新特性,并将Struts 2升级到Struts 2.3.16.3,Spring升级到4.0.4,Hibernate升级到4.3.5。详细介绍了Spring和Hibernate的“零配置”特性,并充分介绍了Struts 2的Convention(约定)支持。为了顺应技术的改变,本书介绍Hibernate持久化映射已经全部升级为注解方式,不再采用传统的XML映射方式;本书还详细介绍了Spring 3.1新增的缓存机制,包括使用@Cacheable执行缓存、使用@CacheEvict清除缓存等、也详细介绍了Spring 4.0的改变,包括增强的自动装配和精确装配等。
本书创作感言
笔者首先要感谢广大读者对本书前几版的认同,本书前几版累计发行近十万册,并获得中国书刊发行业协会颁发的“2011年度全行业优秀畅销品种”大奖,且多次获得电子工业出版社颁发的“最畅销图书奖”。是广大读者的选择让“疯狂Java体系”图书大放异彩;是广大读者的支持让我在孤独的技术创作道路上坚持求索;是广大读者的反馈让“疯狂Java体系”图书日臻完美。
广大读者的热情对我来说既是支持,又是责任——“疯狂Java体系”图书有责任必须完美!因此笔者在改进、升级“疯狂Java体系”图书时,有一种如履薄冰的感觉,希望以最大的努力来贡献最好的作品。
另外,本书还有一本配套的姊妹篇:《经典Java EE企业应用实战》。学习本书时可以采用“轻经合参”的方式来学习:“轻”指的是以“SSH”整合的轻量级Java EE开发平台,“经”指的是以“EJB3+JPA”整合的经典Java EE开发平台;这两种平台本身具有很大的相似性,将两种Java EE开发平台结构放在一起参考、对照着学习,能更好地理解Spring、Hibernate框架的设计思想,从而更深入地掌握它们。与此同时,也可以深入理解EJB 3与Spring容器中的Bean、EJB容器与Spring容器之间的联系和区别,从而融会贯通地掌握EJB3+JPA整合的开发方式。
在介绍非常专业的编程知识之时,笔者总会通过一些浅显的类比来帮助读者更好地理解。“简单、易读”成为笔者一贯坚持的创作风格,也是“疯狂Java体系”图书的特色。另一方面,“疯狂Java体系”图书的知识也很全面、实用。笔者希望读者在看完“疯狂Java体系”的图书之后,可以较为轻松地理解书中所介绍的知识,并切实学会一种实用的开发技术,进而将之应用到实际开发中。万一读者在学习过程中遇到无法理解的问题,可以登录疯狂Java联盟(http://www.crazyit.org)与广大Java学习者交流,笔者也会通过该平台与大家一起交流、学习。
本书有什么特点
本书保持了《轻量级Java EE企业应用实战》前几版简单、实用的优势,同样坚持让案例说话、以案例来介绍知识点的风格。本书最后同样示范开发了企业工作流案例,希望读者通过该案例真正步入实际企业开发的殿堂。
本书依然保留了《轻量级Java EE企业应用实战》前几版的三个特色。
1.经验丰富,针对性强
笔者既担任过软件开发的技术经理,也担任过软件公司的培训导师,还从事过职业培训的专职讲师。这些经验影响了笔者写书的目的,不是一本学院派的理论读物,而是一本实际的开发指南。
2.内容实际,实用性强
本书所介绍的Java EE应用范例,采用了目前企业流行的开发架构,绝对严格遵守Java EE开发规范,而不是将各种技术杂乱地糅合在一起号称Java EE。读者参考本书的架构,完全可以身临其境地感受企业实际开发。
3.高屋建瓴,启发性强
本书介绍的几种架构模式,几乎是时下最全面的Java EE架构模式。这些架构模式可以直接提升读者对系统架构设计的把握。
本书写给谁看
如果你已经掌握Java SE内容,或已经学完了《疯狂Java讲义》一书,那你非常适合阅读此书。除此之外,如果你已有初步的JSP、Servlet基础,甚至对Struts 2、Spring 4.0、Hibernate 4.3有所了解,但希望掌握它们在实际开发中应用,本书也将非常适合你。如果你对Java的掌握还不熟练,则建议遵从学习规律,循序渐进,暂时不要购买、阅读此书,而是按照《疯狂Java学习路线图》中的建议顺序学习。
李刚
2014-8-19
相关推荐
在本资源中,“轻量级JAVA EE企业应用实战随书光盘02”是一个与“轻量级JAVA EE企业应用实战”课程或书籍配套的光盘内容,主要聚焦于第二部分的实践教学。这个压缩包可能包含了一系列的代码示例、项目文件和其他辅助...
【标题】"轻量级JAVA EE企业应用实战随书光盘\codes\05" 提供的是关于JAVA EE企业级应用开发的一个实践案例,重点在于轻量级框架的使用。这个部分可能涉及到如何在实际项目中高效、简洁地构建JAVA EE应用程序。 ...
1.2 轻量级java ee应用相关技术 5 1.2.1 jsp、servlet 3.0和javabean及替代技术 5 1.2.2 struts 2.2及替代技术 5 1.2.3 hibernate 3.6及替代技术 6 1.2.4 spring 3.0及替代技术 6 1.3 tomcat的下载和安装 7 ...
内容概要:本文详细介绍了基于FPGA的四相八拍步进电机控制系统的开发过程。主要内容包括:1. 使用VHDL和Verilog编写LED显示屏驱动代码,用于显示角度、学号和姓名等信息;2. 实现步进电机的正反转控制,通过状态机管理相序变化;3. 开发加速减速控制模块,确保电机启动和停止时的平稳性;4. 设计调速功能,通过调节脉冲频率实现速度控制。此外,文中还讨论了调试过程中遇到的问题及其解决方案。 适合人群:对FPGA开发和步进电机控制感兴趣的电子工程师、嵌入式系统开发者以及相关专业的学生。 使用场景及目标:适用于需要高精度运动控制的应用场合,如工业自动化、机器人技术和精密仪器等领域。目标是帮助读者掌握FPGA控制步进电机的基本原理和技术细节。 其他说明:文中提供了详细的代码片段和调试经验分享,有助于读者更好地理解和应用所学知识。同时,作者还提到了一些实用技巧,如通过PWM调节实现多级变速,以及如何避免步进电机的共振问题。
内容概要:本文详细介绍了基于Android Studio开发的日历备忘录记事本项目,涵盖日历查看、添加备忘录、闹钟提醒和删除备忘录等功能。项目使用SQLite数据库进行数据存储,通过CalendarView、EditText、Button等控件实现用户交互,并利用AlarmManager和PendingIntent实现闹钟提醒功能。此外,项目还包括数据库的设计与管理,如创建DatabaseHelper类来管理数据库操作,确保数据的安全性和完整性。文章还探讨了一些常见的开发技巧和注意事项,如时间戳的使用、手势监听的实现等。 适用人群:适用于初学者和有一定经验的Android开发者,尤其是希望深入了解Android开发基础知识和技术细节的人群。 使用场景及目标:该项目旨在帮助开发者掌握Android开发的基本技能,包括UI设计、数据库操作、闹钟提醒机制等。通过实际项目练习,开发者能够更好地理解和应用这些技术,提升自己的开发能力。 其他说明:文中提到一些进阶任务,如用Room替换SQLite、增加分类标签、实现云端同步等,鼓励开发者进一步扩展和优化项目。同时,项目源码公开,便于学习和参考。
内容概要:本文档详细介绍了一个基于SVM(支持向量机)和Adaboost集成学习的时间序列预测项目。该项目旨在通过结合这两种强大算法,提升时间序列预测的准确性和稳定性。文档涵盖了项目的背景、目标、挑战及其解决方案,重点介绍了模型架构、数据预处理、特征选择、SVM训练、Adaboost集成、预测与误差修正等环节。此外,文档还探讨了模型在金融市场、气象、能源需求、交通流量和医疗健康等多个领域的应用潜力,并提出了未来改进的方向,如引入深度学习、多任务学习、联邦学习等先进技术。 适合人群:具备一定机器学习基础的研究人员和工程师,特别是那些从事时间序列预测工作的专业人士。 使用场景及目标:①用于金融市场、气象、能源需求、交通流量和医疗健康等领域的复杂时间序列数据预测;②通过结合SVM和Adaboost,提升预测模型的准确性和稳定性;③处理噪声数据,降低计算复杂度,提高模型的泛化能力和实时预测能力。 其他说明:文档不仅提供了详细的理论解释,还附有完整的Matlab代码示例和GUI设计指导,帮助读者理解和实践。此外,文档还讨论了模型的部署与应用,包括系统架构设计、实时数据流处理、可视化界面、GPU加速推理等方面的技术细节。
#游戏之追逐奶酪123
内容概要:本文详细介绍了威纶通触摸屏配方管理系统的实现方法及其应用场景。首先,文章讲解了配方管理的基本概念和技术背景,强调了配方管理在工业自动化中的重要性。接着,通过具体的宏程序代码示例,展示了如何实现配方的保存、加载以及安全校验等功能。文中还提到配方数据结构的设计,如使用寄存器地址偏移来确保数据不冲突,并通过CSV文件格式方便地管理和维护配方数据。此外,文章深入探讨了UI设计方面的内容,包括动态图层技术和按钮交互效果的应用,使得用户界面更加友好和直观。最后,作者分享了一些实际项目中的经验和技巧,如文件操作的异常处理和宏指令调试方法。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对触摸屏配方管理系统感兴趣的读者。 使用场景及目标:适用于需要频繁切换设备参数的生产环境,如食品加工、注塑成型等行业。通过使用威纶通触摸屏配方管理系统,可以提高工作效率,减少人为错误,同时简化设备调试和维护流程。 其他说明:附带的工具包提供了完整的宏指令注释版、图库资源和调试工具,帮助用户更好地理解和应用该系统。
张彩明-图形学简明教程 PPT课件
计算机术语.pdf
内容概要:本文详细介绍了利用改进粒子群算法(IPSO)进行微电网多目标优化调度的方法和技术。首先指出了传统粒子群算法(PSO)存在的局限性,如初始化随机性和易陷入局部最优等问题。接着提出了多种改进措施,包括混沌映射初始化、动态权重调整、自适应变异以及引入帕累托前沿机制等。文中通过具体的代码实例展示了这些改进的具体实现,并通过实验验证了改进后的算法在处理微电网优化调度问题时的有效性,尤其是在应对风光发电不确定性方面表现突出。此外,文章还讨论了实际应用场景中的约束处理方法,如功率平衡约束的修复策略,确保理论与实践相结合。 适合人群:对智能优化算法及其在电力系统特别是微电网中的应用感兴趣的科研人员、工程师及研究生。 使用场景及目标:适用于需要对微电网进行多目标优化调度的研究和工程项目,旨在提高微电网运行效率,降低成本并减少环境污染。通过学习本文提供的改进算法和技术手段,能够更好地理解和掌握如何针对特定业务场景定制化地改进经典优化算法。 其他说明:文章不仅提供了详细的理论分析和算法改进思路,还包括了大量的代码片段和实验结果,有助于读者深入理解并快速应用于实际项目中。
内容概要:本文详细介绍了基于西门子S7-1200 PLC和组态王的7车位3x3升降横移立体车库控制系统的设计与实现。主要内容涵盖IO分配、梯形图程序、接线图、组态画面设计以及安全防护逻辑等方面。文中强调了硬件互锁、软件互锁、模块化编程、精确控制和平移控制等关键技术点,并分享了一些调试经验和注意事项。此外,还讨论了光电传感器误触发、急停按钮处理、故障记录等实际应用中的挑战及其解决方案。 适合人群:从事工业自动化领域的工程师和技术人员,特别是熟悉PLC编程和组态软件使用的专业人员。 使用场景及目标:适用于需要设计和实施立体车库控制系统的工程项目。目标是帮助读者掌握S7-1200 PLC与组态王的具体应用方法,提高系统可靠性和安全性。 其他说明:文中提供了详细的代码片段和配置示例,有助于读者更好地理解和实践相关技术。同时,作者分享了许多宝贵的实战经验,对于初学者和有一定经验的技术人员都非常有价值。
内容概要:本文详细介绍了线性表及其顺序表示的概念、原理和操作。线性表作为一种基础数据结构,通过顺序表示将元素按顺序存储在连续的内存空间中。文中解释了顺序表示的定义与原理,探讨了顺序表与数组的关系,并详细描述了顺序表的基本操作,包括初始化、插入、删除和查找。此外,文章分析了顺序表的优点和局限性,并讨论了其在数据库索引、图像处理和嵌入式系统中的实际应用。最后,对比了顺序表和链表的性能特点,帮助读者根据具体需求选择合适的数据结构。 适合人群:计算机科学专业的学生、软件开发人员以及对数据结构感兴趣的自学者。 使用场景及目标:①理解线性表顺序表示的原理和实现;②掌握顺序表的基本操作及其时间复杂度;③了解顺序表在实际应用中的优势和局限性;④学会根据应用场景选择合适的数据结构。 其他说明:本文不仅提供了理论知识,还附带了具体的代码实现,有助于读者更好地理解和实践线性表的相关概念和技术。
计算机数学1 -5 重言式与蕴含式.pdf
内容概要:本文详细介绍了风电永磁直驱发电并网系统的构成及其关键控制部分。首先探讨了真实的风速模型构建方法,利用MATLAB生成带有随机扰动和突风成分的风速曲线,用于模拟自然界的风况。接着深入解析了永磁电机的转速控制机制,特别是最大功率点跟踪(MPPT)算法的具体实现方式,以及如何通过PI控制器调节电磁转矩。随后讨论了并网过程中LCL滤波器的设计要点,确保谐波失真小于3%的同时保持系统稳定性。此外,还涉及到了网侧变流器的锁相环(PLL)设计,增强了其在电网电压跌落情况下的快速跟踪能力。最后讲述了整套系统联调时遇到的问题及解决方案,如协同惯量控制策略应对电网扰动等。 适合人群:从事风力发电研究的技术人员、高校相关专业师生、对新能源发电感兴趣的工程爱好者。 使用场景及目标:适用于希望深入了解永磁直驱风力发电系统的工作原理和技术细节的人群。目标是掌握从风速建模到最终并网控制的完整流程,能够独立进行系统仿真和优化。 其他说明:文中提供了大量具体的代码示例,涵盖MATLAB、Python、C等多种编程语言,有助于读者更好地理解和实践所介绍的内容。
资源内项目源码是均来自个人的课程设计、毕业设计或者具体项目,代码都测试ok,包含核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,答辩评审绝对信服的,拿来就能用。放心下载使用!源码、数据集、部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.dataset.txt文件,仅供学习参考, 切勿用于商业用途。
本程序使用于:思迅软件、科脉软件、百威软件、泰格软件、嬴通软件等。 安装配置完连接参数后,用默认管理员账号:辞郁,密码:ciyu登录,主界面左上角,双击输入管理员辞郁密码:ciyu 进入设计模式。下载内容中有详细示例截图。 辞郁POP打印工具是一款专业的打印解决方案,主要针对零售行业的商品POP促销单。它支持多种零售软件系统,包括但不限于思迅软件、科脉软件、百威软件、泰格软件和嬴通软件。这种工具的出现极大地便利了零售业者在商品推广和营销方面的操作,通过快速生成并打印商品促销单,帮助商家更好地吸引顾客、提升销售业绩。
内容概要:本文详细介绍了利用蒙特卡洛法对电动汽车负荷进行预测的方法。首先解释了基本原理,即通过建立电动汽车出行时间、行驶里程和充电时间的概率模型,采用蒙特卡洛法进行抽样并累加每辆车的充电负荷,从而得出负荷预测结果。随后展示了具体的MATLAB代码实现,包括初始化参数设置、蒙特卡洛仿真循环、结果处理和可视化。代码中涉及到随机数生成、概率分布、数组操作等关键技术点。通过对不同类型的电动汽车(如私家车和出租车)进行建模,模拟了它们的充电行为,并分析了充电负荷的时间分布特点。最后讨论了模型的可扩展性和改进方向,如引入智能充电策略等。 适合人群:对电力系统、电动汽车技术和蒙特卡洛仿真方法感兴趣的科研人员、工程师和技术爱好者。 使用场景及目标:适用于研究和评估电动汽车对电网的影响,帮助规划和设计充电基础设施,确保电网稳定运行。同时,也为进一步优化充电策略提供了理论支持。 其他说明:文中提供的MATLAB代码可以作为学习和研究的基础,用户可以根据具体情况进行修改和完善。此外,还提到了一些常见的编程技巧和注意事项,有助于提高代码质量和效率。
内容概要:本文详细介绍了如何利用Python进行电网故障仿真,重点在于不同类型故障(单相接地、相间短路、相间短路接地)下的序分量分析。文中首先准备了必要的工具包,定义了系统参数,并通过具体的代码实例展示了如何计算和可视化各种故障状态下的正序、负序和零序分量。此外,还讨论了不同类型的故障对序分量的具体影响及其在继电保护中的应用。通过这些仿真,能够更好地理解和预测保护装置的动作特性。 适合人群:从事电力系统分析、继电保护设计以及相关领域的工程师和技术人员。 使用场景及目标:适用于研究和开发电力系统的故障检测和保护机制,帮助工程师们优化继电保护装置的参数设置,提高电力系统的稳定性和可靠性。 其他说明:文章强调了仿真过程中需要注意的关键点,如接地电阻设置、变压器接线方式、线路参数单位等,确保仿真结果的准确性。同时,提供了多个代码片段作为参考,便于读者快速上手实践。
6G中基于量子计算的路由 该代码使用量子退火来优化6G网络中的路径选择 基于图的网络,在考虑干扰和拥塞的同时,根据最短路径优化路由路径。