Application Deployment
Once you have created your application in Forms Developer, you are ready for application Web deployment. Oracle Forms Services accesses an application in Oracle Fusion Middleware through a specified URL.
The URL then accesses the HTTP Listener, which communicates with the Listener Servlet. The Listener Servlet starts a Forms run-time process (frmweb.exe
on Windows or frmweb
on UNIX and Linux) for each Forms Services session.
For information about how Forms Services run, see Oracle Forms Services in Action.
The following section are included:
Deploying Your Application
To deploy a basic form with the default parameters set up by Oracle Fusion Middleware Config Wizard:
Specifying Parameters
There are two ways to predefine parameter values for your Oracle Forms Services applications. You can define parameters by:
- Editing your application settings in the default section of the Web Configuration page of Fusion Middleware Control. The default configuration section displays the default values that are used by Oracle Forms Services.
- Managing (adding, editing, copying, deleting) other system and user parameter values in the named application configuration section (see Creating Configuration Sections in Fusion Middleware Control). For example, in the configuration section you create for
myApp
, you can add or change these parameters and their values, as shown in the following table.
Parameters specified in the named configuration section of a Web Configuration override the settings in the default section.
Note:
System Parameters cannot be overridden in the URL, while user parameters can.Creating Configuration Sections in Fusion Middleware Control
Within the configuration sections you created in step 2 of Deploying Your Application, you can specify parameters for your Oracle Forms Services applications. You can specify any application and system parameters that are available in the default section for Web Configuration page.
For example, you can set the look and feel of the application to the Oracle look and feel by setting the lookAndFeel
parameter to the value of oracle
and clicking Apply.
You can also override the default parameter values in the named configuration section. For example, to predefine the connect information of an application to <username>/<password>@orcl
, the parameter value for userid
must be set in the named configuration section by changing the parameter value of userid
to <username>/<password>@orcl
.
For other parameters that you can edit, see Forms Configuration Parameters.
Editing the URL to Access Oracle Forms Services Applications
You can directly type unrestricted parameters in the URL that accesses your Oracle Forms Services application. Using the previous example, instead of specifying the form
parameter in your configuration file, you could also type it into the URL as follows:
http://example.com:9001/forms/frmservlet?config=my_application&form=hrapp
You can use the ampersand (&) to call a combination of a form and named configuration parameters. In the above example, you are calling the form "hrapp" with the parameter settings you specified in "my_application".
Note:
Parameters specified in the URL override the parameters set in the configuration section, see Managing URL Security for Applications.Specifying Special Characters in Values of Runform Parameters
Certain considerations apply if values passed to runform parameters contain special characters. This section describes these considerations, and compares the default behavior in this release with the behavior in prior releases.
Runform parameters are those that are specified in the serverArgs applet parameter of the template HTML file. The value specified for the serverArgs parameter in the template HTML file, after variable substitution, is sometimes referred to as the command-line parameters string. It consists of a series of blank-separated name=value
pairs. The name must consist solely of alphanumeric or underscore characters. The value portion of a name=value pair can be an arbitrary string.
Default Behavior in the Current Release
The value of a runform parameter can be specified in one of three places:
- In the value of the
serverArgs
parameter in the template HTML file (for example,base.htm
). - In the value of a variable specified in the configuration file (for example,
formsweb.cfg
), which is substituted (directly or recursively) for a variable reference in (1). Such values are typically maintained using Fusion Middleware Control; see Configuring Forms Services. - As an attribute value in a URL, which is substituted directly for a variable reference in (1) or (2).
For case (3), URL syntax rules (as enforced by the browser and the application server) require that certain characters be entered as URL escape sequences ('%' followed by 2 hexadecimal digits representing the ASCII value of the character, for a total of three characters).
This requirement includes the %
character itself (which must be entered as %25
). In addition, Oracle Forms Services currently requires that the quote character ('"') be entered as %22
, even if the browser and the application server allow a quote to be entered without escaping.
URL syntax rules also allow a space to be entered as a +
(as an alternative to the URL escape sequence %20
). However in the value of the otherparams
configuration parameter, a +
is treated specially; it separates name=value pairs as opposed to indicating a space embedded in the value of a runform parameter.
For example, if a runform application has user parameters param1
and param2
, and you want to assign them the values 'a b' and 'c d', you do so by incorporating the following into a URL:
&otherparams=param1=a%20b+param2=c%20d
When specifying runform parameters in the template HTML files or in the configuration files (cases (1) and (2)), Forms requires URL escape sequences in some circumstances, allows them in others, and forbids them in still others.
Outside of the values of runform parameters, URL escape sequences must not be used. For example, the =
in a name=value pair must always be specified simply as =
, and the space that separates two adjacent name=value pairs must always be specified simply as " " (a single space character).
Within the value of a runform parameter, space (' ') must be specified as a URL escape sequence (%20
). The HTML delimiter character (specified in the configuration file) must also be specified as a URL escape sequence. And when the runform parameter is specified in the template HTML file (case (1)), quote ('"') must also be specified as a URL escape sequence (%22).
Any other 7-bit ASCII character may also be specified as a URL escape sequence, although this is not required (except possibly for %
, as noted below). Certain additional restrictions apply to the %
character. These include:
- If the HTML delimiter is
%
(the default), then an occurrence of%
within the value of a runform parameter must be escaped (specified as%25
). (This actually follows from the requirement stated above, that the HTML delimiter character be escaped). Furthermore, variable names must never begin with two hexadecimal digits that represent a 7-bit ASCII value (that is, two hexadecimal digits, the first of which is in the range 0-7). - If the HTML delimiter is not
%
, then an occurrence of%
must be escaped if it is immediately followed by an octal digit and then a hexadecimal digit. It is recommended that other occurrences of '%' also be escaped; but this is not a requirement.
Note:
You might choose to ignore this recommendation if you have existing template HTML files or configuration files created in prior releases, which use an HTML delimiter other than '%', and which contain '%' in runform parameter values.Behavior in Previous Releases
Release 9.0.4 and later behave the same as the current release except that a quote must be escaped (%22) within the value of a runform parameter in a configuration file, and in the template HTML file.
Releases before 9.0.4 did not allow URL escape sequences in runform parameter values specified in the template HTML file or the configuration file (cases (1) and (2) above). In all three cases, it was difficult or impossible to specify certain special characters, notably space, quote, and apostrophe. Also, certain transformations were applied to the parameter value before passing it to runform. Most notably, if a value began and ended with an apostrophe, these were typically stripped off. However, these transformations were not well-defined, and they differed between the Web and client/server environments.
Obtaining the Behavior of Prior Releases in the Current Release
If your applications are dependent on the behavior of prior releases, you can obtain that behavior in the current release, by simply setting the value of the escapeparams
variable to False
in the configuration file (this can be accomplished using Fusion Middleware Control).
If you want to obtain the old behavior only for selected applications, you can specify different values for the escapeparams
variable in different configuration sections. Applications that require the old behavior can specify a configuration section in which the escapeparams
variable is set to False
; applications that require (or tolerate) the behavior in the current release can specify a configuration section in which the escapeparams
variable is set to True
.
Considerations for Template Files
If you are creating your own template files, consider the following:
- It is recommended that a reference to the
escapeparams
variable (the string%escapeparams%
, if '%
' is the HTML delimiter character) appear at the beginning of the value of theserverArgs
applet parameter, followed by a space. See the shippedbase.htm
file for an example. - References to the
escapeparams
variable must appear nowhere else in the template file. If you choose to enclose the value of theserverArgs
applet parameter in apostrophes instead of quotes, then within the value of a runform parameter in your template file, apostrophes must be escaped (%27). Quotes do not require escape sequences. - It is permissible to omit the reference to the
escapeparams
variable from the beginning of the value of theserverArgs
applet parameter. This results in the behavior of prior releases, regardless of the value specified in the configuration file for theescapeparams
variable.
Considerations for Static HTML Pages
Note:
The use of static HTML or JNLP is not recommended. It is recommended that all calls to Forms applications be routed through the Forms Servlet (frmservlet
). Not doing so may result in unpredictable behavior.
The basic rule is that your static HTML must look like the HTML generated by the Forms servlet. Specifically, the value of the serverArgs
applet parameter must begin with the string escapeparams=true
(case-insensitive).
Also, in the value portion of each name=value pair, in the value of the serverArgs
applet parameter, certain characters must be specified by a URL escape sequence, as listed in the following table.
Table -3 URL Escape Sequences for Static HTML pages
Characters that must be escaped | URL Escape Sequence |
---|---|
newline ' \n ' | %0a |
space ' ' | %20 |
quote ' " ' | %22 |
percent ' % ' | %25 |
apostrophe ' ' ' | %27 |
left parenthesis ' ( ' | %28 |
right parenthesis ' ) ' | %29 |
It is also permissible to escape other 7-bit ASCII characters in the value portion of a name=value
pair.
Here's an example of what the serverArgs
applet parameter might look like in static HTML. This is for a form named "my form" (quotes not included), which is being passed the value "foo'bar" (quotes again not included) to the user-defined parameter named myparam
.
<PARAM NAME="serverArgs" VALUE="escapeparams=true module=my%20form myparam=foo%27bar">