All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.com.ibm.as400.util.servlet.ServletHyperlink Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: ServletHyperlink.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2001 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.util.servlet;

import com.ibm.as400.access.ExtendedIllegalStateException;
import com.ibm.as400.util.html.HTMLHyperlink;
import com.ibm.as400.util.html.URLEncoder;
import com.ibm.as400.access.Trace;

import java.util.Enumeration;
import java.util.Properties;
import java.beans.PropertyChangeSupport;
import java.beans.PropertyChangeListener;
import java.beans.PropertyVetoException;

import javax.servlet.http.*;

/**
*  The ServletHyperlink class represents an HTML hyperlink tag.
*  
*  

This example creates an ServletHyperlink and displays the HTML tag. *

*  ServletHyperlink link = new ServletHyperlink("http://www.myCompany.com", "myCompany Home Page");
*  link.setHttpServletResponse(resp);
*  link.setPathInfo("/myServletDirectory/servlet");
*  System.out.println(link.getTag());
*  
* *

Here is the output of the ServletHyperlink: *

*  <a href="http://www.myCompany.com/myServletDirectory/servlet&SomeSessionID=942349280740">myCompany Home Page</a>
*  
* *

This example creates an ServletHyperlink and sets two properties. *

*  ServletHyperlink link = new ServletHyperlink("http://www.myCompany.com", "myCompany Home Page");
*  Properties properties = new Properties();
*  properties.put("userID", "fred");
*  properties.put("employeeID", "01234567");
*  link.setProperties(properties);
*  link.setHttpServletResponse(resp);
*  link.setPathInfo("/myServletDirectory/servlet");
*  System.out.println(link.getTag());
*  
* *

Here is the output of the ServletHyperlink: *

*  <a href="http://www.myCompany.com/myServletDirectory/servlet?userid=fred&employeeID=01234567&SomeSessionID=942349280740">myCompany Home Page</a>
*  
* *

ServletHyperlink objects generate the following events: *

    *
  • PropertyChangeEvent *
**/ public class ServletHyperlink extends HTMLHyperlink { static final long serialVersionUID = 6349134986210346587L; private HttpServletResponse response_; // An http servlet response **this needs to be // transient or else you can't do serialization. private String pathInfo_; // The extra path info to the servlet location. // ex. - http://myServlet/myPathInfo transient PropertyChangeSupport changes_; //@CRS /** * Creates a default ServletHyperlink object. **/ public ServletHyperlink() { } /** * Creates a ServletHyperlink object with the specified resource link. * @param link The Uniform Resource Identifier (URI). **/ public ServletHyperlink(String link) { super(link); } /** * Creates a ServletHyperlink object with the specified resource link * represented by the specified text. * @param link The Uniform Resource Identifier (URI). * @param text The text representation for the resource. **/ public ServletHyperlink(String link, String text) { super(link, text); } /** * Creates a ServletHyperlink object with the specified resource link * and target frame represented by the specified text. * @param link The Uniform Resource Identifier (URI). * @param text The text representation for the resource. * @param target The target frame. **/ public ServletHyperlink(String link, String text, String target) { super(link, text, target); } /** * Creates a ServletHyperlink object with the specified resource link, link text, * target frame, resource link path, and HTTPServlet response. * @param link The Uniform Resource Identifier (URI). * @param text The text representation for the resource. * @param target The target frame. * @param path The resource link path information. * @param response The Http servlet response. **/ public ServletHyperlink(String link, String text, String target, String path, HttpServletResponse response) { super(link, text, target); setPathInfo(path); setHttpServletResponse(response); } /** Adds a PropertyChangeListener. The specified PropertyChangeListener's propertyChange method is called each time the value of any bound property is changed. @see #removePropertyChangeListener @param listener The PropertyChangeListener. **/ public void addPropertyChangeListener(PropertyChangeListener listener) { if (listener == null) throw new NullPointerException("listener"); if (changes_ == null) changes_ = new PropertyChangeSupport(this); //@CRS changes_.addPropertyChangeListener(listener); //must call the parents change listener since it is //in a different package. super.addPropertyChangeListener(listener); } /** * Returns a copy of the ServletHyperlink. * * @return An ServletHyperlink. **/ public Object clone() //$A2A { ServletHyperlink l = new ServletHyperlink(); try { if (getHttpServletResponse() != null) l.setHttpServletResponse(getHttpServletResponse()); if (getProperties() != null) l.setProperties(getProperties()); // @A5C if (getLocation() != null) //$A3A l.setLocation(getLocation()); //$A3A if (getPathInfo() != null) // @A4A l.setPathInfo(getPathInfo()); // @A4A if (getAttributes() != null) // @A4A l.setAttributes(getAttributes()); // @A4A if (getLink() != null) l.setLink(getLink()); if (getTarget() != null) l.setTarget(getTarget()); if (getText() != null) l.setText(getText()); if (getTitle() != null) l.setTitle(getTitle()); if (getDirection() != null) l.setDirection(getDirection()); if (getLanguage() != null) l.setLanguage(getLanguage()); if (getName() != null) l.setName(getName()); } catch (PropertyVetoException e) { /* Ignore */ } return l; } /** * Returns the direction attribute tag. * @return The direction tag. **/ String getDirectionTag() { if ((getDirection() != null) && (getDirection().length() > 0)) return " dir=\"" + getDirection() + "\""; else return ""; } /** * Returns the Http servlet response. * @return The response. **/ public HttpServletResponse getHttpServletResponse() { return response_; } /** * Returns the language attribute tag. * @return The language tag. **/ String getLanguageTag() { if ((getLanguage() != null) && (getLanguage().length() > 0)) return " lang=\"" + getLanguage() + "\""; else return ""; } /** * Returns the path information. * @return The path. **/ public String getPathInfo() { return pathInfo_; } /** * Returns the HTML tag that represents the resource link. * @return The HTML tag. **/ public String getTag() { return getTag(getText(), getProperties()); } /** * Returns the HTML tag that represents the resource link * with the specified text and properties. The original ServletHyperlink object text * and properties are not changed/updated. * @param text The text. * @param properties The Properties. * @return The HTML tag. **/ public String getTag(String text, Properties properties) { // Verify that the link has been set. if (getLink() == null) { Trace.log(Trace.ERROR, "Attempting to get tag before setting the link."); throw new ExtendedIllegalStateException("link", ExtendedIllegalStateException.PROPERTY_NOT_SET); } // Validate the text parameter. if (text == null) throw new NullPointerException("text"); // create the tag. StringBuffer link = new StringBuffer(getLink()); //path info for servlet ex.- http://myServer/myPathInfo if (pathInfo_ != null) { // if the link ends with a "/", the path does not need a leading "/" if (getLink().endsWith("/")) { if (pathInfo_.startsWith("/")) { pathInfo_ = pathInfo_.substring(1); } else { // pathInfo_ = pathInfo_; } } else //link does not end with a "/", so the path needs to start with "/" { if (pathInfo_.startsWith("/")) { // pathInfo_ = pathInfo_; } else { pathInfo_ = "/" + pathInfo_; } } // place holder for real implementation... link.append(URLEncoder.encode(pathInfo_, false)); } if (properties != null) { String name; String parmStart = "?"; Enumeration propertyList = properties.propertyNames(); while (propertyList.hasMoreElements()) { name = (String)propertyList.nextElement(); link.append(parmStart); link.append(URLEncoder.encode(name)); link.append("="); link.append(URLEncoder.encode(properties.getProperty(name))); parmStart = "&"; } } StringBuffer url = new StringBuffer(); if (response_ != null) url.append(response_.encodeURL(link.toString())); else url.append(link.toString()); // create the tag. StringBuffer buffer = new StringBuffer(); buffer.append(""); buffer.append(text); buffer.append(""); return buffer.toString(); } /** * Deserializes and initializes transient data. **/ private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { in.defaultReadObject(); //@CRS changes_ = new PropertyChangeSupport(this); } /** Removes the PropertyChangeListener from the internal list. If the PropertyChangeListener is not on the list, nothing is done. @see #addPropertyChangeListener @param listener The PropertyChangeListener. **/ public void removePropertyChangeListener(PropertyChangeListener listener) { if (listener == null) throw new NullPointerException("listener"); if (changes_ != null) changes_.removePropertyChangeListener(listener); //@CRS //must call the parents change listener since it is //in a different package. super.removePropertyChangeListener(listener); } /** * Sets the Http servlet response for the resource link. * * @param response The Http servlet response. **/ public void setHttpServletResponse(HttpServletResponse response) { if (response == null) throw new NullPointerException("response"); HttpServletResponse old = response_; response_ = response; if (changes_ != null) changes_.firePropertyChange("response", old, response); //@CRS } /** * Sets the path information for the resource link. * * @param path The path information. **/ public void setPathInfo(String path) { if (path == null) throw new NullPointerException("path"); String old = pathInfo_; pathInfo_ = path; if (changes_ != null) changes_.firePropertyChange("path", old, path); //@CRS } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy