| Oracle® Application Server Portal Configuration Guide 10g Release 2 (10.1.2) Part No. B14037-01 | 
 | 
|  Previous |  Next | 
OracleAS Portal gives you the ability to create various kinds of Web pages. You can supplement this ability with JavaServer Pages (JSPs).
This appendix describes how you can secure OracleAS Portal to allow access to only approved JSPs, and prevent unauthorized access by JSPs to portlet content. It also describes the steps required to allow access for protected external JSPs that require login.
The following topics are covered in this appendix:
Because almost any JSP using the tag library can request OracleAS Portal portlet content, there is a need for a secure way to ensure that only approved JSPs obtain access. You can control this through two mechanisms:
The <portal:usePortal> tag in the JSP
An external JSP configuration file
The configuration file identifies the OracleAS Portal instances, and page groups within those instances, to which an external JSP is allowed access.
The specific coding requirements of the configuration file are explained in Section F.1.1, "Contents of Your JavaServer Page Configuration File".
Your completed configuration file must then be identified to OracleAS Portal. This step is explained in Section F.1.3, "Location of Your JavaServer Page Configuration File".
This section contains the following sub-sections:
The required tags are:
<jps>
<portal>
<database>
<url>
<cookie>
<pageGroups>
<pageGroup>
The <jps> tag is a container tag that provides a list of OracleAS Portal instances to which external JSPs can have access.
<jps version="1.0">
Version must be set to 1.0 for the current OracleAS Portal release.
</jps>
The <portal> tag describes an individual OracleAS Portal instance.
<portal name="MyPortal" default="true">
</portal>
Table F-1 The <portal> Tag's Attributes
| Attribute | Value | 
|---|---|
| name | Any descriptive name given to an OracleAS Portal instance. The name must be unique within the configuration file. | 
| default | A trueorfalseflag indicating whether this portal is the default instance that is used if a usePortal tag does not specify a portal name. If you provide no value, default is set tofalse. | 
Only one default portal is allowed for each configuration file.
The <database> tag provides database connection information about a given OracleAS Portal instance. For example:
<database data-source="jdbc/MyPortal"/>
The data-source attribute value is the name of the data source, which must be specified in the data-sources.xml file located in the J2EE_HOME/config directory.
Here is an example of a data-source definition:
<data-source class="com.evermind.sql.DriverManagerDataSource" name="MyPortal" location="jdbc/MyPortal" xa-location="jdbc/xa/MyPortal" ejb-location="jdbc/MyPortal" connection-driver="oracle.jdbc.driver.OracleDriver" username="portal_app" password="portal_app" url="jdbc:oracle:thin:@xyz.oracle.com:1521:orcl" inactivity-timeout="30" />
The username and password attributes must be set to the OracleAS Portal application schema user name and password.
The <url> tag provides connection information to the OracleAS Portal instance. For example:
<url protocol="http" host="defg.oracle.com" port="7500" path="/pls/portal"/>
Table F-2 The <url> Tag's Attributes
| Attribute | Value | 
|---|---|
| protocol | The name of the protocol used to connect to the OracleAS Portal instance. Currently, only HTTP and HTTPS protocols are supported. If you do not specify a protocol attribute, the default will be http. | 
| host | The machine name for the OracleAS Portal middle-tier. | 
| port | Port number. If no port is specified, the default number will be 80. | 
| path | For this release, path must be set to /pls/<PORTAL-DAD-NAME>. | 
The <cookie> tag describes the OracleAS Portal cookie. For example:
<cookie name="portal" maxAge="-1" path="/" domain=".oracle.com"/>
Table F-3 The <cookie> Tag's Attributes
| Attribute | Value | 
|---|---|
| name | The name of the cookie. This must be the same as the OracleAS Portal instance cookie name. name is a required attribute of the cookie tag. | 
| maxAge | The maximum age of the cookie, specified in seconds. Specify a value of -1if you want the cookie to persist until browser shutdown. maxAge is a required attribute of the cookie tag. | 
| path | The path on the server to which the browser returns this cookie. path is a required attribute of the cookie tag. | 
| domain | This attribute should be specified only if changes were made to the SSO portlet cookie configuration. See the SSO documentation. | 
The <pageGroups> tag forms a container for the pageGroup tags. This tag has no attributes.
<pageGroups>
</pageGroups>
The <pageGroup> tag describes each individual page group's properties. For example:
<pageGroup name="JPSDemo" key="welcome" default="true"/>
Table F-4 The <pageGroup> Tag's Attributes
| Attribute | Value | 
|---|---|
| name | The page group name. This must be the name given to the page group when it was created in OracleAS Portal. | 
| key  | The page group's key. The value must match the Access Key value that was assigned to the page group in OracleAS Portal. (Note that a page group identified here must have JSP Access enabled.) | 
| default  | A flag set to trueorfalseindicating whether or not this page group is the default page group within this OracleAS Portal instance. A default page group is the one used in the usePortal tag if no page group name is supplied. If no value provided for default in this pageGroup tag, it will be set tofalse. | 
Only one default page group is allowed for each portal instance.
The following is an example of a JSP configuration file:
Example F-1 Example JavaServer Page Configuration File
<jps version="1.0">
   <portal name="MyPortal" default="true">
      <database data-source="jdbc/MyPortal"/>
      <url host="xyz.oracle.com" port="7500" path="/pls/portal"/>
      <cookie name="portal" maxAge="-1" path="/" />
      <pageGroups>
         <pageGroup name="JPSDemo"  key="welcome" default="true"/>
         <pageGroup name="JPSDemo2" key="welcome" default="false"/>
      </pageGroups>
   </portal>
   <portal name="AnotherPortal">
      <database data-source="jdbc/AnotherPortal"/>
      <url protocol="http" host="abc.oracle.com" port="8888"
         path="/pls/portal90"/>
      <cookie name="portal90" maxAge="-1" path="/" />
      <pageGroups>
         <pageGroup name="JPSDemo"  key="welcome"/>
         <pageGroup name="JPSDemo1"  key="welcome1"/>
         <pageGroup name="JPSDemo2"  key="welcome2"/>
         <pageGroup name="JPSDemo3"  key="welcome3"/>
         <pageGroup name="JPSDemo4"  key="welcome4"/>
      </pageGroups>
   </portal>
