Form_Form与OAF页面互相调用(案例)
2014-12-27 Created By BaoXinjian
一、摘要
OAF框架和Oracle EBS都提供了Oracle基于Forms的Oracle EBSforms和基于OAF页面的集成。
你可以从OAF页面运行一个Oracle EBS form,也可以从Oracle EBS form调用一个OAF HTML页面。
1. Form调用OAF页面
通过FND_FUNCTION进行跳转
2. OAF调用Form页面
(1). 设置Item URL为form:responsibilityApplicationShortName:responsibilityKey:securityGroupKey:functionName
(2). 通过webbean中方法OAPageContext.forwardImmediatelyToForm(Stringurl)进行跳转
二、案例 - Form调用OAF页面
1. 如果你想从Oracle Applications Form直接调用OAF页面Function,你必须使用下面的Oracle API
PACKAGE FND_FUNCTION IS
procedure EXECUTE(function_name in varchar2,
open_flag in varchar2 default 'Y',
session_flag in varchar2 default 'SESSION',
other_params in varchar2 default NULL,
activate_flag in varchar2 default 'ACTIVATE',
browser_target in varchar2 default NULL);
2. 参数的传递
你也可以使用URL格式通过other_params传递额外的参数,比如name1=value1&name2=value2…
注意:在第一个参数的名/值对之前没有(&)符号,但是在后面的参数名/值对的前面都有(&)符号。
注意:open_flag和session_flag参数不显示在上面的示例中,因为对于HTML function来说,那是无效的。
3. 参数传递例子
fnd_function.execute( function_name => 'OKE_OKEKVCOM'
other_params => 'headerid='||:parameter.k_header_id||
'&Ver1='||:compare_version.version1||
'&Ver2='||:compare_version.version2);
二、案例 - 通过Item URL:OAF调用Form
1. 为Item设置ID属性,符合OA Framework File Standards,并设置Item类型属性为button,image或者链接
form:responsibilityApplicationShortName:responsibilityKey:securityGroupKey:functionName
2. 如果你想传参数给form,那么就设置Destination URI属性为使用下面格式的值(注意参数列表在每个”parameter=value”对之间使用空格隔开).
form:responsibilityApplicationShortName:responsibilityKey:securityGroupKey:functionName:param1=value1param2=value2 param3=value3
3. 参数的特殊字符 -空格
注意:如果你想传递varchar2参数值并且其中包含空格,使用”\”把字符串值包括起来。比如,要传递给form的值如下面:
TXN_NUMBER=LT INVOICE 1 =>> TXN_NUMBER=\”LT INVOICE 1\”
4. 案例,创建一个button item,设定Destination URI
三、案例 - 通过OAPageContext:OAF调用Form
1. 运行时控制通过OAPageContext控制
从OAF页面的一个按钮,图片或者链接来运行一个Oracle Form是不必需要特殊的编码步骤的。
OAButtonBean, OALinkBean和OAImageBean支持上面关于DestinationURI属性的特殊form function的URL格式。
当OAF遇到这种特殊值,它会生成合适的URL并添加一个隐藏的IFrame(内置 frame)到OAF页面。隐藏的IFrame用于Oracle EBS提供的FormsLauncher applet.
提供提交按钮来运行Oracle Form
如果你在OAF页面想通过提交按钮来运行Oracle Form,
你必须使用oracle.apps.fnd.framework.webui.OAPageContext中的OAPageContext.forwardImmediatelyToForm(Stringurl)方法
2. 简单例子
public voidprocessFormRequest(OAPageContext pageContext, OAWebBean webBean)
{
super.processFormRequest(pageContext,webBean);
if(pageContext.getParameter("Apply")!=null)
{
String destination = "form:SYSADMIN:SYSTEM_ADMINISTRATOR:STANDARD:FND_FNDMNMNU";
pageContext.forwardImmediatelyToForm(destination);
}
}
Thanks and Regards
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?