Oracle Forms Services Architecture
Oracle Forms Services Architecture
Contents
Forms Services Architecture
Summary
Oracle EBS Form架构 (Forms
Services Architecture) 是典型的三层, 所有客户端触发的 Trigger的处理都发生在 DB层和应用服务器层。 Forms
Services Architecture 主要包括四大组件: the Forms Servlet, the Java Applet(Forms Client),
the Forms Listener Servlet, and the Forms Runtime Engine


Forms Servlet
Form Servlet是一个 Java
Servlet,运行于 Oracle HTTP Server 中,用于为客户端创建动态 HTML
Form Applet
Form Applet是一个 Java
Applet, 提供界面来展示 (交互 )Form
Runtime Engine.
Applet采用 Java 创建的基于 HTML的程序。浏览器将其暂时下载到用户的硬盘上,并在 Web 页打开时在本地运行。含有 Applet 的网页的HTML 文件代码中部带有 <applet>和</applet> 这样一对标记,当支持 Java 的网络浏览器遇到这对标记时,就将下载相应的小应用程序代码并在本地计算机上执行该 Applet 。
查看EBS Applet 的初始页面的源代码

可以看到,确实是有 <applet> 和 </applet> 这样一对标记 ,
code="oracle.forms.engine.Main" 是要运行的 Java
Applet Class,
这个Java类在fndforms.jar中(fndforms.jar会在Applet启动前预加载)
codebase="/OA_JAVA/", 给出Class 所在的位置
archive="/OA_JAVA/oracle/apps/fnd/jar/fndforms.jar, /OA_JAVA/oracle/apps/fnd/jar/fndformsi18n.jar,….” 是指Applet 运行前,需要预加载的 jar 文件

<PARAM name=serverArgs value="module=/slot/ems2384/appmgr/apps/apps_st/appl/fnd/12.0.0/forms/US/FNDSCSGN….> 说明,Applet 打算加载的第一个 Form 文件是FNDSCSGN.fmb
打开FNDSCSGN.fmb 就可以看到,这个 form 实际上EBS 的 Navigator的主界面

Forms Listener Servlet
Form Listener Servlet也是一个 Java
Servlet ,它运行在支持 Servlet引擎的 Web
Server 中(例如OC4J )。 Form
Listener Servlet负责管理每一个 Forms Runtime
process ,通过Web Server 管理 Client和 Forms
Runtime Process 的交互。
Forms Runtime Engine
Form Runtime Engine是运行于 App
Server 上的一个进程,这个进程是有 Form Listener
Servlet 触发的。Forms Runtime Engine 是真正处理所有业务逻辑和 Form 功能的地方。 fmx,plx,mmx这些“可执行文件”就是被 Form
Runtime Engine 调用的。
It is important to understand that all of the Forms logic is executed by the Forms Runtime Engine
running on this middle tier. That is, the Forms Runtime Engine opens the appropriate FMX file, connects to the database and executes the Form. No
logic executes on the client. Only what Oracle classes as UI information is sent to the client. Each major action on the client, such as navigating between Form fields, choosing an item from a list, etc,
incurs a round trip to the Application server in order to be processed by the Forms Runtime Engine.
--Oracle Web Forms(http://doc.xmarc.net/xmarc6/es/Fire/fug/webforms.htm)
A Complete Process
大体过程:首先用户通过浏览器输入 Application 的网址(eg.
http://domain:port/forms/frmservlet),然后 HTTP
Server 中Form Servlet 接收请求之后,生成一个 HTML文件并传回到客户端 (生成的过程实际上是在静态网页的基础上加入和环境相关的变量 ),这个 HTML文件是包含 <Applet> 程序的,这个Applet 就是用来展示 Form的容器,同时应用程序的逻辑是执行在 Middle
Server 层上。
接下来是一个详细的运行时过程

1] 在浏览器中输入 URL ,准备访问 Form应用
http://domain:port/forms/frmservlet
2]中间层的 HTTP 服务器接收到用户请求之后, 再通知Form
Servlet 。
3] Forms Servlet 为客户端动态产生一个 HTML 页面, 这个页面包含启动 Form 的所有信息。
就像之前提到的,可以打开这个 HTML 页面源代码,就可以看到里面的细节。

4] 如果是第一次登陆的话,想要运行 HTML 中的Applet ,就必须先通过 HTTP
Server 下载相应的 jar文件 (HTML 页面的源代码中 archive部分 ) 。
5] Applet启动后 ( 一般会先运行 FNDSCSGN.fmb(Navigator
Form)), Applet 这是会通知 Forms
Listener Servlet, Forms Listener
Servlet 然后会在中间层启动一个 Forms Runtime
Engine Session。
6] Forms Listener Servlet建立一个 Form
Runtime Engine 的连接, Form Runtime
Engine 会连接数据库并且加载运行时文件 (fmb,plx,mmx 文件)