</jps>
By default, the name of the configuration file is assumed to be wwjps.xml, and the default location of the file is:
J2EE_HOME/applications/portal/portal/WEB-INF
However, your configuration file can have any other name, and can be located anywhere in the file system.
You specify the location using a context parameter in the web.xml file, which is located in the directory J2EE_HOME/applications/portal/portal/WEB-INF.
The context parameter in the web.xml file is:
<context-param>
   <param-name>oracle.webdb.service.ConfigLoader</param-name>
   <param-value>/WEB-INF/wwjps.xml</param-value>
      <description>This parameter specifies the location of the JPS
         configuration file</description>
</context-param>
External JSPs can be categorized by their login requirements:
Public JSPs, which do not require login (or to which users log in through the OracleAS Portal login link)
Protected JSPs, which do require login
Protected external JSPs have additional setup requirements. These are explained in the next section.
The following steps are required only for protected external JSPs. That is, external JSPs that require login.
In the external JSPs, if you need to log in to the portal, you need to use the following tag syntax:
<portal:usePortal id="AnyPortal" pagegroup="AnyPageGroup" login="true" />
When you execute this JSP, you will be redirected to OracleAS Single Sign-On if you are not already logged on. To make this work, look at the following sections:
Setting Up mod_osso (if not already set up)
By default, your Oracle HTTP Server is registered with OracleAS Single Sign-On. The following steps are given here only if that has been changed, and re-registration is necessary.
You need to register your Oracle HTTP Server with OracleAS Single Sign-On as a partner application. To do so:
Go to your OracleAS Single Sign-On home and login, for example:
http://abc.company.com:3000/pls/portal_sso/
Go to SSO Server administration: Administer Partner applications: Add Partner Application.
Enter the following at the prompts.
Name: Oracle HTTP Server (any name)
Home URL: http://abc.company.com:3000/
Success URL: http://abc.company.com:3000/osso_login_success
Logout URL: http://abc.company.com:3000/osso_logout_success
Click Apply. Keep a record of the values that are displayed. You will need these values in the next step.
Create a file (for example, portal.clr) based on Example F-2. Replace the values in this example file with the values you got in the previous step (when you registered your application).
Example F-2 Example Directory File
sso_server_version=v1.2 cipher_key=95CFC0004E594CB3 site_id=1325 site_token=NCZ4UZMV1325 login_url=http://abc.company.com:3000/pls/portal_sso/portal_sso.wwsso_a pp_admin.ls_login logout_url=http://abc.company..com:3000/pls/portal_sso/portal_sso.wwsso_app_admin.ls_logout cancel_url=http://abc.company..com:3000/pls/portal_sso/
After making your changes in the file, place the file in the following directory:
<Oracle HTTPhome>/Oracle HTTP/Oracle HTTP/conf/osso/
Go to <Oracle HTTPhome>/Oracle HTTP/Oracle HTTP/conf/osso/ and run:
<Oracle HTTPhome>/Oracle HTTP/Oracle HTTP/bin/apobfuscate portal.clr osso.conf
JAZN is the internal name for a Java Authentication and Authorization Service (JAAS) provider. JAAS is a Java package that enables applications to authenticate and enforce access controls upon users. The use of JAZN in OracleAS Portal is limited to the authentication of external JSPs.
Confirm that the JAZN is working with the LDAP. (You can use the demo provided by the JAZN.)
Do the following additional step:
Go to J2EE_HOME/application-deployments/portal/orion-application.xml and add the following:
<jazn provider="LDAP" location="ldap://<OIDHOST>:389" default-realm="oracle"> <jazn-web-app auth-method="SSO" /> </jazn>
Port number 389 is a default port for LDAP servers. However, any other port can be assigned. Contact your Oracle Internet Directory Administrator to obtain <host> and <port> information.
| See Also:For more information: |