cocoon系列——开发一个Web站点<!----><o:p></o:p>
<o:p></o:p>
Cocoon 2 引入了这些数据库集成功能,但它并没有被设计成完整的 Java 应用程序服务器框架。Cocoon 2 不与基于 J2EE 体系结构的服务器竞争,因为它没有提供同等级别的资源和事务管理、负载均衡和部署选项。Cocoon 2 最适合于少量复杂业务逻辑和处理主要用于内容生成的应用程序。然而,您仍然可以和 EJB 服务器一起使用 Cocoon 2。Cocoon 2 可以轻易地充当替换表示层,而更常用的 Java Servlet 和 Java Server Pages 则要逊色得多。简而言之,Cocoon 2 旨在通过从少量的功能提供最大的灵活性来满足 80/20 规则。<o:p></o:p>
<o:p></o:p>
一、配置DB连接
1.1、web.xml<o:p></o:p>
<init-param><o:p></o:p>
<param-name>extra-classpath</param-name><o:p></o:p>
<param-value>WEB-INF/extra-classes1:/ABSOLUTE-PATH-TO-ARCHIVE</param-value><o:p></o:p>
</init-param><o:p></o:p>
或者直接将jdbc驱动扔到tomcat的common\lib中<o:p></o:p>
<init-param> <o:p></o:p>
<param-name>load-class</param-name><o:p></o:p>
<param-value><o:p></o:p>
com.mysql.jdbc.Driver<o:p></o:p>
</param-value><o:p></o:p>
</init-param><o:p></o:p>
1.2、cocoon.xconf中加:
<datasources><o:p></o:p>
……<o:p></o:p>
<jdbc logger="core.datasources.personnel" name="ldodds"><o:p></o:p>
<pool-controller max="10" min="5"/><o:p></o:p>
<dburl>jdbc:mysql://localhost:3306/new_db?autoReconnect=true</dburl><o:p></o:p>
<user>root</user><o:p></o:p>
<password>bibi</password><o:p></o:p>
</jdbc><o:p></o:p>
……<o:p></o:p>
</datasources><o:p></o:p>
<o:p></o:p>
二、ESQL 逻辑表<o:p></o:p>
ESQL 逻辑表是标准 JDBC API 上较“瘦”的一层,它定义了许多映射到特定 JDBC 功能的标记。因此,逻辑表是一种为应用程序生成 JDBC 代码的简单方法。使用 ESQL 逻辑表时,必须使用许多常用结构化元素。其中每个元素都从 JDBC API 中等价的对象中派生出它的功能。在所有情况下,您都可以将 ESQL 标记同那些由 XSP 页面直接输出的用户定义标记混合在一起。您也可以使用 XSP 标记和来自其它逻辑表的标记,来定义所需的额外处理。唯一真正的限制是要确保 XSP 页面保持格式良好。<o:p></o:p>
2.1、esql:connection<o:p></o:p>
esql:connection
等价于 JDBC Connection。
正如所有 JDBC 操作最终都派生自特殊的数据库连接一样,必需将每个 ESQL 元素都适当地嵌套在 esql:connection
元素内。在单个 XSP 页面内具有多个连接元素是可能的,这样就允许单个页面同多个数据源交互。连接元素还必须包含定义如何创建数据库连接的其它元素(例如,esql:pool
)。<o:p></o:p>
第一种方法是简单地引用以前定义的连接池,使用 esql:pool
元素实现这一点:<o:p></o:p>
<esql:connection><o:p></o:p>
<esql:execute-query><o:p></o:p>
<esql:pool>myPoolName</esql:pool><o:p></o:p>
...<o:p></o:p>
</esql:execute-query><o:p></o:p>
</esql:connection><o:p></o:p>
第二种方法是直接在 esql:connection
元素内定义连接参数。使用下列元素来实现这一点:<o:p></o:p>
esql:dburl
— JDBC 连接字符串 <o:p></o:p>
esql:username
— 连接到数据库的用户名 <o:p></o:p>
esql:password
— 以上用户名的密码 <o:p></o:p>
esql:driver
— JDBC 驱动程序 <o:p></o:p>
esql:autocommit
— 指出应当自动提交 JDBC 连接 <o:p></o:p>
后一种方法的优点在于可以动态生成连接详细信息 — 例如,从当前会话检索用户名和密码。虽然这样做提供了极大程度的灵活性,但是也丧失了通过使用数据库池让 Cocoon 管理连接的性能优点。<o:p></o:p>
因此,除非需要这一动态行为,否则就建议使用 esql:pool
元素定义连接。<o:p></o:p>
2.2、esql:execute-query<o:p></o:p>
esql:execute-query
元素等价于 JDBC PreparedStatement
对象。它定义如何在给定数据库连接内执行个别查询以及应该如何处理这些查询的结果。嵌套个别 esql:execute-query
元素以创建嵌套的数据库查询是可接受的。<o:p></o:p>
2.3、esql:query<o:p></o:p>
esql:query
元素含有将要使用这一连接执行的 SQL 查询(SELECT、INSERT、UPDATE 或 DELETE)。对查询结果的处理取决于执行的查询类型。对 SELECT 语句的处理定义在 esql:results
元素内,而 INSERT、UPDATE 和 DELETE 的结果则在 esql:update-results
元素内处理。<o:p></o:p>
<esql:query><o:p></o:p>
select cat_id, name from category<o:p></o:p>
order by cat_id<o:p></o:p>
</esql:query>
<o:p></o:p>
2.4、esql:row-results<o:p></o:p>
使用 esql:row-results
元素来定义如何处理查询结果中的每一行,该元素是 esql:results
的子元素。该元素的内容被转换成由查询生成的 JDBC ResultSet
中的每一行都执行的代码。<o:p></o:p>
<esql:results><o:p></o:p>
<esql:row-results><o:p></o:p>
<category><o:p></o:p>
<esql:get-columns/><o:p></o:p>
</category><o:p></o:p>
</esql:row-results><o:p></o:p>
</esql:results><o:p></o:p>
产生下列输出:<o:p></o:p>
<categories><o:p></o:p>
<category><o:p></o:p>
<CAT_ID>1</CAT_ID><NAME>Blues</NAME><o:p></o:p>
</category><o:p></o:p>
...more results...<o:p></o:p>
</categories><o:p></o:p>
2.5、读方法(getter) 元素
<esql:results><o:p></o:p>
<esql:row-results><o:p></o:p>
<category><o:p></o:p>
...xsp:attribute elements as before...<o:p></o:p>
<xsp:logic><o:p></o:p>
if (<esql:get-int column="cat_id"/> % 2 == 0)<o:p></o:p>
{<o:p></o:p>
<xsp:attribute name="rowtype">even</xsp:attribute><o:p></o:p>
}<o:p></o:p>
else<o:p></o:p>
{<o:p></o:p>
<xsp:attribute name="rowtype">odd</xsp:attribute><o:p></o:p>
}<o:p></o:p>
</xsp:logic><o:p></o:p>
</category><o:p></o:p>
</esql:row-results><o:p></o:p>
</esql:results><o:p></o:p>
<o:p></o:p>
2.6、其它数据操作元素
esql:get-column-count
— 返回结果中列的数目。请在需要按顺序处理列的地方使用该元素来建立循环。 <o:p></o:p>
esql:get-metadata
— 返回对 ResultSetMetadata
的引用。 <o:p></o:p>
esql:get-resultset
— 返回对 JDBC ResultSet
的引用以供直接操作。 <o:p></o:p>
esql:get-row-position
— 获取结果中当前行的位置。请使用该元素来提供表的行数等功能。 <o:p></o:p>
esql:get-column-name
— 获取当前列的名称,必须用该列的位置来引用该列。在按顺序处理结果集中的列时,请使用该元素。 <o:p></o:p>
esql:is-null
— 测试给定列是否具有 NULL 值。 <o:p></o:p>
esql:get-xml
— 添加由 JDBC ResultSet
提供的功能。检索指定列的值并将其作为 XML 解析。在解析之前,可以有选择地将列的值封装在另一个元素(由 root
属性指定)中。在原始 XML 数据存放在数据库中时,请使用该元素。<o:p></o:p>
2.7、处理空结果和错误<o:p></o:p>
前面的这些示例假定查询总是成功完成并且总是返回结果。显然,事情并不总是这样的:有些查询可能不返回数据,也可能发生数据库错误(例如,由于连接故障)。ESQL 逻辑表提供允许您处理这些情形的标记。<o:p></o:p>
如果查询不返回结果,那么可以通过使用 esql:no-rows
元素来采取行动。<o:p></o:p>
...<o:p></o:p>
<esql:results><results/></esql:results><o:p></o:p>
<esql:no-results><no-results/></esql:no-results><o:p></o:p>
...<o:p></o:p>
esql:error-results
元素为处理 SQLException
提供了一个钩接(hook),该异常是在处理查询结果期间生成的。<o:p></o:p>
<o:p></o:p>
...<o:p></o:p>
<esql:error-results><o:p></o:p>
<error><o:p></o:p>
<message><esql:get-message/></message><o:p></o:p>
<trace><esql:get-stacktrace/></trace><o:p></o:p>
<string><esql:to-string/></string><o:p></o:p>
</error><o:p></o:p>
</esql:error-results><o:p></o:p>
...<o:p></o:p>
将处理结果时发生的异常情形同创建数据库连接或查询包含语法错误时发生的异常情形区分开来非常重要。这些更严重的错误并不传递给 XSP 页面,而是由 Cocoon 2 自身处理。<o:p></o:p>
2.8、将参数传递给查询
<esql:query><o:p></o:p>
select * from album<o:p></o:p>
where cat_id = <xsp-request:get-parameter name="id"/><o:p></o:p>
</esql:query><o:p></o:p>
<o:p></o:p>
2.9、嵌套查询
<esql:connection><o:p></o:p>
<esql:execute-query><o:p></o:p>
<esql:query/><o:p></o:p>
<esql:results><o:p></o:p>
<!-- results from query<o:p></o:p>
one --><o:p></o:p>
<esql:execute-query><o:p></o:p>
<esql:query/><o:p></o:p>
<esql:results><o:p></o:p>
<!-- results from query<o:p></o:p>
two --><o:p></o:p>
</esql:results><o:p></o:p>
</esql:execute-query><o:p></o:p>
</esql:results><o:p></o:p>
</esql:execute-query><o:p></o:p>
</esql:connection><o:p></o:p>
内部查询引入了一段新 ESQL 语法:<o:p></o:p>
<o:p></o:p>
<esql:query><o:p></o:p>
select alb_id as id, title, artist,<o:p></o:p>
num_tracks as tracks<o:p></o:p>
from album<o:p></o:p>
where cat_id = <esql:get-int column="cat_id" ancestor="1"/><o:p></o:p>
</esql:query><o:p></o:p>
<o:p></o:p>
在查询的 WHERE 子句中,esql:get-int
元素用于检索外部查询的当前类别值。新的 ancestor
元素指示从哪个外面查询检索该值 — 例如同第一个 esql:execute-query
ancestor 元素相关联的结果。<o:p></o:p>
<o:p></o:p>
2.10、分组数据
esql:group
和 esql:member
元素可以利用表连接结果中的这些模式来将相关记录整理在一起。esql:group
元素具有 group-on
属性。该属性标识结果中可以用来区别外部元素(换句话就是类别)的列。元素的内容定义将对每个不同类别采用的处理,而不是定义对结果的每一行的处理。esql:member
元素定义对共享由 group-on
属性定义的公共列的每一行的处理。这里,该元素含有建立每个专辑的 XML 结构所需的处理,最终的 XML 结构与嵌套查询版本生成的结构相同。<o:p></o:p>
<esql:row-results><o:p></o:p>
<esql:group group-on="cat_id"><o:p></o:p>
<category><o:p></o:p>
<!-- process category data --><o:p></o:p>
<albums><o:p></o:p>
<esql:member><o:p></o:p>
<album><o:p></o:p>
<!-- process album data --><o:p></o:p>
<id><esql:get-string column="alb_id"/></id><o:p></o:p>
</album><o:p></o:p>
</esql:member><o:p></o:p>
</albums><o:p></o:p>
</category><o:p></o:p>
</esql:group><o:p></o:p>
</esql:row-results><o:p></o:p>
<o:p></o:p>
三、表单验证
3.1描述表单
下面的示例演示了用于描述表单字段、由 Form Validator Action 所支持的 XML 格式的基本语法。<o:p></o:p>
<root><o:p></o:p>
<!-- field definitions --><o:p></o:p>
<parameter name="id" type="long" <o:p></o:p>
min="1" max="99999" nullable="no"/><o:p></o:p>
<parameter name="cat" type="long" <o:p></o:p>
min="1" max="999" nullable="no"/><o:p></o:p>
<parameter name="title" type="string" <o:p></o:p>
max-len="100" nullable="no"/><o:p></o:p>
<parameter name="artist" type="string" <o:p></o:p>
max-len="100" nullable="no"/><o:p></o:p>
<parameter name="tracks" type="long" <o:p></o:p>
max="99" nullable="no"/><o:p></o:p>
<o:p></o:p>
<constraint-set <o:p></o:p>
name="insert-album"><o:p></o:p>
<validate name="id"/><o:p></o:p>
<validate name="cat"/><o:p></o:p>
<validate name="title"/><o:p></o:p>
<validate name="artist"/><o:p></o:p>
分享到:
相关推荐
另一方面,Struts是一个专为Java Servlet和JSP技术设计的开源框架,遵循MVC设计模式,提供了ControllerServlet,用于调度Action对象处理用户请求,从而简化Web应用程序的开发流程。 综上所述,选择合适的Java开发...
Lenya的开发背景源于另一个开源项目——Cocoon,它继承并扩展了Cocoon的架构和理念,旨在为内容管理提供一个强大的平台。 **XML与XSLT在Apache Lenya中的应用** XML(可扩展标记语言)是一种用于存储和交换结构化...
Lenya的开发源自另一个开源项目——Apache Cocoon。Cocoon是一个基于组件的Web开发框架,专注于内容管理和转换。Cocoon的核心在于其XML流水线(SAX-based pipeline)概念,这一概念被Lenya继承并进一步应用到内容...
Apache Cocoon 2是一个由Apache软件基金会开发的开源内容管理框架,它以XML为中心,提供了构建Web应用程序的强大工具。Cocoon 2以其模块化和可配置性著称,能够帮助开发者快速构建复杂的Web应用,特别适合需要处理...
Delphi 12.3控件之TraeSetup-stable-1.0.12120.exe
基于GPRS,GPS的电动汽车远程监控系统的设计与实现.pdf
内容概要:本文详细介绍了如何利用MATLAB/Simulink 2018a进行单机无穷大系统的暂态稳定性仿真。主要内容包括搭建同步发电机模型、设置无穷大系统等效电源、配置故障模块及其控制信号、优化求解器设置以及绘制和分析转速波形和摇摆曲线。文中还提供了多个实用脚本,如故障类型切换、摇摆曲线计算和极限切除角的求解方法。此外,作者分享了一些实践经验,如避免常见错误和提高仿真效率的小技巧。 适合人群:从事电力系统研究和仿真的工程师和技术人员,尤其是对MATLAB/Simulink有一定基础的用户。 使用场景及目标:适用于需要进行电力系统暂态稳定性分析的研究项目或工程应用。主要目标是帮助用户掌握单机无穷大系统的建模和仿真方法,理解故障对系统稳定性的影响,并能够通过仿真结果评估系统的性能。 其他说明:文中提到的一些具体操作和脚本代码对于初学者来说可能会有一定的难度,建议结合官方文档或其他教程一起学习。同时,部分技巧和经验来自于作者的实际操作,具有一定的实用性。
KUKA机器人相关资料
基于DLR模型的PM10–能见度–湿度相关性 研究.pdf
内容概要:本文详细介绍了如何使用MATLAB/Simulink进行光伏并网系统的最大功率点跟踪(MPPT)仿真,重点讨论了电导增量法的应用。首先阐述了电导增量法的基本原理,接着展示了如何在Simulink中构建光伏电池模型和MPPT控制系统,包括Boost升压电路的设计和PI控制参数的设定。随后,通过仿真分析了不同光照强度和温度条件对光伏系统性能的影响,验证了电导增量法的有效性,并提出了针对特定工况的优化措施。 适合人群:从事光伏系统研究和技术开发的专业人士,尤其是那些希望通过仿真工具深入理解MPPT控制机制的人群。 使用场景及目标:适用于需要评估和优化光伏并网系统性能的研发项目,旨在提高系统在各种环境条件下的最大功率点跟踪效率。 其他说明:文中提供了详细的代码片段和仿真结果图表,帮助读者更好地理解和复现实验过程。此外,还提到了一些常见的仿真陷阱及解决方案,如变步长求解器的问题和PI参数整定技巧。
KUKA机器人相关文档
内容概要:本文详细探讨了双馈风力发电机(DFIG)在Simulink环境下的建模方法及其在不同风速条件下的电流与电压波形特征。首先介绍了DFIG的基本原理,即定子直接接入电网,转子通过双向变流器连接电网的特点。接着阐述了Simulink模型的具体搭建步骤,包括风力机模型、传动系统模型、DFIG本体模型和变流器模型的建立。文中强调了变流器控制算法的重要性,特别是在应对风速变化时,通过实时调整转子侧的电压和电流,确保电流和电压波形的良好特性。此外,文章还讨论了模型中的关键技术和挑战,如转子电流环控制策略、低电压穿越性能、直流母线电压脉动等问题,并提供了具体的解决方案和技术细节。最终,通过对故障工况的仿真测试,验证了所建模型的有效性和优越性。 适用人群:从事风力发电研究的技术人员、高校相关专业师生、对电力电子控制系统感兴趣的工程技术人员。 使用场景及目标:适用于希望深入了解DFIG工作原理、掌握Simulink建模技能的研究人员;旨在帮助读者理解DFIG在不同风速条件下的动态响应机制,为优化风力发电系统的控制策略提供理论依据和技术支持。 其他说明:文章不仅提供了详细的理论解释,还附有大量Matlab/Simulink代码片段,便于读者进行实践操作。同时,针对一些常见问题给出了实用的调试技巧,有助于提高仿真的准确性和可靠性。
linux之用户管理教程.md
内容概要:本文详细介绍了利用三菱PLC(特别是FX系列)和组态王软件构建3x3书架式堆垛式立体库的方法。首先阐述了IO分配的原则,明确了输入输出信号的功能,如仓位检测、堆垛机运动控制等。接着深入解析了梯形图编程的具体实现,包括基本的左右移动控制、复杂的自动寻址逻辑,以及确保安全性的限位保护措施。还展示了接线图和原理图的作用,强调了正确的电气连接方式。最后讲解了组态王的画面设计技巧,通过图形化界面实现对立体库的操作和监控。 适用人群:从事自动化仓储系统设计、安装、调试的技术人员,尤其是熟悉三菱PLC和组态王的工程师。 使用场景及目标:适用于需要提高仓库空间利用率的小型仓储环境,旨在帮助技术人员掌握从硬件选型、电路设计到软件编程的全流程技能,最终实现高效稳定的自动化仓储管理。 其他说明:文中提供了多个实用的编程技巧和注意事项,如避免常见错误、优化性能参数等,有助于减少实际应用中的故障率并提升系统的可靠性。
基于STM32的循迹避障小车 主控:STM32 显示:OLED 电源模块 舵机云台 超声波测距 红外循迹模块(3个,左中右) 蓝牙模块 按键(6个,模式和手动控制小车状态) TB6612驱动的双电机 功能: 该小车共有3种模式: 自动模式:根据红外循迹和超声波测距模块决定小车的状态 手动模式:根据按键的状态来决定小车的状态 蓝牙模式:根据蓝牙指令来决定小车的状态 自动模式: 自动模式下,检测距离低于5cm小车后退 未检测到任何黑线,小车停止 检测到左边或左边+中间黑线,小车左转 检测到右边或右边+中间黑线,小车右转 检测到中边或左边+中间+右边黑线,小车前进 手动模式:根据按键的状态来决定小车的状态 蓝牙模式: //需切换为蓝牙模式才能指令控制 *StatusX X取值为0-4 0:小车停止 1:小车前进 2:小车后退 3:小车左转 4:小车右转
矢量边界,行政区域边界,精确到乡镇街道,可直接导入arcgis使用
内容概要:本文探讨了基于IEEE33节点的主动配电网优化方法,旨在通过合理的调度模型降低配电网的总运行成本。文中详细介绍了模型的构建,包括风光发电、储能装置、柴油发电机和燃气轮机等多种分布式电源的集成。为了实现这一目标,作者提出了具体的约束条件,如储能充放电功率限制和潮流约束,并采用了粒子群算法进行求解。通过一系列实验验证,最终得到了优化的分布式电源运行计划,显著降低了总成本并提高了系统的稳定性。 适合人群:从事电力系统优化、智能电网研究的专业人士和技术爱好者。 使用场景及目标:适用于需要优化配电网运行成本的研究机构和企业。主要目标是在满足各种约束条件下,通过合理的调度策略使配电网更加经济高效地运行。 其他说明:文章不仅提供了详细的理论推导和算法实现,还分享了许多实用的经验技巧,如储能充放电策略、粒子群算法参数选择等。此外,通过具体案例展示了不同电源之间的协同作用及其经济效益。
KUKA机器人相关文档
内容概要:本文详细介绍了将光热电站(CSP)和有机朗肯循环(ORC)集成到综合能源系统中的优化建模方法。主要内容涵盖系统的目标函数设计、关键设备的约束条件(如CSP储热罐、ORC热电耦合)、以及具体实现的技术细节。文中通过MATLAB和YALMIP工具进行建模,采用CPLEX求解器解决混合整数规划问题,确保系统在经济性和环境效益方面的最优表现。此外,文章还讨论了碳排放惩罚机制、风光弃能处理等实际应用场景中的挑战及其解决方案。 适合人群:从事综合能源系统研究的专业人士,尤其是对光热发电、余热利用感兴趣的科研工作者和技术开发者。 使用场景及目标:适用于需要评估和优化包含多种能源形式(如光伏、风电、燃气锅炉等)在内的复杂能源系统的项目。目标是在满足供电供热需求的同时,最小化运行成本并减少碳排放。 其他说明:文中提供了大量具体的MATLAB代码片段作为实例,帮助读者更好地理解和复现所提出的优化模型。对于初学者而言,建议从简单的确定性模型入手,逐渐过渡到更复杂的随机规划和鲁棒优化。
网站设计与管理作业一.ppt