WebSphere Portal, Express Beta Version 6.1
Operating systems: i5/OS, Linux,Windows


 

Client profile information (CC/PP) in portlets

For each incoming request, the portal tries to determine the client that issued the request. It is important to determine the client in order to know its capabilities and respond properly. The portal database contains a repository of client profiles, providing all relevant information about the supported clients. The Portal uses JSR 188, which provides a standard API named "CC/PP" for accessing client profiles.

The Portal allows portlets to access the profile through a request attribute on the profile. See following code snippet, how to get the profile in a portlet and to access an profile attribute.

Figure 1. Accessing an attribute of the client profile
import javax.ccpp.Attribute;
import javax.ccpp.Profile;
.........
        
Profile clientProfile = 
    (Profile) portletRequest.getAttribute(com.ibm.portal.portlet.Constants.
  REQUEST_CLIENT_PROFILE);
String vendor = null;
if (clientProfile != null) {
    		Attribute attribute = clientProfile.getAttribute("Vendor");
    		if (attribute != null) {
        		vendor =  attribute.toString();
    		}
}

The following attributes and components are supported by the default profile implementation in the portal. The proprietary attributes supported by the portal default implementation, but not part of the UAPROF dictionary, are all collected in the component ProcessingInstructions.

The following table lists all attributes required for WebSphere Portal to work properly.

Name Component Type Description Example Value
Vendor HardwarePlatform Literal Name of the vendor manufacturing the browser or device "Netscape"
BrowserName BrowserUA Literal Name of the browser user agent associated with the current request "Navigator"
BrowserVersion BrowserUA Literal Version of the browser "6.x"
MarkupName ProcessingInstructions Literal Markup that the browser or device accepts "html"
MarkupVersion ProcessingInstructions Literal Version of the markup "ns6"
CcppAccept SoftwarePlatform Literal List of content types the device supports "text/html"
HtmlVersion BrowserUA Literal Version of Hyper Text Markup Language (HTML) supported by the browser "4.0"
HtmlCSS BrowserUA Boolean Indicates whether cascaded style sheets can be used with this browser  
FramesCapable BrowserUA Boolean Indicates whether the browser is capable of displaying frames  
IFramesCapable BrowserUA Boolean Indicates whether the browser is capable of displaying inline frames  
JavaAppletEnabled BrowserUA Boolean Indicates whether the browser supports Java applets  
JavaScriptEnabled BrowserUA Boolean Indicates whether the browser supports JavaScript  
TablesCapable BrowserUA Boolean Indicates whether the browser is capable of displaying tables  
HtmlNestedTable BrowserUA Boolean Indicates whether the browser is capable of displaying nested tables  
WmlVersion WapCharacteristics Literal Wireless Markup Language (WML) version supported by the device "1.1"
WmlTable WapCharacteristics Literal Indicates whether the WML device is capable of displaying tables  
FragmentIdentifier ProcessingInstructions Boolean Indicates whether the browser or device supports fragment identifiers  

For more information on JSR 188, please see its detailed description page at the Java Community Process site.

 

Related information

Parent topic: Understanding the basics
Library | Support | Terms of use |