7] Forms applet展示加载的 Form.
8] Forms Listener Servlet通过 OC4J 或者HTTP
Server 管理 Form Applet和 Form
Runtime Engine 的交互。
Reference
J2EE, Web Services, and Internet Applications
http://docs.oracle.com/cd/B10464_05/core.904/b10375/webstapp.htm
Oracle Web Forms
http://doc.xmarc.net/xmarc6/es/Fire/fug/webforms.htm
转载请注明出处:http://blog.csdn.net/pan_tian/article/details/7645710
Oracle Forms Services Architecture的更多相关文章
- Oracle Forms 10g Tutorial Ebook Download - Oracle Forms Blog
A step by step tutorial for Oracle Forms 10g development. This guide is helpful for freshers in Orac ...
- How To Install Oracle Forms 12c On Windows 7
Below is the step by step guide to install Oracle Forms 12c on Windows 7. To install Oracle Forms 12 ...
- Upload Files To FTP in Oracle Forms D2k
Upload Files To FTP in Oracle Forms D2k Use following procedure to upload files to Ftp. PROCEDURE ...
- Download Oracle Forms 6i
To download Oracle Forms Developer 6i from Oracle click this link http://download.oracle.com/otn/nt/ ...
- Number To Indian Rupee Words in Oracle Forms / Reports
Convert numbers to Indian Rupees format in Oracle Forms / Reports.Create the below mention function ...
- Creating Custom Login Screen In Oracle Forms 10g
Below is the example plsql unit to validate login credentials and after successful validation open a ...
- Writing Text Files On The Client in Oracle Forms 10g
Below is the example to write file on client in Oracle Forms 10g with webutil library package.Note: ...
- Displaying Window In Center In Oracle Forms 6i
Center window automatically in Oracle Forms 6i, use the following procedure by passing window name ...
- Adding List Item Element At Runtime In Oracle Forms
Add combo list / drop down list item element at runtime in Oracle forms.SyntaxPROCEDURE ADD_LIST_ELE ...
随机推荐
- 实验与作业(Python)-文件操作
1.CSV文件的处理 下载-身份证号文件 导入: 读入"身份证号.txt",然后打印出来.注意:是否多打了一行,为什么? 读入"身份证号.txt",然后存储到& ...
- ZooKeeper之(五)集群管理
在一台机器上运营一个ZooKeeper实例,称之为单机(Standalone)模式.单机模式有个致命的缺陷,一旦唯一的实例挂了,依赖ZooKeeper的应用全得完蛋. 实际应用当中,一般都是采用集群模 ...
- 20160226.CCPP体系详解(0036天)
程序片段(01):01.多线程.c+02.多线程操作.c 内容概要:多线程 ///01.多线程.c #include <stdio.h> #include <stdlib.h> ...
- NLP系列(4)_朴素贝叶斯实战与进阶
作者: 寒小阳 && 龙心尘 时间:2016年2月. 出处:http://blog.csdn.net/han_xiaoyang/article/details/50629608 htt ...
- logistic分类
对Logistic回归模型,个人做的一些总结: 公式就不套用了,教材上面基本都有而且详细.logistic回归用图形化形式描述如下: logistic回归是一种简单高效的分类模型,它不仅可以通过学习来 ...
- Activtiy完全解析(二、layout的inflate过程)
转载请标明出处: http://blog.csdn.net/xmxkf/article/details/52457893 本文出自:[openXu的博客] 在上一篇文章<Activtiy完全 ...
- Swift类型推测在可选调用中的小提示
我们知道Swift中协议里也有对应于Objc中的可选方法或计算属性,当然协议必须以@objc伪指令修饰否则不可以哦. 如下示例: @objc protocol Transaction{ fun com ...
- Android艺术开发探索第四章——View的工作原理(下)
Android艺术开发探索第四章--View的工作原理(下) 我们上篇BB了这么多,这篇就多多少少要来点实战了,上篇主席叫我多点自己的理解,那我就多点真诚,少点套路了,老司机,开车吧! 我们这一篇就扯 ...
- 如何编写入门级redis客户端
概述 Redis是开源的.基于内存的数据结构存储系统,可用作数据库.缓存以及消息代理方面.Redis支持许多种数据结构,并内置了丰富的诸如冗余.脚本.事务.持久化等功能,深受业界喜爱,被各种业务系统广 ...
- Java进阶(四十四)线程与进程的特征及区别
线程与进程的特征及区别 定义及特征 进程 指在系统中能独立运行并作为资源分配的基本单位,它是由一组机器指令.数据和堆栈等组成的,是一个能独立运行的活动实体. 进程的特征: 1.动态性:进程的实质是 ...