72. XPages的文档数据源

2024-02-01 18:48
文章标签 文档 数据源 72 xpages

本文主要是介绍72. XPages的文档数据源,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在经典的Lotus Notes应用程序开发中,表单与Notes文档密不可分,在位于表单的代码里获取当前文档几乎是后续所有操作和运算的起点。在XPages里,页面和数据虽然在架构上是分开的,但是一个用作表单的XPage的数据源通常还是一个Notes文档,只不过在SSJS里可以直接使用的document1等变量对应的是一个Java的com.ibm.xsp.model.domino.wrapped.DominoDocument对象。如果只用SSJS编程,这些变量具有和LotusScript里NotesDocument类似的方法可以读写字段。但如果要用Java开发,很多人已经习惯了使用lotus.domino包【注1】里的类,它们与LotusScript里的Notes类有几乎一一对应的属性和方法。那么怎样从一个设定了数据源为一个Domino文档的XPage获取代表该文档的lotus.domino.Document类型的Java对象呢?笔者写了如下的工具方法,可以在managedbean里调用:

	public static Document getCurrentDocument() throws Exception{UIViewRootEx2 view=(UIViewRootEx2) FacesContext.getCurrentInstance().getViewRoot();for (DataSource ds : view.getData()){if (ds instanceof DominoDocumentData){DominoDocumentData ddd=(DominoDocumentData) ds;DominoDocument dd=(DominoDocument) ddd.getDataObject();return dd.getDocument();}}throw new AppException("No document data source is found.");}

UIViewRootEx2 view是代表整个XPage的视图对象,它的getData()方法返回该页面添加的所有数据源,这些对象都实现了com.ibm.xsp.model.DataSource接口。如果添加了一个Domino文档,就会产生一个类型为com.ibm.xsp.model.domino.DominoDocumentData的对象,从这个数据源对象的getDataObject()方法可以返回一个com.ibm.xsp.model.domino.wrapped.DominoDocument对象,从它的getDocument()方法才能最终得到我们想要的lotus.domino.Document对象。如果当前XPage没有添加任何Domino文档数据源,则抛出一个自定义的异常AppException(简单扩展Exception,统一标志自定义的异常)。

com.ibm.xsp.model.domino.wrapped.DominoDocument类(以后简称DominoDocument)从名称就显示了它是一个包装器(wrapper),实际上它也确实是XPages对lotus.domino.Document类(以后简称Document)的包装,因为Document类不能满足在一个XPage上作数据源的要求,XPages构建了一个复杂的类和接口的层次【注2】,Document只是在最底层作为和Lotus Domino平台的接口读写文档的数据,最上层的com.ibm.xsp.model.domino.DominoDocumentData类作为数据源,和它绑定的各个表单控件从中读写数据,还要在同一页面每次被提交后和视图一道恢复状态。因此,在XPages环境下用Java编程时,不少情况用DominoDocument比Document更合适。比如用户填写了一个XPage表单后,点击一个按钮触发managed bean里的事件代码,在业务逻辑里读取用户输入的字段值,修改和保存表单背后的Domino文档时,就都应该调用DominoDocument的相应方法,而不能用Document,因为与在Lotus Notes客户端NotesDocument的各字段动态获得用户的输入值不同,在XPages里更新的是DominoDocument对象,而不是底层的Document。所以只有从DominoDocument对象才能获得用户输入的值;保存时如果直接调用Document的save方法,则会丢失用户的修改;若要修改文档,也要使用DominoDocument对象,否则在调用DominoDocument的save方法时,Document上做的修改会被DominoDocument对应的字段值覆盖掉。既然我们要经常获得和使用这个DocuminoDocument对象,也就应该像Document一样写一个工具方法:

	public static DominoDocument getCurrentDominoDocument() throws Exception{UIViewRootEx2 view=(UIViewRootEx2) FacesContext.getCurrentInstance().getViewRoot();for (DataSource ds : view.getData()){if (ds instanceof DominoDocumentData){DominoDocumentData ddd=(DominoDocumentData) ds;return (DominoDocument) ddd.getDataObject();}}throw new AppException("No document data source is found.");}

有了这个对象我们就可以像下面这样读取修改和保存文档数据源。

		DominoDocumentData domDoc=XSPUtil.getCurrentDominoDocument();String status = domDoc.getItemValueString("Status");domDoc.replaceItemValue("Action", "");domDoc.save();

注1:lotus.domino包随R5发布,自那以后Java访问Lotus Domino对象都是藉由其中的类, XPages API里有关Domino对象的类也是依靠调用lotus.domino包。

 

注2:下面只是列举了XPages API里与Domino文档数据源相关的部分类和接口的层次:

Classcom.ibm.xsp.model.domino.DominoDocumentData

 java.lang.Object

 extended by com.ibm.xsp.complex.ValueBindingObjectImpl

     extended by com.ibm.xsp.model.AbstractDataSource

         extended by com.ibm.xsp.model.AbstractDocumentDataSource

              extended by com.ibm.xsp.model.domino.DominoDocumentData

All Implemented Interfaces:

ComponentBindingObject,ValueBindingObject, DataPublishingObject, DataSource, DocumentDataSource,javax.faces.component.StateHolder

 

Classcom.ibm.xsp.model.domino.wrapped.DominoDocument

java.lang.Object

 extended by com.ibm.xsp.model.domino.wrapped.DominoDocument

All Implemented Interfaces:

   com.ibm.xsp.model.DataObject, java.io.Serializable

这篇关于72. XPages的文档数据源的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/668135

相关文章

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

Python实现合并与拆分多个PDF文档中的指定页

《Python实现合并与拆分多个PDF文档中的指定页》这篇文章主要为大家详细介绍了如何使用Python实现将多个PDF文档中的指定页合并生成新的PDF以及拆分PDF,感兴趣的小伙伴可以参考一下... 安装所需要的库pip install PyPDF2 -i https://pypi.tuna.tsingh

SpringBoot利用dynamic-datasource-spring-boot-starter解决多数据源问题

《SpringBoot利用dynamic-datasource-spring-boot-starter解决多数据源问题》dynamic-datasource-spring-boot-starter是一... 目录概要整体架构构想操作步骤创建数据源切换数据源后续问题小结概要自己闲暇时间想实现一个多租户平台,

Python批量调整Word文档中的字体、段落间距及格式

《Python批量调整Word文档中的字体、段落间距及格式》这篇文章主要为大家详细介绍了如何使用Python的docx库来批量处理Word文档,包括设置首行缩进、字体、字号、行间距、段落对齐方式等,需... 目录关键代码一级标题设置  正文设置完整代码运行结果最近关于批处理格式的问题我查了很多资料,但是都没

Python自动化Office文档处理全攻略

《Python自动化Office文档处理全攻略》在日常办公中,处理Word、Excel和PDF等Office文档是再常见不过的任务,手动操作这些文档不仅耗时耗力,还容易出错,幸运的是,Python提供... 目录一、自动化处理Word文档1. 安装python-docx库2. 读取Word文档内容3. 修改

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

SpringBoot3集成swagger文档的使用方法

《SpringBoot3集成swagger文档的使用方法》本文介绍了Swagger的诞生背景、主要功能以及如何在SpringBoot3中集成Swagger文档,Swagger可以帮助自动生成API文档... 目录一、前言1. API 文档自动生成2. 交互式 API 测试3. API 设计和开发协作二、使用