CATEGORII DOCUMENTE |
Asp | Autocad | C | Dot net | Excel | Fox pro | Html | Java |
Linux | Mathcad | Photoshop | Php | Sql | Visual studio | Windows | Xml |
If you are developing Java applications for the World Wide Web, this chapter will help you start writing Java applets that will navigate the Web. It introduces you to some of the basic concepts of the World Wide Web and explains, in detail, the Java classes that help you tap into the resources on the Web from within a Java application. In addition, it describes the exception signals that are thrown when an error is detected while connecting to or using a resource available over the network. The chapter project illustrates how you can use the Java classes to access objects specified by Uniform Resource Locator addresses. This will help you get started with writing your own Java programs that interact with the Internet.
As its name indicates, the World Wide Web is a global network of computers. Web clients request and receive information from Web servers. Just as in postal addresses in different countries, the location of information may vary from one computer to another. If each computer had its own addressing scheme for retrieving its data, then the process of transparently accessing this information would become very difficult. The architects of the Web formulated an addressing scheme that could be used by one and all to serve and access information on the Web. Information on this network is accessible using an address specification called a URL. URL stands for Uniform Resource Locator. It is a structured address that uniquely identifies a resource (be it a document, an image, or whatever) on the World Wide Web.
A complete URL consists of a protocol specifier followed by a string, whose format depends on the protocol specification. Many protocols are supported on the World Wide Web, the most popular being the HTTP or HyperText Transfer Protocol. Other popular protocols are news (to read Usenet newsgroups), gopher (the Gopher protocol) and many more. The client-server interaction is markedly different among the various protocols. The basic syntax of a HTTP URL is as follows:
https://hostname[:portnumber]/directory/filename
The http denotes the protocol type. Colons and slashes (/) are used as delimiters. The hostname field is used to specify an Internet hostname (e.g., www.syr.edu). The portnumber is an optional field that is used to specify the port on the target host, at which an http server is running. If it is omitted then the default port for the protocol is used. The directory and file name fields are used to specify the path name of the document that is to be retrieved. This path name is relative to the directory that the http server makes public. Figure 11-1 looks at an example of an HTTP Uniform Resource Locator in detail.
Figure 11-1 Anatomy of a HyperText Transfer Protocol (HTTP)
URL
World Wide Web browsers have become very popular. Information that is out there on the Internet is just a click of the mouse button away. How does the browser distinguish between image files, text files, audio files, and the many other file formats that exist? Part of the protocol between the client and the server involves sending some header or context information about the data that is being sent by the server. The Multipurpose Internet Mail Extensions (MIME) format specifies this context information. A MIME type is of the format:
type/subtype.
Using this information, the client (browser) can identify the type of file that it retrieved. The major types supported on the World Wide Web are: text, image, audio, video, and application. Even among these major types of files there are different formats. For example, two popular data formats for image files are GIF (Graphics Interchange Format) and TIFF (Tagged Image File Format). The subtype of the MIME-type specifies the exact format of the file. This table lists some sample content types and their corresponding MIME-types:
|
|
Content Type |
MIME-Type/Subtype |
|
|
GIF image |
image/gif |
TIFF image |
image/tiff |
Plain text file |
text/plain |
HTML file |
text/html |
Audio file (AU format) |
audio/basic |
|
Java provides many classes that can be used to write applications that access resources on the World Wide Web. The URL class encapsulates the concept of a Uniform Resource Locator. The URL class and the Applet class will satisfy most of the needs of Java Web applications. The designers of the Java Development Kit included a set of extensible classes that are very useful for programmers who are developing Web browsers and for those involved in developing protocols to be used on the Web.
Each protocol has its own set of specifications for client-server interaction. If you want to write your own protocol handler in Java, you must extend and implement a number of classes. The first of these is the URLStreamHandler class. This class must be extended to implement the protocol-specific functionality. The URLConnection class represents a connection to an object referenced by a URL. The implementation of this class also is protocol-specific. It is this class that determines what type of content is in the file referenced by the URL.
For each type of file format, (such as GIF or HTML) there is an associated MIME-type/subtype combination. The ContentHandler class must be extended for each MIME-type. Figure 11-2 shows the basic relationships between URLs, ProtocolHandlers, and ContentHandlers.
Figure 11-2 URL class relationships
The basic functionality required of a ContentHandler is very small. A ContentHandler object should be able to read data off a URLConnection and construct an object that represents that content type. So if there is a subclass of Image that represents a GIF image, a ContentHandler for GIF files would simply read the data off the URLConnection and return a GIFImage object.
The URLStreamHandlerFactory and ContentHandlerFactory interfaces may be implemented so that the protocol-specific and content-specific classes can be constructed within the factory object. This provides a simple, uniform interface that the Java classes use to manufacture different protocol-specific or content-specific classes without explicitly specifying the class name. All these classes and interfaces provide a useful abstraction for developers of applications, such as Web browsers. ContentHandlers provide a means by which even nonstandard data formats can be viewed without having a viewer installed on your local machine. Using Java, you get the viewer bundled along with the data!
Implementing a protocol handler or a content handler is highly specific to the nature of the protocol or the format of the data and is beyond the scope of this book. As a consequence, some of the method descriptions are not accompanied by concrete examples. The HotJava browser uses implementations of protocol and content handlers written in Java. If you develop a protocol handler or a content handler, you will need to refer to the browser's documentation to determine the naming policy for these classes and also to determine where these classes must be installed so that the browser uses your protocol and content handlers.
Exceptions signal abnormal error conditions within the application. In object-oriented terminology, a method that detects an error may throw (or generate) an exception. In order to detect this error condition, the application that invoked the method must catch the exception. The Java keywords try and catch are used to detect exceptions. Exceptions are usually caught to inform the user that something bad happened. Exceptions related to URLs and networking are described at the end of the summary section.
Table 11-1 summarizes the classes and interfaces described in this chapter.
|
||||||||||||||||||||||||||||||
ContentHandler
Purpose
To interpret data read from a URLConnection object and construct an object that represents a specific MIME-type/subtype combination, such as image/gif, text/plain, and so on.
Syntax
public class ContentHandler extends Object
Description
This abstract class must be subclassed to implement content handlers for specific MIME-type/subtype combinations. ContentHandlers read data from the URLConnection stream and construct an object that represents the MIME-type. Subclasses of this class can be used in Web browsers to interpret specific MIME-type/subtype combinations. Figure 11-2 shows the basic relationships between URLs, ProtocolHandlers and ContentHandlers. Applications should not construct ContentHandlers directly. Instead, they should use the getContent methods of the URL class or the URLConnection class. This method constructs and returns an instance of a ContentHandler object that is appropriate for the MIME-type of the connection. By default, the URLConnection class combines the MIME-type and subtype to form a path name for the Java class. It then looks for a Java .class file of this name in the sun/net/www/content directory (if such a directory is found relative to the directory in which the standard Java classes were installed). For example, if the MIME-type/sub-type returned were image/gif, the default content handler for this object would be sun/net/www/content/image/gif.class. Figure 11-3 shows the inheritance diagram for the ContentHandler class.
Figure 11-3 Inheritance diagram for the ContentHandler class
PackageName
java.net
Imports
import java.net.ContentHandler;
Constructors
public ContentHandler()
Parameters
None.
Example
The following example shows how you can write your own content handlers.
// File: tdif.javagetContent(URLConnection)
ClassName
ContentHandler
Purpose
Reads and interprets the data from a URLConnection stream and constructs an object that represents the MIME-type/subtype combination handled by this class.
Syntax
public abstract Object getContent(URLConnection urlc) throws IOException
Parameters
urlc
The URLConnection stream from which data must be read and interpreted to create an object for the MIME-type that this class represents.
Description
This abstract method must be implemented by each subclass of ContentHandler to read and interpret data from the URLConnection data-stream and create a representation of the MIME object that the subclass represents. An IOException is thrown if some error occurs while reading the data from the URLConnection stream.
Imports
import java.net.ContentHandler;
Returns
This method returns an Object that represents the specific MIME-type/subtype implemented by this class.
See Also
The getContent method of the URL class and the getContent of the URLConnection class described in this chapter
Example
The previous example illustrates how you can implement this method in your own content handlers.
ContentHandlerFactory
Purpose
Defines the interface that must be implemented by classes that know how to create an instance of a subclass of ContentHandler that handles a specified MIME-type.
Syntax
public interface ContentHandlerFactory extends Object
Description
As the name implies, a class that implements this interface must know how to manufacture (construct) instances of subclasses of the ContentHandler class. Each concrete subclass of the abstract base class, ContentHandler, handles a specific MIME-type. A class that implements this interface must maintain an association between the MIME-type strings and the name of the class that handles that MIME-type/subtype combination. ContentHandlerFactory objects construct (on demand) the appropriate ContentHandler for a given MIME-type. This class will mainly be used in subclasses of the URLConnection class. If you are writing content handlers and you do not want to install these classes in the default directories, such as sun/net/www/content/, then you can use a class that implements the ContentHandlerFactory interface to create instances of your classes. To implement a protocol handler in Java, you must extend the URLStreamHandler class to provide implementations of streams that are specific to the protocol. You must also subclass the URLConnection class to provide implementations of the different types of content that can be handled by the protocol. The URLConnection class has a static ContentHandlerFactory object as a member variable. This implies that every instance of the URLConnection class uses the same source for constructing ContentHandlers. Figure 11-4 shows the inheritance diagram for the ContentHandlerFactory interface.
Figure 11-4 Inheritance diagram for the ContentHandlerFactory
interface
PackageName
java.net
Imports
import java.net.ContentHandlerFactory;
Constructors
None.
Parameters
None.
Example
The example for the createContentHandler method illustrates how you can implement a custom Content Handler factory class.
createContentHandler(String)
InterfaceName
ContentHandlerFactory
Purpose
Constructs an instance of the specific subclass of ContentHandler that handles the specified MIME-type.
Syntax
public abstract ContentHandler createContentHandler(String mimetype)
Parameters
mimetype
The Multipurpose Internet Mail Extension (MIME) type for which an instance of the appropriate subclass of ContentHandler is to be constructed.
Description
Classes that implement the ContentHandlerFactory interface must know the names and locations of the specific subclasses of ContentHandler that handle the various MIME-type/subtype combinations. Depending on the MIME-type/subtype specified, an instance of the appropriate subclass of ContentHandler is constructed and returned. How does the URLConnection class know which MIME-type is to be supplied as a parameter to this method? The getContentType method of the URLConnection class provides the answer to this question. The getContentType method returns a string that contains the MIME-type/subtype combination of the URLConnection. This string can then be used as the parameter to this method.
Imports
import java.net.ConentHandlerFactory;
Returns
This method returns an instance of the ContentHandler subclass that represents the specified MIME-type.
See Also
The ContentHandler class; the setContentHandlerFactory method of the URLConnection class; and the getContentType method of the URLConnection class, all of which are described in this chapter
Example
The following example shows you a class that implements this interface.
// File: CustomContentHandlerFactory.javaURL
Purpose
Represents a Uniform Resource Locator (URL). Uniform Resource Locators are references to objects on the World Wide Web that can be retrieved using protocols such as the HyperText Transfer Protocol (HTTP).
Syntax
public final class URL extends Object
Description
This class is used to access objects on the World Wide Web. It encapsulates the concept of a Uniform Resource Locator. Handling the different protocol types (http, ftp) and content types (GIF images, Postscript files) is transparent to the application that uses URL objects to access data on the Web. This class cannot be subclassed, and once constructed, the URL object cannot be modified (i.e., instances of the URL class are constant objects). You can create URL objects either by specifying the absolute path or by specifying a path relative to another URL. Constructing URL objects by specifying a path relative to another URL object is useful for creating URLs to references (named anchor tags, e.g., "https://www.syr.edu/index.html#LIBRARY") within a HTML (HyperText Markup Language) file. If the parameters supplied to the constructor are not valid, a MalformedURLException is generated, and hence the constructor statements should be within a try/catch statement pair. The URL class maintains a table of URLStreamHandler objects that handle different protocols such as http, file, news, doc, and verbatim. These URLStreamHandler objects are created on demand and are shared by all instances of the URL class (i.e., the table is a static member variable of the URL class). When a URL object is created, a URLStreamHandler object is created. This specific instance of the URLStreamHandler object depends on the protocol specified in the URL. Figure 11-2 shows the basic relationships between URLs, ProtocolHandlers, and ContentHandlers. If a URLStreamHandler factory object has been defined, then this factory is used to generate the URLStreamHandler. If no factory has been defined, then the URL class looks in certain default directories (for example: sun/net/www/protocol/http/Handler.class for the http protocol) for the URLStreamHandler subclass that implements the specified protocol. If you are writing Java applications that access resources on the World Wide Web, then you will be using the URL class often. Figure 11-5 shows the inheritance diagram for the URL class.
Figure 11-5 Inheritance diagram for the URL class
PackageName
java.net
Imports
import java.net.URL;
Constructors
public URL(String protocol, String host, int port, String file) throws MalformedURLException
public URL(String protocol, String host, String file) throws MalformedURLException
public URL(String spec) throws MalformedURLException
public URL(URL context, String spec) throws MalformedURLException
Parameters
protocol
The protocol (http, news, and so on) to use for this URL.
host
The Internet name of the host machine to connect to (e.g., www.syr.edu).
port
The port number on the host machine to connect to.
file
The path name of the file on the host.
spec
A string specifying an absolute (unparsed) URL (e.g. "https://www.syr.edu/").
context
A URL object to be used as a context into which a string specifying a URL (usually a relative path to the context URL) may be parsed.
Example
The following samples of code illustrate the different ways of constructing URL objects. Refer to the URLTestControls constructor method in Step 7 of the project at the end of this chapter for a more complete example.
equals(Object)
ClassName
URL
Purpose
Compares the specified URL object to the URL on which this method is invoked and determines whether the two URL objects are equal or not.
Syntax
public boolean equals(Object obj)
Parameters
obj
The URL object to compare against.
Description
The URL object specified in the parameter of this method is compared to the URL object on which the method was invoked. The protocol, hostname, port number, and file specifications of two URL objects are compared.
Note: This method does not make use of facilities like the Unix Domain Name Service (DNS) to look for aliases of the hostnames. It simply compares the strings specifying the hostname, protocol, and file specifications. If the hostname strings do not match, this method evaluates the Internet addresses of the hostnames of the URL objects being compared.
Imports
import java.net.URL;
Returns
This method returns true if and only if the parameter obj is an instance of the URL class and the protocol, host, port, and file properties of the two URL objects match.
Example
The following Java class illustrates the use of this method.
import java.net.*;getContent()
ClassName
URL
Purpose
Returns an object constructed from the data read from the object referred to by this URL.
Syntax
public final Object getContent() throws IOException
Parameters
None.
Description
The protocol-specific URLStreamHandler handling this URL determines the content type of the object referred to by this URL. The ContentHandler for that MIME-type reads the data from the URLConnection stream and constructs the content-specific object that is returned.
Imports
import java.net.URL;
Returns
The Object returned by this method is constructed from the data read from the URLConnection. Depending on the MIME-type of the object referred to by this URL, a specific instance of a class that represents that content is created. The instance of operator should be used to determine the class that this object belongs to. An IOException indicates that an error occurred while reading and interpreting data from the remote object.
See Also
The ContentHandler class; the getContent method; and the URLConnection class, described in this chapter
Example
The following example shows how you can use the instance of operator to determine the type of object that the URL refers to.
// File: URLContentType.javaThis program prints the following on the screen:
This URL refers to a String objectgetFile()
ClassName
URL
Purpose
Gets the filename portion of the URL specification.
Syntax
public String getFile()
Parameters
None.
Description
This method returns the value of the filename portion of the URL specification. The first two forms of the URL constructor allow you to specify the filename explicitly. The next two variants of the URL constructor allow you to specify a URL as a string of text (e.g., "https://www.syr.edu/index.html") and the URL constructor parses this string to extract the filename ("/index.html" in this case).
Imports
import java.net.URL;
Returns
The return value of this method is a String object that contains the name of the file referenced by this URL object.
See Also
Constructors for this class
Example
Refer to the showParams() method in the URLPanel class of the section project (Step 5) at the end of this chapter.
getHost()
ClassName
URL
Purpose
Retrieves the hostname portion of the Uniform Resource Locator specification.
Syntax
public String getHost()
Parameters
None.
Description
This method returns the value of the hostname portion of the URL specification. The first two forms of the URL constructor allow you to specify the hostname explicitly. The next two variants of the URL constructor allow you to specify a URL as a string of text (e.g., "https://www.syr.edu/index.html") and the URL constructor parses this string to extract the hostname ("www.syr.edu" in this case).
Imports
import java.net.URL;
Returns
The return value of this method is a String object that contains the hostname on which the file referenced by this URL object resides.
See Also
Constructors for this class
Example
This use of this method is illustrated in the showParams() method in the URLPanel class of the section project (Step 5) at the end of this chapter.
getPort()
ClassName
URL
Purpose
Gets the port number (on the target host machine) to which this URL object connects.
Syntax
public int getPort()
Parameters
None.
Description
This method returns the value of the port number of the URL specification. The first form of the URL constructor allows you to explicitly specify the port number. The second form of the URL constructor sets the port number to the default value (which depends on the protocol). The next two variants of the URL constructor allow you to specify a URL as a string of text (e.g., "https://www.syr.edu:80/index.html") in which you can optionally specify a port number, and the URL constructor parses this string to extract the port number (80 in this case).
Imports
import java.net.URL;
Returns
This method returns an integer that specifies the port number this URL object connects to. If the port number was not explicitly specified while constructing the URL, then the return value of this method is -1.
See Also
Constructors for this class
Example
The use of this method is illustrated in the showParams() method in the URLPanel class of the section project (Step 5) at the end of this chapter.
getProtocol()
ClassName
URL
Purpose
Gets the protocol used to retrieve the object referenced by this URL.
Syntax
public String getProtocol()
Parameters
None.
Description
This method returns the value of the protocol portion of the URL specification. The first two forms of the URL constructor allow you to specify the protocol explicitly. The next two variants of the URL constructor allow you to specify a URL as a string of text (e.g., "https://www.syr.edu/index.html") and the URL constructor parses this string to extract the protocol ("http" in this case).
Imports
import java.net.URL;
Returns
The return value of this method is a String object that specifies the protocol used to retrieve the object referenced by this URL.
See Also
Constructors for this class
Example
The use of this method is illustrated in the showParams() method in the URLPanel class of the section project (Step 5) at the end of this chapter.
getRef()
ClassName
URL
Purpose
Gets the anchor tagname for this URL object. Anchors are used to point to a specific section in a document.
Syntax
public String getRef()
Parameters
None
Description
The # mark indicates a named anchor in a HTML (HyperText Markup Language) document. By specifying an anchor in a document, one can go directly to that specified section in the document. This method retrieves the name of the anchor (if any) from the URL specification.
Note: This method does not detect the reference specification when the URL object is created using the following form of the URL constructor.
URL u1 = new URL("https://www.syr.edu/index.html#LIBRARY");
In this case, u1.getRef() returns the null string.
Imports
import java.net.URL;
Returns
This method returns the anchor tagname (string following the '#' character) in the URL.
See Also
The set method of this class and the different forms of constructors for this class
Example
The use of this method is illustrated in the showParams() method in the URLPanel class of the section project (Step 5) at the end of this chapter.
hashCode()
ClassName
URL
Purpose
Returns a hash value that can be used to index into a hash table.
Syntax
public int hashCode()
Parameters
None.
Description
This method overrides the hashCode method of the Object class. It returns a number that is the hash value of the URL object on which this method was invoked.
Imports
import java.net.URL;
Returns
This method returns an integer that represents the hash value for this URL object.
Example
The following Java class shows how to invoke this method in your application.
import java.net.*;openConnection()
ClassName
URL
Purpose
Opens a connection to the object referred to by this URL object.
Syntax
public URLConnection openConnection() throws IOException
Parameters
None.
Description
The subclass of URLStreamHandler that handles the protocol specified by this URL object creates an instance of a subclass of the URLConnection class and returns this URLConnection object. The specific subclass of the URLConnection class to instantiate is determined by the URLStreamHandler object that implements the protocol used by this URL object. An IOException is thrown when there is an error in establishing a connection to the remote object.
Imports
import java.net.URL;
Returns
This method returns an instance of the protocol-specific subclass of the URLConnection class that contains a connection to the object referred to by this URL.
See Also
The URLConnection class; the openStream and getContent methods of the URL class, described in this chapter
Example
This example illustrates how you can access the URLConnection object associated with a URL and read data from the URLConnection object over the network.
// File: URLRead1.javaThe file test.html contains:
<HTML>This example prints the following lines on the screen:
Line 1: <HTML>openStream()
ClassName
URL
Purpose
Opens an input stream to the object referenced by this URL.
Syntax
public final InputStream openStream() throws IOException
Parameters
None.
Description
This function returns an InputStream to the object referred to by the URL. The InputStream is established by the protocol-specific URLConnection object that was created by the URLStreamHandler object handling this URL. If the protocol of this URL object supports input streams, then applications can use this InputStream object to read the data of the object referred to by the URL.
Imports
import java.net.URL;
Returns
The InputStream object returned by this method can be used to read the data of the object referred to by this URL object. If the protocol does not support InputStreams, an UnknownServiceException is thrown. Protocol implementors can trigger other exceptions while implementing the getInputStream method of the protocol-specific subclass of the URLConnection class.
See Also
The getInputStream method of the URLConnection class; the openConnection and getContent methods of the URL class described in this chapter
Example
This example essentially performs the same function as the previous example. It uses the openStream method of the URL class to read data from the object. This example uses the same test.html file as the previous example.
// File: URLRead2.javaWhen executed, this example prints the following lines on the screen:
Line 1: <HTML>sameFile()
ClassName
URL
Purpose
Compares the specified URL object against the object on which this method was invoked.
Syntax
public boolean sameFile(URL other)
Parameters
other
The URL object that must be compared against the object on which this method is invoked.
Description
If the four fields ( protocol, hostname, port number, and file path name) of the two URL objects are the same, then the URLs are said to be equal. The reference field, that indicates an offset in a file, is not taken into account for the comparison.
Imports
java.net.URL;
Returns
This method returns true if the specified URL object is equal to this URL; otherwise, it returns the boolean value false.
See Also
The equals and set methods of the URL class, described in this chapter
Example
This method is used in the example for the equals method of this class.
set(String, String, int, String, String)
ClassName
URL
Purpose
Sets the individual fields of the URL object. This is a privileged function that is accessible only to classes in the java.net package.
Syntax
protected void set(String protocol, String host, int port, String file, String ref)
Parameters
protocol
The protocol (http, news, etc) to use for this URL.
host
The Internet name of the host machine to connect to (e.g., www.syr.edu).
port
The port number on the host machine to connect to.
file
The path name of the file on the host.
ref
The name of the reference that indicates a specific offset into the file.
Description
This method is provided so that the parseURL method of the URLStreamHandler class can set the fields of a URL. It is a protected method that is accessible only to classes in the java.net package.
Imports
import java.net.URL;
Returns
None.
Example
This method can only be invoked by classes in the java.net package and hence no example code illustrating the usage of this method is provided here.
setURLStreamHandlerFactory(URLStreamHandlerFactory)
ClassName
URL
Purpose
Specifies the factory object (that implements the URLStreamHandlerFactory interface) that all URL objects should use to create protocol-specific URLStreamHandler objects.
Syntax
public static synchronized void setURLStreamHandlerFactory(URLStreamHandlerFactory fac)
Parameters
fac
The URLStreamHandlerFactory object that must be used for creating protocol-specific stream handlers.
Description
All objects of the URL class share the same URLStreamHandlerFactory object. By invoking this method, you can install your own URLStreamHandlerFactory. An error is generated if a URLStreamHandlerFactory already exists. If you write new protocol handler classes and install these classes in nonstandard locations, you will need to create a class that implements the URLStreamHandlerFactory interface. This factory class will need to know where to find the protocol-specific implementations of classes such as the URLConnection class and the URLStreamHandler class.
Imports
import java.net.URL;
See Also
The URLStreamHandlerFactory class and the URLStreamHandler class described in this chapter
Returns
None.
Example
The following pieces of code illustrate how you might set the URLStreamHandlerFactory to a custom factory that you have implemented.
// File: myFactory.javatoExternalForm()
ClassName
URL
Purpose
Represents this URL as a text string.
Syntax
public String toExternalForm()
Parameters
None.
Description
The textual representation of this URL is constructed from the individual fields of the URL (such as protocol, hostname, etc.). Default values (such as default port number) are omitted from the text string.
Imports
import java.net.URL;
Returns
The String object returned by this method contains a text string that specifies the protocol, hostname, portnumber (if specified), file name, and reference (if specified) of this URL object.
See Also
The toString method of this class
Example
This method is invoked by the toString method of this class. The following Java class shows how to invoke this method in your application.
import java.net.*;When this example is compiled (javac URLTestExternalForm.java) and executed (java URLTestExternalForm), the following string is printed on the screen.
u1.toExternalForm = https://web.syr.edu:80/index.htmltoString()
ClassName
URL
Purpose
Represents this URL as a text string.
Syntax
public String toString()
Parameters
None.
Description
This method simply invokes the toExternalForm method to represent the URL object as a text string.
Imports
java.net.URL;
Returns
The String object returned by this method contains a text string that specifies the protocol, hostname, port number (if specified), file name, and reference (if specified) of this URL object.
See Also
The toExternalForm method of this class
Example
The use of this method is illustrated in the showParams method in the URLPanel class of the section project (Step 5) at the end of this chapter.
URLConnection
Purpose
Sets/modifies the connection-session parameters and handles the network connection to the remote object referred to by a Uniform Resource Locator.
Syntax
public class URLConnection extends Object
Description
This abstract class must be subclassed by protocol-implementors to provide protocol-specific implementations for connecting to remote objects referred to by Uniform Resource Locators (URLs). This class will handle the parsing of protocol-specific message headers and message content. The various properties of the connection session for a protocol will also be handled by subclasses of this class. All instances of the URLConnection class share a table of ContentHandlers. These ContentHandlers represent specific MIME-type/subtype combinations. Instances of this class (for a specific protocol) are created by the subclass of the URLStreamHandler class that implements the specified protocol's stream handling functionality. Figure 11-2 shows the basic relationships between URLs, ProtocolHandlers, and ContentHandlers. Figure 11-6 shows the inheritance diagram for the URLConnection class.
Figure 11-6 Inheritance diagram for the URLConnection class
PackageName
java.net
Imports
import java.net.URLConnection;
Constructors
protected URLConnection(URL url)
Parameters
url
The URL object to which a connection needs to be established.
Example
The constructor method for this class is protected and hence you cannot create objects of this class. To implement protocol handlers, you will need to extend this class.
connect()
ClassName
URLConnection
Purpose
Connects to the remote object referred to by the URL for which this URLConnection object was created.
Syntax
public abstract void connect() throws IOException
Parameters
None.
Description
Invoking this method causes a connection to be established to the object referred to by the URL. The properties of this connection-session cannot be altered (using the methods such as setDoInput and setDoOutput) once a connection is established. This method must be implemented by any class that extends the URLConnection class.
Imports
import java.net.URLConnection;
Returns
None.
Example
The following code shows a portion of a Java class that extends the URLConnection class.
// File: CustomURLConnection.javagetAllowUserInteraction()
ClassName
URLConnection
Purpose
Returns the value of the flag that indicates whether the protocol permits user interaction while establishing the connection to the remote object.
Syntax
public boolean getAllowUserInteraction()
Parameters
None.
Description
Protocols such as http, that have access/security control features, allow user interaction (such as authentication by asking for a user name and password) during the process of setting up a connection to an object referred to in a URL. Protocol implementors specify whether this interaction is permitted by the protocol or not.
Imports
import java.net.URLConnection;
Returns
The return value is true if the protocol permits user-interaction at the time of establishing a connection, and false if user-interaction is not permitted by the protocol.
See Also
The setAllowUserInteraction, getDefaultAllowUserInteraction and setDefaultAllowUserInteraction methods of this class
Example
The following example illustrates the usage of this method and some of the other related methods of this class.
// File: URLConnTest1.javaWhen this program is compiled and executed it prints the following messages on the screen.
URL: https://cosmos/∼asriniva/index.htmlgetContent()
ClassName
URLConnection
Purpose
Reads the data from the remote object and constructs an instance of the subclass of ContentHandler that handles the MIME-type of the object this URL refers to.
Syntax
public Object getContent() throws IOException
Parameters
None.
Description
This method determines the MIME-type/subtype of the object referred to by the URL and constructs the appropriate ContentHandler (if it does not already exist). The getContent method of the ContentHandler class is invoked and the ContentHandler object reads the data from this URLConnection stream. Then it constructs and returns the object referred to by the URL. For example, a plain text content handler may just read the data from the URLConnection object and return a String object containing the text read from the remote object, or a content handler that handles the image/gif MIME-type could construct a GIFImage object. This GIFImage object would typically be an instance of a subclass of the Image class.
Imports
import java.net.URLConnection;
Returns
The Object returned by this method is constructed from the data read from the URLConnection. Depending on the MIME-type of the object referred to by the URL, a specific instance of a class that represents that content is created. The instanceof operator should be used to determine the class that this object belongs to. An IOException indicates that an error occurred while reading and interpreting data from the remote object.
See Also
The ContentHandler class and the getContent method of the URL class and of the URLStreamHandler class. These are described in this chapter.
Example
The following example uses the getContent method of the URLConnection class to access the object referred to by the URL.
// File: URLConnContentType.javaThis program prints the following on the screen.
This URL refers to a String object
Contents of the URL object: This is the only line of text in hello.txt!getContentEncoding()
ClassName
URLConnection
Purpose
Gets the mechanism used to encode the data of the remote object to which this URLConnection is connected.
Syntax
public String getContentEncoding()
Parameters
None.
Description
One of the MIME header fields that specifies information about the object is the Content-Encoding field. It specifies the encoding mechanism used to encode the object data. Content codings are primarily used to allow data to be compressed or encrypted. Encoding mechanisms such as compress and gzip are used to compact the data so that less data needs to be transferred over the network.
Imports
import java.net.URLConnection;
Returns
This method returns a String that specifies the encoding mechanism used. If the encoding mechanism is not known, this method returns a null value. Two common encoding mechanisms are x-compress and x-gzip.
Example
The following example illustrates the usage of some of the methods of this class.
// File: URLConnTest.javaWhen this program is compiled (javac URLConnTest.java) and run (java URLConnTest), the following text is printed on the screen.
URL: https://cosmos/∼asriniva/index.htmlgetContentLength()
ClassName
URLConnection
Purpose
Gets the length of the content of the remote object that this URLConnection is connected to.
Syntax
public int getContentLength()
Parameters
None.
Description
One of the MIME header fields that specifies information about the object is the Content-Length field. It implies that the object data should be treated as binary data, and the integer value associated with this field specifies the data size of the remote object.
Imports
import java.net.URLConnection;
Returns
The integer value returned by this method specifies the size of the content of the remote object. If the content length cannot be determined, this method returns the value -1.
Example
This method is used in the example for the getContentEncoding method of this class.
getContentType()
ClassName
URLConnection
Purpose
Gets the MIME-type/subtype combination of the remote object that this URLConnection is connected to.
Syntax
public String getContentType()
Parameters
None.
Description
The value associated with the Content-Type field of the MIME header specifies the MIME-type and subtype of the object that the URL refers to.
Imports
import java.net.URLConnection;
Returns
The String returned by this method contains the MIME-type and subtype combination of the remote object. If the content type is not known, this method returns a null value. For example, if the URL referred to a HTML file, this method would return text/html, whereas if the URL referred to a postscript file, the string returned by this method would be application/postscript.
Example
This method is used in the example for the getContentEncoding method of this class.
getDate()
ClassName
URLConnection
Purpose
Gets the date and time that the object was sent.
Syntax
public long getDate()
Parameters
None.
Description
One of the MIME header fields is the Date field. The value associated with this field specifies the date and time that the data, accompanying this header, was sent. The Date field of the MIME header contains a string representation of the date, such as the following text.
Mon, 15 Apr 1996 09:00:00 GMT
This method invokes the parse method of the Date class to convert this string representation into a time value, and returns this time value.
Imports
import java.net.URLConnection;
Returns
The value returned by this method is obtained by invoking the parse method of the Date class which returns the number of milliseconds since the beginning epoch, for the specified date. If the date is not known, the value 0 is returned.
See Also
The parse method of the Date class. This class is described in Chapter 13.
Example
This method is used in the example for the getContentEncoding method of this class. The Date class is used to convert the number returned by this method to a string representation of a date and time.
getDefaultAllowUserInteraction()
ClassName
URLConnection
Purpose
Gets the default value of the flag that indicates whether the protocol permits user-interaction while establishing the connection to the remote object.
Syntax
public static boolean getDefaultAllowUserInteraction()
Parameters
None.
Description
This method can be used to determine whether or not the protocol permits user-interaction. This property is required of some protocols that require user-interaction, such as typing in a password, before proceeding further. The variable that stores the value of the flag associated with this property is a static variable in the URLConnection class. This ensures uniformity in this policy among all instances of the URLConnection class for that protocol.
Imports
java.net.URLConnection;
Returns
The return value is true or false, depending on whether or not the default value associated with this property for this protocol is true or false. The default value for this variable is false.
See Also
The setDefaultAllowUserInteraction method; the getAllowUserInteraction and the setAllowUserInteraction methods of this class
Example
This method is used in the example for the getAllowUserInteraction method of this class.
getDefaultRequestProperty(String)
ClassName
URLConnection
Purpose
Gets the default value associated with the specified field of the request header.
Syntax
public static String getDefaultRequestProperty(String key)
Parameters
key
The name of the request header field for which the default value is to be returned.
Description
In a protocol transaction such as http, the client sends a list of fields to the http server. Some of these fields (such as Accept and Accept Encoding) convey information about the capabilities of the client. This method is used to determine the default values associated with a specified field of the request header. The request fields (properties) contained in a HTTP protocol header are
From |
Accept |
Accept-Encoding |
Accept-Language |
User-Agent |
Referrer |
Authorization |
Charge-to |
If-Modified-Since |
Pragma |
Imports
import java.net.URLConnection;
Returns
This method returns a String object that contains a default value associated with the specified property. The default implementation of this method (in the URLConnection class) simply returns a null string.
See Also
The setDefaultRequestProperty method of this class
Example
The following example shows how you can override this method.
// File: CustomURLConnection.java
To access the contents, click the chapter and section titles. Java Networking & AWT API SuperBible
getDefaultUseCaches() ClassName URLConnection Purpose Gets the default value of the flag that indicates whether the protocol should use the cache to retrieve an object or whether it should ignore the cache and fetch the object from the remote site. Syntax public boolean getDefaultUseCaches() Parameters None. Description Some protocols use local caches to enable quick access to previously retrieved objects. The URLConnection class maintains a per-instance boolean variable that indicates whether or not to use caching. A static boolean variable specifies the default value for the per-instance variable. This method returns the value of the static boolean variable. Imports import java.net.URLConnection; Returns The return value is true or false, depending on whether the URLConnection should use the cache or ignore the cache. The default value for this variable is true. See Also The setDefaultUseCaches method the setUseCaches and getUseCaches methods of this class Example This method is used in the example for the getAllowUserInteraction method of this class. getDoInput() ClassName URLConnection Purpose Gets the value of the flag that indicates whether this URLConnection can be used for input (i.e. can be read from). Syntax public boolean getDoInput() Parameters None. Description The value returned by this method indicates whether or not data can be read from the URLConnection. Imports import java.net.URLConnection; Returns The boolean value returned is true if the URLConnection can be used for input and false if not. The default value for this flag is true. See Also The setDoInput method of this class Example This method is used in the example for the getAllowUserInteraction method of this class. getDoOutput() ClassName URLConnection Purpose Gets the value of the flag that indicates whether this URLConnection can be used for output (i.e., can be written to). Syntax public boolean getDoOutput() Parameters None. Description The value returned by this method indicates whether or not data can be written to the remote object that the URLConnection is connected to. Imports import java.net.URLConnection; Returns The boolean value returned is true if the URLConnection can be used for output and false if not. The default value for this flag is false. See Also The setDoOutput method of this class Example This method is used in the example for the getAllowUserInteraction method of this class. getExpiration() ClassName URLConnection Purpose Gets the date after which the information retrieved from the remote object ceases to be valid and must be reloaded. Syntax public long getExpiration() Parameters None. Description One of the MIME header fields that specifies information about the object is the Expires field. The value associated with this field specifies the date after which the information already retrieved ceases to be valid and must be retrieved again. The object referred to by the URL is considered to be stale after the date/time specified in this field. This allows the data to be refreshed periodically and also allows a limited amount of control over caching policies. The Expires field of the MIME header contains a string representation of the date, such as the following text. Mon, 15 Apr 1996 09:00:00 GMT This method invokes the parse method of the Date class to convert this string representation into a time value, and returns this time value. Imports import java.net.URLConnection; Returns The return value indicates the date after which the object needs to be retrieved again. The value returned by this method is obtained by invoking the parse method of the Date class that returns the number of milliseconds since the beginning epoch, for the specified date. If the expiration date is not known then the value 0 is returned. See Also The parse method of the Date class. This class is described in Chapter 13. Example This usage of this method is illustrated in the example for the getContentEncoding method of this class. getHeaderField(int) ClassName URLConnection Purpose Gets the value associated with the nth header field of the object's header. Syntax public String getHeaderField(int n) Parameters n The index number of the header field whose value is to be retrieved. Description This method retrieves the value associated with a particular header field. The header field is specified using an index. Without knowing the actual field names contained in the header, one can use this method and the GetHeaderFieldKey method to iterate through all the header field names and associated values. The index n starts at zero. Imports import java.net.URLConnection; Returns If the index n is less than the number of fields in the header, then the value for that field is returned. If n is greater than the number of fields in the header, the return value is null. The default implementation of this method (in the URLConnection class) simply returns a null string. See Also The URLConnection.getHeaderField(String) method Example Please refer to the example for the getDefaultRequestProperty method of this class to see how you can provide a custom implementation of this method in any class that extends the URLConnection class. |
getHeaderField(String)
ClassName
URLConnection
Purpose
Gets the value associated with the specified header field.
Syntax
public String getHeaderField(String name)
Parameters
name
The name of the header field whose value is to be retrieved.
Description
This method retrieves the value associated with a specified header field. The header field is specified by name (e.g,. Content-Type).
Imports
import java.net.URLConnection;
Returns
The String object returned by this method contains the value associated with the specified field name. If the header field name was not found in the data stream read from the remote object, then the value returned by this method is null. The default implementation of this method (in the URLConnection class) simply returns a null string. The header fields given with or in relation to objects in HTTP are
Allowed |
Public |
Content-Length |
Content-Type |
Content-Transfer-Encoding |
Content-Encoding |
Date |
Expires |
Last-Modified |
Message-Id |
URL |
Version |
Derived-From |
Content-Language |
Cost |
Link |
Title |
See Also
The getHeaderField method of this class
Example
Please refer to the example for the getDefaultRequestProperty method of this class to see how you can provide a custom implementation of this method in any class that extends the URLConnection class.
getHeaderFieldDate(String, long)
ClassName
URLConnection
Purpose
Gets the value associated with the specified header field, reads this value as a date value, and returns the date value.
Syntax
public long getHeaderFieldDate(String name, long strDef)
Parameters
name
The name of the header field whose value is to be retrieved as a date value.
strDef
The default value to return if the header field name is not found.
Description
This method reads the value associated with the header field and returns this value as a date value. This method can be used by protocols that have pre-parsed headers where the formats of individual fields are known. Please refer to the getDate method description for the format of the date value returned by this method.
Imports
import java.net.URLConnection;
Returns
This method returns the value specified in strDef if the field name is not known. If the field name is found, the value associated with it is returned as a long integer.
Example
This helper method, shown below, can be used to extract the contents of a field and convert it into a long integer representing the number of milliseconds since the epoch.
// File: CustomURLConnection.javagetHeaderFieldInt(String, int)
ClassName
URLConnection
Purpose
Gets the value associated with the specified header field, reads this value as an integer value, and returns the integer value.
Syntax
public int getHeaderFieldInt(String name, int valDef)
Parameters
name
The name of the header field whose value is to be retrieved as an integer value.
valDef
The default value to return if the header field name is not found.
Description
This method reads the value associated with the header field and returns this value as an integer value. This method can be used by protocols that have pre-parsed headers, where the formats of individual fields are known.
Imports
java.net.URLConnection;
Returns
This method returns the value specified in valDef if the field name is not known. If the field name is found, the value associated with it is returned as an integer.
Example
This helper method can be used in a manner similar to that described in the example for the getHeaderFieldDate method description.
getHeaderFieldKey(int)
ClassName
URLConnection
Purpose
Gets the field name of the nth header field.
Syntax
public String getHeaderFieldKey(int n)
Parameters
n
The index number of the header field whose field name is to be retrieved.
Description
This method retrieves the field name associated with a particular header field. The header field is specified using an index. Without knowing the actual field names contained in the header, one can use this method and the GetHeaderField (int) method to iterate through all the header field names and their associated values. The index n starts at zero.
Imports
import java.net.URLConnection;
Returns
If index n is less than the number of fields in the header, then the field name for that field is returned. If n is greater than the number of fields in the header, the return value is null. The default implementation of this method (in the URLConnection class) simply returns a null string.
See Also
The getHeader method of this class
Example
Please refer to the example for the getDefaultRequestProperty method of this class to see how you can provide a custom implementation of this method in any class that extends the URLConnection class.
getIfModifiedSince()
ClassName
URLConnection
Purpose
Gets the time that is sent as the value of the If-Modified-Since header field of the request header to determine whether or not an object should be retrieved.
Syntax
public long getIfModifiedSince()
Parameters
None.
Description
The If-Modified-Since field of the request header is sent by the client to the server in order to make the retrieval of an object conditional. By specifying a time with this header field, the client instructs the server not to send the object, if the object has not changed since the time indicated, as the value for this header field. This method gets the value associated with this field.
Imports
import java.net.URLConnection;
Returns
The return value is a long integer that indicates the time that should be used by a server to determine whether an object has been modified or not.
Example
This method can be used in a manner similar to the getLastModified method.
getInputStream()
ClassName
URLConnection
Purpose
Gets an input stream from which data from the remote object can be read.
Syntax
public InputStream getInputStream() throws IOException
Parameters
None.
Description
This method opens and returns an InputStream to the remote object that this URLConnection object is connected to. The object's data can be read using the InputStream object returned by this method. Protocols that permit input must implement this method.
Imports
import java.net.URLConnection;
Returns
This method returns an InputStream object that can be used to read data from the remote object. An UnknownServiceException is generated if the protocol does not support input. The default implementation of this method (in the URLConnection class) simply throws an UnknownServiceException.
Example
This method is used in the example for the openConnection method of the URL class.
getLastModified()
ClassName
URLConnection
Purpose
Gets the time that the object that this URLConnection is connected to was last modified.
Syntax
public long getLastModified()
Parameters
None.
Description
One of the MIME header fields that specifies information about the object is the Last-Modified field. The value associated with this field specifies the time that the object was last modified. The format of this field is the same as the date format for the Date field described in the getDate method of this class. The server compares this value against the value of the If-Modified-Since field of the request header to determine whether the object needs to be sent to the client.
Imports
import java.net.URLConnection;
Returns
The return value indicates the time that the object this URLConnection is connected to was last modified. If the time is not known, the value 0 is returned.
See Also
The getIfModifiedSince method of this class; the parse method of the Date class, and the Date class, described in Chapter 13.
Example
An example of this method is illustrated in the example for the getContentEncoding method of this class.
getOutputStream()
ClassName
URLConnection
Purpose
Gets an output stream that the remote object can be written to.
Syntax
public OutputStream getOutputStream() throws IOException
Parameters
None.
Description
This method opens and returns an OutputStream to the remote object that this URLConnection object is connected to. Data can be written to the object using the OutputStream object returned by this method. Writing to a URLConnection is similar to the POST method of the HTTP protocol. It provides a means by which information can be sent to the object referenced by the URL. You can use the output stream of a URLConnection to send data back to CGI (Common Gateway Interface) scripts that are running on a World Wide Web server. Protocols that permit output must implement this method.
Imports
import java.net.URLConnection;
Returns
This method returns an OutputStream object. An UnknownServiceException is generated if the protocol does not support output. The default implementation of this method (in the URLConnection class) simply throws an UnknownServiceException.
Example
The following example is a simple template that you can use to write Java programs that post and receive data to or from CGI scripts.
// File: URLConnWrite.javaThe output of this program is:
Line 1: <HTML>getRequestProperty()
ClassName
URLConnection
Purpose
Gets the value associated with the specified request header field name.
Syntax
public String getRequestProperty(String key)
Parameters
key
The request header field name whose associated value is to be returned
Description
In a protocol transaction such as http, the client sends a list of fields to the http server. These fields are part of the request header. In the http protocol, From, Accept, If-Modified-Since, and Pragma are some of the field names sent in the request header. A more comprehensive list of property names is listed in the getDefaultRequestProperty method description. This method is used to retrieve the value associated with a specific property. This method should not be invoked if the URLConnection object is already "connect()"ed.
Imports
import java.net.URLConnection;
Returns
The String returned by this method contains the value of the request header field. If the header field is not found, then the null value is returned. The default implementation of this method (in the URLConnection class) throws an IllegalAccessError if the URLConnection object is already connected; otherwise it returns a null string.
See Also
The setRequestProperty method of this class
Example
Please refer to the example for the getDefaultRequestProperty method of this class to see how you can provide a custom implementation of this method in any class that extends the URLConnection class.
getURL()
ClassName
URLConnection
Purpose
Gets the URL object to which this connection was established.
Syntax
public URL getURL()
Parameters
None.
Description
This method simply returns the URL object that was supplied as a parameter to the URLConnection constructor.
Imports
import java.net.URLConnection;
Returns
This method returns the URL object that this URLConnection established a connection to.
Example
This usage of this method is illustrated in the following example.
// File: URLConnTest.javagetUseCaches()
ClassName
URLConnection
Purpose
Gets the value of the flag that indicates whether this URLConnection object should use the cache to retrieve an object or whether it should ignore the cache and fetch the object from the remote site.
Syntax
public boolean getUseCaches()
Parameters
None.
Description
Some protocols use local caches to enable quick access to previously retrieved objects. The URLConnection class maintains a per-instance boolean variable that indicates whether or not to use caching. This method returns the value of this boolean variable.
Imports
import java.net.URLConnection;
Returns
The return value is true or false, depending on whether the URLConnection should use the cache or ignore the cache. The default value returned by this method is true.
See Also
The setUseCaches method; the setDefaultUseCaches method and getDefaultUseCaches methods of this class
Example
This method is used in the example for the getAllowUserInteraction method of this class.
guessContentTypeFromName(String)
ClassName
URLConnection
Purpose
Guesses the MIME-type/subtype of the specified object by examining its name.
Syntax
static protected String guessContentTypeFromName(String fname)
Parameters
fname
The specification of the remote object (can be a text representation of a URL or just a plain file name).
Description
This method tries to determine the MIME-type of the specified object,by examining the file name extension of the object. The file name extension is compared against a list of extensions for which the MIME-type/subtype combinations are known. For example, if fname was https://www.syr.edu/smiley.gif, then the .gif extension would have been identified as a known MIME-type and would have returned the string image/gif. The following is a list of file name extensions and the corresponding MIME-type/subtype combinations that this method returns.
Extension MIME-type/subtypeImports
import java.net.URLConnection;
Returns
If the extension of the specified object matched a known extension, then the corresponding MIME-type/subtype combination is returned. The string content/unknown is returned for file names whose extensions do not match any of the known extensions.
See Also
The guessContentTypeFromStream method of this class
Example
This protected method can only be accessed by subclasses of the URLConnection class and by classes in the java.net package. The following code sample shows how you might invoke this method within a class that extends the URLConnection class.
// File: CustomURLConnection.javaguessContentTypeFromStream(InputStream)
ClassName
URLConnection
Purpose
Guesses the MIME-type/subtype of the specified object by inspecting the data read from the specified InputStream.
Syntax
static protected String guessContentTypeFromStream(InputStream is) throws IOException
Parameters
is
The InputStream that is connected to the remote object whose content type is to be determined
Description
This method tries to determine the content type of an object by reading and examining data from the object. Many content types such as image files have magic strings as part of the header of the object that identify the object as a particular image format. Use this method with care!
Imports
import java.net.URLConnection;
Returns
If a valid content type is detected, this method returns the MIME-type/subtype combination of the object; otherwise, it returns a null value.
See Also
The guessContentTypeFromName method of this class
Example
This protected method can only be accessed by subclasses of the URLConnection class and by classes in the java.net package. This method can be used in a manner similar to the way that the guessContentTypeFromName is used. The difference between the two is that the parameter supplied to this method is an InputStream object instead of a file name.
setAllowUserInteraction(boolean)
ClassName
URLConnection
Purpose
Sets the value of the flag that indicates whether the protocol permits user-interaction while establishing the connection to the remote object.
Syntax
public void setAllowUserInteraction(boolean bFlag)
Parameters
bFlag
The boolean value that, if set to true, allows user-interaction or, if set to false, disables user-interaction.
Description
Protocols such as http, that have access and security control features, allow user-interaction (such as authentication by asking for a user name and password) during the process of setting up a connection to an object referred to in a URL. Protocol implementors must specify whether this interaction is permitted by the protocol or not. This variable is maintained on a per-instance basis for the URLConnection class. This method cannot be invoked if the URLConnection object is already "connect()"ed.
Imports
import java.net.URLConnection;
Returns
None.
See Also
The getAllowUserInteraction, getDefaultAllowUserInteraction, and the setDefaultAllowUserInteraction methods of this class
Example
The following example illustrates how you might invoke this method to manipulate whether or not to allow user-interaction.
import java.net.*;setContentHandlerFactory(ContentHandlerFactory)
ClassName
URLConnection
Purpose
Specifies the factory object (that implements the ContentHandlerFactory interface) that knows how to create content-specific ContentHandler objects.
Syntax
public static synchronized void setContentHandlerFactory(ContentHandlerFactory factory)
Parameters
factory
The ContentHandlerFactory object that must be used to create content-specific content handlers.
Description
All objects of the URLConnection class share the same ContentHandlerFactory object. By invoking this method, you can install your own ContentHandlerFactory. An error is generated if a ContentHandlerFactory already exists. If you write new content handler classes and install these classes in nonstandard locations, then you will need to create a class that implements the ContentHandlerFactory interface. This class will need to know where to find the content-specific implementations of the ContentHandler class.
Imports
java.net.URLConnection;
Returns
None.
See Also
The ContentHandlerFactory class described in this chapter
Example
The following code sample shows how you can direct the URLConnection class to use a custom ContentHandlerFactory object.
import java.net.*;setDefaultAllowUserInteraction(boolean)
ClassName
URLConnection
Purpose
Sets the default value of the flag that indicates whether the protocol permits user-interaction while establishing the connection to the remote object.
Syntax
public static void setDefaultAllowUserInteraction(boolean bFlag)
Parameters
bFlag
The default boolean value for this property.
Description
The variable that stores the value of the flag associated with this property is a static variable in the URLConnection class. Setting this variable will affect all future connections made by URLConnection classes created henceforth.
Imports
import java.net.URLConnection;
Returns
None.
See Also
The getDefaultAllowUserInteraction, getAllowUserInteraction, and setAllowUserInteraction methods of this class
Example
This method is a static method of the URLConnection class and does not need an object reference to invoke the method. You can invoke the method by prefixing it with the class name as shown here:
. // somewhere in your Java applicationsetDefaultRequestProperty(String, String)
ClassName
URLConnection
Purpose
Sets the default value associated with the specified field of the request header.
Syntax
public static void setDefaultRequestProperty(String fieldName, String fieldValue)
Parameters
fieldName
The name of the field in the request header.
fieldValue
The default value to assign to the above field.
Description
In a protocol transaction such as http, the client sends a list of fields to the http server. Some of these fields (such as Accept and Accept Encoding) convey information about the capabilities of the client. This method is used to set the default values associated with a specified field of the request header. For example, you may set the default value of the Accept field to text/plain, text/html, and image/gif. Doing this allows the client to inform the server that it can accept plain files and HTML files, as well as GIF images. The values set here are used for initialization whenever a URLConnection object is constructed. The default implementation of this method (in the URLConnection class) does nothing.
Imports
import java.net.URLConnection;
Returns
None.
See Also
The getDefaultRequestProperty method of this class
setDefaultUseCaches(boolean)
ClassName
URLConnection
Purpose
Sets the default value of the flag that indicates whether the protocol should use the cache to retrieve an object or whether it should ignore the cache and fetch the object from the remote site.
Syntax
public void setDefaultUseCaches(boolean bFlag)
Parameters
bFlag
The default boolean value for this property.
Description
Some protocols use local caches to enable quick access to previously retrieved objects. The URLConnection class maintains a per-instance boolean variable that indicates whether to use caching or not. A static boolean variable specifies the default value for the per-instance variable. This method sets the value of the static boolean variable. Setting this value affects all URLConnection objects created hereafter.
Imports
import java.net.URLConnection;
Returns
None.
See Also
The getDefaultUseCaches, setUseCaches, and getUseCaches methods of this class
setDoInput(boolean)
ClassName
URLConnection
Purpose
Sets the value of the flag that indicates whether this URLConnection can be used for input (i.e., can be read from).
Syntax
public void setDoInput(boolean bFlag)
Parameters
bFlag
The boolean value for this property. If set to true, this URLConnection object can be read from.
Description
The parameter bFlag specifies whether or not this URLConnection object can be used for input. If it is set to false, data cannot be read from this URLConnection object. This method should not be invoked if the URLConnection object is already "connect()"ed.
Imports
import java.net.URLConnection;
Returns
None.
See Also
The getDoInput method of this class
setDoOutput(boolean)
ClassName
URLConnection
Purpose
Sets the value of the flag that indicates whether this URLConnection can be used for output (i.e., can be written to).
Syntax
public void setDoOutput(boolean bFlag)
Parameters
bFlag
The boolean value for this property. If set to true, this URLConnection object can be used for output (i.e, it can be written to).
Description
The parameter bFlag specifies whether or not this URLConnection object can be used for output. If it is set to false, data cannot be written to the remote object using this URLConnection object. This method should not be invoked if the URLConnection object is already "connect()"ed.
Imports
import java.net.URLConnection;
Returns
None.
See Also
The getDoOutput method of this class
setIfModifiedSince(long)
ClassName
URLConnection
Purpose
Sets the time sent as the value of the If-Modified-Since header field of the request header to determine whether or not an object should be retrieved.
Syntax
public void setIfModifiedSince(long timeValue)
Parameters
timeValue
The time value that the server should use for comparison to determine whether or not the object is to be sent to this URLConnection.
Description
The If-Modified-Since field of the request header is sent by the client to the server in order to make the retrieval of an object conditional. By specifying a time with this header field, the client instructs the server not to send the object if the object has not changed since the time indicated by the value for this header field. This method sets the value associated with this field. This method should not be invoked if the URLConnection object is already "connect()"ed.
Imports
import java.net.URLConnection;
Returns
None.
setRequestProperty(String, String)
ClassName
URLConnection
Purpose
Sets the value associated with the specified request header field name.
Syntax
public void setRequestProperty(String key, String value)
Parameters
key
The name of the field in the request header.
value
The default value to assign to the above field.
Description
In a protocol transaction such as http, the client sends a list of fields to the http server. These fields are part of the request header. In the http protocol, From, Accept, If-Modified-Since, and Pragma are some of the field names sent in the request header. This method is used to set the value associated with a specific property. This method should not be invoked if the URLConnection object is already "connect()"ed. The default implementation of this method (in the URLConnection class) throws an IllegalAccessError if the URLConnection object is already "connect()"ed.
Imports
import java.net.URLConnection;
Returns
None.
See Also
The getRequestProperty method of this class
setUseCaches(boolean)
ClassName
URLConnection
Purpose
Sets the value of the flag that indicates whether this URLConnection object should use the cache to retrieve an object or whether it should ignore the cache and fetch the object from the remote site.
Syntax
public void setUseCaches(boolean bFlag)
Parameters
bFlag
The boolean value that indicates whether this URLConnection should use the caches or not.
Description
Some protocols use local caches to enable quick access to previously retrieved objects. The URLConnection class maintains a per-instance boolean variable that indicates whether to use caching or not. This method sets the value of this boolean variable. This method should not be invoked if the URLConnection object is already "connect()"ed.
Imports
import java.net.URLConnection;
Returns
None.
See Also
The getUseCaches, setDefaultUseCaches, and getDefaultUseCaches methods of this class
toString()
ClassName
URLConnection
Purpose
Represents the parameters of the URLConnection object as a String.
Syntax
public String toString()
Parameters
None.
Description
This method is used when the parameters associated with this URLConnection object are to be printed as a string. This method is generally used for debugging purposes.
Imports
import java.net.URLConnection;
Returns
This method returns a String object that contains the values of the parameters for this URLConnection object. The default implementation of this method prints the class name and the URL that this URLConnection object was created for. Subclasses of the URLConnection class can override this method to provide more information.
Example
The following example prints the text representation of a URLConnection object.
import java.net.*;This example prints the following string on the screen:
sun.net.www.protocol.http.HttpURLConnection:https://cosmos/~asriniva/URLEncoder
Purpose
Encodes strings into URL format. Encoding a string in this uniform format ensures that the string is not corrupted by errors such as character set variations on different systems.
Syntax
public class URLEncoder extends Object
Description
Some protocols use characters (in the URL specification) that may cause problems due to corruption by imperfect gateways or to a difference in the character sets used in different environments. You will find this class very useful if you are writing Java programs that interact with CGI (Common Gateway Interface) scripts. Figure 11-7 shows the inheritance diagram for the URLEncoder class.
Figure 11-7 Inheritance diagram for the URLEncoder class
PackageName
java.net
Imports
import java.net.URLEncoder;
Constructors
None.
Parameters
None.
Example
Refer to the example for the encode method of this class. This method is also used in the example for the getOutputStream method of the URLConnection class described in this chapter.
encode(String)
ClassName
URLEncoder
Purpose
Returns a URL encoded form of the specified string.
Syntax
public static String encode(String s)
Parameters
s
The string to be encoded.
Description
This method simply translates the text string s into a URL encoded string and returns this string. The following (sets of) characters are left unchanged in the encoded form of the text string: characters A through Z, a through z, 0 through 9 and the underscore character (_). The space character () is replaced with the + sign. All other characters are replaced by a percent sign (%) followed by a 2-digit hexadecimal number. This hexadecimal number represents the value of the character.
Imports
import java.net.URLEncoder;
Returns
This method returns a String object that contains the URL encoded representation of the text in the string s.
Example
Because this method is static, you can invoke it simply by prefixing it with the class name (URLEncoder), as illustrated in the TestEncoder example shown here.
import java.net.URLEncoder;When this example is compiled (javac TestEncoder.java) and run (java TestEncoder), it produces the following output.
Source string: https://myschool.edu/index.htmlURLStreamHandler
Purpose
Specifies an abstract base class that must be subclassed to implement stream handlers for specific protocols (such as http, nntp, ftp, and so on).
Syntax
public class URLStreamHandler extends Object
Description
To implement a protocol handler in Java, you will need to subclass both the URLStreamHandler class and the URLConnection class. The URLStreamHandler object returns a URLConnection object, which is connnected to the specified URL. This URLConnection object implements the specifics of the protocol. This class defines the methods that can be overridden in the subclass to implement the protocol-specific functionality. Except for the constructor, the rest of the methods of this class are protected, which implies that these methods can be accessed only from within the package in which the subclasses are defined. An instance of the subclass that implements the functionality required for a specific protocol is created within the constructor of the URL class. Figure 11-2 shows the basic relationships between URLs, ProtocolHandlers, and ContentHandlers.
By convention, the URLStreamHandler class is always called Handler and it is always created by referring to the absolute path name for the class. The ambiguity of all the URLStreamHandler subclasses being called Handler is resolved by referring to each class using its absolute path name specification. The URL class, by default, looks for a class named Handler in a subdirectory named with the protocol name in the sun/net/www/protocol directory. The sun/net/www/protocol directory structure can be found along with the other standard directories containing the .class files that Java uses. For example, the subclass of the URLStreamHandler class that handles the http protocol will be located in the sun/net/www/protocol/http/Handler.class file. If you are writing protocol handlers, you can either follow this convention or you can write your own class that implements the URLStreamHandlerFactory interface. This factory should know how to create instances of your protocol handlers.
Figure 11-8 shows the inheritance diagram for the URLStreamHandler class.
Figure 11-8 Inheritance diagram for the URLStreamHandler
class
PackageName
java.net
Imports
import java.net.URLStreamHandler;
Constructors
public URLStreamHandler()
Parameters
None.
Example
The following code shows how you create a custom URL StreamHandler.
// File: CustomURLConnection.javaopenConnection(URL)
ClassName
URLStreamHandler
Purpose
Opens an active connection to the specified URL and returns an object that represents this connection.
Syntax
protected abstract URLConnection openConnection(URL u) throws IOException
Parameters
u
The URL object specifying the Uniform Resource Locator to which the connection should be established.
Description
This method must be overridden in the subclass of the URLStreamHandler class that handles a specific protocol. This method should create and return an instance of a subclass of the URLConnection class that handles the connection stream to the protocol-specific data.
Imports
import java.net.URLStreamHandler;
Returns
This method returns an instance of a protocol-specific implementation of the URLConnection class. This object is used to get access to the actual data the URL points to.
See Also
The URL.getContent(URL) method
Example
Please refer to the example for the constructor method of this class.
parseURL(URL, String, int, int)
ClassName
URLStreamHandler
Purpose
Parses a string specification of a Uniform Resource Locator into the context of an existing URL object.
Syntax
protected void parseURL(URL u, String spec, int start, int limit)
Parameters
u
The URL object to use as the context for parsing the string specification (spec).
spec
A string object that specifies a Uniform Resource Locator as a text string.
start
The start index in spec at which to start the parsing.
limit
The character position in spec at which to stop parsing.
Description
The string specification spec is parsed as a URL. If it is an absolute URL, then the value of the context URL object u is set to this new URL. If the string specification is a relative path specification, then this path is parsed into u. The start parameter usually points to the character position immediately following the ':' character in a URL, and the limit index is normally the last character in the string or the position of the '#' reference mark. When a URL object is created, a URLStreamHandler object for the protocol specified in the URL is created and this method is invoked on that URLStreamHandler object.This protected method can be invoked only by the other classes in the java.net package.
Imports
import java.net.URLStreamHandler;
Returns
None. The result of the parsing is stored in the URL object u.
See Also
The URL class constructors described in this chapter
Example
This method can only be invoked by classes in the java.net package and hence no example code illustrating the usage of this method is provided here.
setURL(URL)
ClassName
URLStreamHandler
Purpose
Sets the fields of the specified URL object. This is used when a string specification is to be parsed into the context of an existing URL object.
Syntax
protected void setURL(URL u, String protocol, String host, int port, String file, String ref)
Parameters
u
The URL object that is to be modified.
protocol
The protocol (http, news, etc) to use for the URL.
host
The Internet name of the host machine.
port
The port number on the host machine.
file
The path name of the file on the host.
ref
The name of the reference that indicates a specific offset (to an anchor) into the file.
Description
This protected method is invoked by the parse(URL, String, int, int) method of this class to set the individual fields of a URL that is used as a context for parsing a string specification into.
Imports
import java.net.URLStreamHandler;
Returns
None.
See Also
The parse method of this class
Example
This method can only be invoked by classes in the java.net package and hence no example code illustrating the usage of this method is provided here.
toExternalForm(URL)
ClassName
URLStreamHandler
Purpose
Represents the specified URL object as a text string.
Syntax
protected String toExternalForm(URL u)
Parameters
u
The URL object that is to be represented as a plain text string.
Description
The specified URL object is queried to extract the individual fields (such as protocol, hostname, port, file, and reference tag) and these values are concatenated to form a text string. This text string is then returned to the invoker of this method. This is a protected method and can be accessed only by the other classes in the java.net package.
Imports
import java.net.URLStreamHandler;
Returns
This method returns a text string that represents the specified UniformResource Locator.
See Also
The toString and toExternalForm methods of the URL class, described in this chapter
URLStreamHandlerFactory
Purpose
Defines the interface that must be implemented by a class that knows how to create an instance of a specific subclass of URLStreamHandler for a specific protocol.
Syntax
public interface URLStreamHandlerFactory extends Object
Description
A class that implements this interface must know the specific subclass of URLStreamHandler that needs to be created for a protocol. As mentioned earlier in this chapter, the URLStreamHandler class needs to be subclassed to implement a URLStreamHandler for each protocol that is supported by the browser. The implementation details of constructing specific instances of the subclasses of URLStreamHandler are hidden behind this interface. Figure 11-9 shows the inheritance diagram for the URLStreamHandlerFactory interface.
Figure 11-9 Inheritance diagram for the
URLStreamHandlerFactory interface
PackageName
java.net
Imports
import java.net.URLStreamHandlerFactory;
Constructors
None.
Parameters
None.
createURLStreamHandler(String)
InterfaceName
URLStreamHandlerFactory
Purpose
Creates an instance of a subclass of the URLStreamHandler class that knows how to create and handle streams for a specified protocol.
Syntax
public abstract URLStreamHandler createURLStreamHandler(String protocol)
Parameters
protocol
The protocol for which an instance of a specific subclass of the URLStreamHandler class (that handles the specified protocol) needs to be created.
Description
To implement a protocol handler in Java, you must extend the URLStreamHandler class and implement the specifics of the protocol. One of the data members of the URL class is an instance of a class that implements the URLStreamHandlerFactory interface. This data member is the same for all instances of the URL class (i.e., it is a static member) and can be set using the setURLStreamHandlerFactory method of the URL class. When you construct an URL object, the URL class invokes this method on its factory object to create an instance of the URLStreamHandler subclass that handles the protocol specified in the constructor of the URL object.
Imports
java.net.URLStreamHandlerFactory
Returns
This method returns an instance of a subclass of the URLStreamHandler object that handles the specified protocol (http, nntp, and so on).
See Also
The setURLStreamHandlerFactory of the URL class described in this chapter
Example
The following Java class implements the URLStreamHandlerFactory interface.
// File: CustomURLStreamHandlerFactory.javaMalformedURLException
Purpose
Signals that the specified Uniform Resource Locator (URL) is invalid.
Syntax
public class MalformedURLException extends IOException
Description
This exception is used to indicate that the URL specified is not valid. It should be used by applets to indicate that an error occurred because the specified URL was not valid. A URL that specifies an unsupported protocol is one example of a case where this exception is thrown to indicate an error in the specified protocol. Figure 11-10 shows the inheritance diagram for the MalformedURLException class.
Figure 11-10 Inheritance diagram for the
MalformedURLException class
PackageName
java.net
Imports
import java.net.MalformedURLException;
Constructors
public MalformedURLException()
public MalformedURLException(String msg)
Parameters
msg
A placeholder for a message that can be used to give additional information to the user about the error that triggered this exception.
Example
The following example shows how this exception can be caught in an application.
import java.net.*;ProtocolException
Purpose
Indicates that an EPROTO error was detected when the application tried to connect to a socket.
Syntax
public class ProtocolException extends IOException
Description
This exception specifically indicates that a protocol (EPROTO) error was detected when the application tried to connect to a socket. Figure 11-11 shows the inheritance diagram for the ProtocolException class.
Figure 11-11 Inheritance diagram for the ProtocolException
class
PackageName
java.net
Imports
import java.net.ProtocolException;
Constructors
public ProtocolException()
public ProtocolException(String msg)
Parameters
msg
This string can be used to give a specific description of the error that caused the ProtocolException to be thrown.
Example
The following code sample shows how you use a try/catch statement pair to catch this exception.
import java.net.ProtocolException;SocketException
Purpose
Indicates that an error occurred during an operation using a socket.
Syntax
public class SocketException extends IOException
Description
This exception is used to indicate errors that occur while operations are being performed on sockets. Applications may specify additional details of the error that caused this exception to be thrown in the msg parameter of the constructor for this exception. Figure 11-12 shows the inheritance diagram for the SocketException class.
Figure 11-12 Inheritance diagram for the SocketException
class
PackageName
java.net
Imports
import java.net.SocketException;
Constructors
public SocketException()
public SocketException(String msg)
Parameters
msg
This string can be used to give a specific description of the error that occurred while using the socket.
Example
The following code sample shows how you use a try/catch statement pair to catch this exception.
import java.net.SocketException;UnknownHostException
Purpose
Indicates that the address of the host specified by a network client is not valid.
Syntax
public class UnknownHostException extends IOException
Description
This exception is thrown when the host address (specified by an application that is trying to connect to a server) cannot be resolved as a valid address. Applications that use the socket classes and the classes that deal with Uniform Resource Locators use this class to signal and handle error conditions. Figure 11-13 shows the inheritance diagram for the UnknownHostException class.
Figure 11-13 Inheritance diagram for the UnknownHostException
class
PackageName
java.net
Imports
import java.net.UnknownHostException;
Constructors
public UnknownHostException()
public UnknownHostException(String msg)
Parameters
msg
A placeholder for a message that can be used to give additional information to the user about the error that triggered this exception.
Example
The following code sample shows how you use a try/catch statement pair to catch this exception.
import java.net.UnknownHostException;UnknownServiceException
Purpose
Signals an error indicating that the requested service is not supported by the client-server protocol.
Syntax
public class UnknownServiceException extends IOException
Description
This exception is used to indicate that a particular service is not recognized by the protocol being used to effect the network transaction. This is intended primarily for use by developers of protocol handlers. Protocol handlers will extend the URLConnection class to handle specific protocols and it is in this class that this exception will be used to indicate that a service is not supported by the protocol handler. Figure 11-14 shows the inheritance diagram for the UnknownServiceException class.
Figure 11-14 Inheritance diagram for the
UnknownServiceException class
PackageName
java.net
Imports
import java.net.UnknownServiceException;
Constructors
public UnknownServiceException()
public UnknownServiceException(String msg)
Parameters
msg
A placeholder for a message that can be used to give additional information to the user about the error that triggered this exception.
Example
The following code sample shows how you use a try/catch statement pair to catch this exception.
import java.net.UnknownServiceException;This applet invokes many of the methods in the URL class. By looking at this applet and running it, you will become more familiar with using the URL class. The different types of constructors for URL objects are implemented in this example and the individual fields of a URL are parsed and displayed on the screen. Data contained in the URL object is read from it and printed in the TextArea component of the URLtest applet. Figure 11-15 shows the URLtest applet in action.
Figure 11-15 The URLtest applet in action
This applet divides its display area into two regions. In the first region (represented by class URLPanel), the various parameters of the URL object are displayed to the user. The second region is the control panel that controls which URL's fields are displayed in the URLPanel area. The URLTestControls class implements this simple control panel.
1. The class name for the applet is URLtest, so edit a new file named URLtest.java and type the following code into this file. (As always, you must first import the necessary java packages.)
import java.awt.*;2. Now create the URLtest class which simply extends the java.applet.Applet class. It uses the BorderLayout layout manager to lay out the URLPanel and the URLTestControls objects one below the other. The event handler for this class traps the WINDOW_DESTROY event and exits if the user closes the application. It has a main method so that it can be run as an applet or as a stand-alone Java program.
public class URLtest extends Applet3. The URLPanel displays the field parameters of the URL that was selected in the Choice box of the URLTestControls area. This class sets up labels for the fields of the URL and arranges these labels in a two-column format. A TextArea component is used to display the data read from the URL object.
class URLPanel extends Panel5. The next method is invoked to parse a URL string specification and display the individual field values. A URL object is created using the specified string and the individual fields of the URL are extracted using the methods of the URL class. The contents of the URL object are read and these contents are displayed in the TextArea component. An error message is printed in the TextArea if an exception was caught while reading the contents of the URL. If the specified URL string is not a valid URL then the MalformedURLException is trapped and an error message is displayed on the ErrorStatus Label component of this panel.
public void showParams(String urlString) catch (IOException ie)6. This event handler exits if the user quits the application.
public boolean handleEvent(Event e)7. All you have left to do is put up the main control panel for this applet. The URLTestControls class is the control panel. It displays a Choice component with different URLs in it that the user can select. When a URL is selected, the fields of the URL are displayed in the URLPanel area. This class needs to notify the URLPanel whenever a selection is made, so it keeps a reference to the URLPanel object. The constructor utilizes the different forms of constructors for the URL class and adds the string representation of these URLs to the Choice box. An invalid URL specification is also added to the list of choices. This will enable you to see how exceptions are caught.
class URLTestControls extends Panel catch (MalformedURLException mue)8. When a selection is made from the list of choices, the event handler notifies the URLPanel to update the URL field parameters, as seen in the following example.
public boolean action(Event e, Object arg) else if (e.id == Event.WINDOW_DESTROY)9. That's it, you have finished creating the applet. Now save this file and compile it by typing javac URLtest.java. Then run the application by typing java URLtest.
This applet divides its display area into two regions. In the first region (represented by class URLPanel), the various parameters of the URL object are displayed to the user. The second region is the control panel that controls which URL's fields are displayed in the URLPanel area. The URLTestControls class implements this simple control panel.
1. The class name for the applet is URLtest, so edit a new file named URLtest.java and type the following code into this file. (As always, you must first import the necessary java packages.)
import java.awt.*;2. Now create the URLtest class which simply extends the java.applet.Applet class. It uses the BorderLayout layout manager to lay out the URLPanel and the URLTestControls objects one below the other. The event handler for this class traps the WINDOW_DESTROY event and exits if the user closes the application. It has a main method so that it can be run as an applet or as a stand-alone Java program.
public class URLtest extends Applet3. The URLPanel displays the field parameters of the URL that was selected in the Choice box of the URLTestControls area. This class sets up labels for the fields of the URL and arranges these labels in a two-column format. A TextArea component is used to display the data read from the URL object.
class URLPanel extends Panel5. The next method is invoked to parse a URL string specification and display the individual field values. A URL object is created using the specified string and the individual fields of the URL are extracted using the methods of the URL class. The contents of the URL object are read and these contents are displayed in the TextArea component. An error message is printed in the TextArea if an exception was caught while reading the contents of the URL. If the specified URL string is not a valid URL then the MalformedURLException is trapped and an error message is displayed on the ErrorStatus Label component of this panel.
public void showParams(String urlString) catch (IOException ie)6. This event handler exits if the user quits the application.
public boolean handleEvent(Event e)7. All you have left to do is put up the main control panel for this applet. The URLTestControls class is the control panel. It displays a Choice component with different URLs in it that the user can select. When a URL is selected, the fields of the URL are displayed in the URLPanel area. This class needs to notify the URLPanel whenever a selection is made, so it keeps a reference to the URLPanel object. The constructor utilizes the different forms of constructors for the URL class and adds the string representation of these URLs to the Choice box. An invalid URL specification is also added to the list of choices. This will enable you to see how exceptions are caught.
class URLTestControls extends Panel catch (MalformedURLException mue)8. When a selection is made from the list of choices, the event handler notifies the URLPanel to update the URL field parameters, as seen in the following example.
public boolean action(Event e, Object arg) else if (e.id == Event.WINDOW_DESTROY)9. That's it, you have finished creating the applet. Now save this file and compile it by typing javac URLtest.java. Then run the application by typing java URLtest.
This project illustrates some of the methods of the URL class. These methods are applied to different URL strings and the results of these methods are displayed. This project also shows how you can use the URL class to read data from a remote URL object. Java programs written for Internet applications will find the URL class invaluable. Classes such as the ContentHandler class and the URLStreamHandler class can easily be extended to support custom data formats and protocols.These custom formats can then be viewed using the class extensions. The classes and interfaces described in this chapter provide functionality for accessing data on the Internet, and for sending to and receiving information from the World Wide Web.
Politica de confidentialitate | Termeni si conditii de utilizare |
Vizualizari: 1003
Importanta:
Termeni si conditii de utilizare | Contact
© SCRIGROUP 2025 . All rights reserved