advertisement
javaboutique
Search Tips
Articles  |   Tutorials  |   Reviews  |   Tools  |   by Category  |   by Date  |   by Name  |   Submit  |   Source  |   Forums  |  
javaboutique
Browse DevX


Partners & Affiliates











advertisement

Tutorials : Creating Content and Protocol Handlers in Java, Part 2 :

Creating Content and Protocol Handlers in Java, Part 2

by Anghel Leonard

Part 1 of this series showed you how to work with an existing content handler and how to create a new one. It also discussed how to define a new MIME type for a new kind of file (the .xy file) and how to transfer it from a simple HTTP server to a Java client. In principle, the Internet browser (Internet Explorer 6.0) and the Java client that you have developed for the new content handler use the same idea—that is, both of them use the HTTP specification protocol for connecting and sending a request to the HTTP server HTTPServer.java (the source code for this minimal HTTP server can be viewed in Part 1). When they get the sever response, they process it using their appropriate content handlers.

The question is: how does the Java client (or the browser) know that it will "talk" with an HTTP server and how does it know what to "say"? The answer is that the Java client has no idea what kind of server it will "talk" to. The Java client just parses the provided URL and extracts the protocol name (http, ftp, etc.). After that, it associates the protocol name with the corresponding protocol implementation. These tasks are accomplished by the protocol handler.

In this article, you will learn how to work with an existing Java protocol handler and how to create a new one. Of course, when you're writing your own protocol handler, it will not be recognized by Internet servers, or any other kind of servers, because they can't possibly recognize it. For testing purposes, these examples use the HTTPServer.java you developed in Part 1. This server will recognize the protocol handler defined in Part 2 and the content handler defined in Part 1.

Working with an Existing Protocol Handler

Whenever you "ask" for an Internet resource, the browser must complete three essential tasks.
  1. The first task is to parse the specified URL (conforming to URL specifications) and extract the protocol name.
  2. The second task is based on the protocol name—the browser is choosing "the right words" for connecting and communicating with the requested server. The final task is to put the received resource into a readable form. These first two tasks are accomplished by the protocol handler.
  3. The final task is accomplished by the content handler. The browser has a protocol handler for every kind of protocol, so the HTTP protocol handler know how to "talk" with an HTTP server, a FTP protocol handler know how to "talk" with an FTP server, etc.
In Java, URL objects use protocol handlers to open connections to specified servers. By default, Java supports a set of protocol handlers that have been developed for the most common protocols, but Java also offers you support for any new protocol handlers you should create. Such support can be found in the java.net.URLStreamHandler and java.net.URLConnection classes.

The default protocol handlers' class names, along with their associated package names, reflect the protocol names themselves. For example, the http protocol's proper protocol handler is in the sun.net.www.protocol.http package and its name is Handler.class. The sun.net.www.protocol path is fixed and the rest depends on the protocol name. The table below contains the correspondence between some protocol names and their protocol handlers (J2SE 1.5):

Protocol name

path

class

doc

sun.net.www.protocol.doc

Handler.class

file

sun.net.www.protocol.file

Handler.class

ftp

sun.net.www.protocol.ftp

Handler.class

gopher

sun.net.www.protocol.gopher

Handler.class

http

sun.net.www.protocol.http

Handler.class

jar

sun.net.www.protocol.jar

Handler.class

mailto

sun.net.www.protocol.mailto

Handler.class

netdoc

sun.net.www.protocol.netdoc

Handler.class

systemresource

sun.net.www.protocol.systemresorce

Handler.class

verbatim

sun.net.www.protocol.verbatim

Handler.class

Xy (your protocol handler)

sun.net.www.protocol.xy

Handler.class

Note: Usually, the sun.net.www.protocol... path is in the <JDK_HOME>/jre/lib/rt.jar.

Listing 1 demonstrates how to create a simple Java client that uses the protocol handler specific to the HTTP protocol for connecting and communicating with an HTTP server.

As you can see, the default HTTP protocol handler eliminates the need to write any HTTP commands because Java knows how to implement it in the sun.net.www.protocol.http package.

How to Add Java Applets to Your Site

New on the Java Boutique:

New Review:

Time Management Made Easy with the Quartz Enterprise Job Scheduler
Why not just use the Java timer API? This open source scheduling API boasts simplicity, ease-of-integration, a well-rounded feature set, and it's free!

New Applet:

Reverse Complement
Reverse Complement is a simple applet that converts DNA or RNA sequences into three useful formats.

Elsewhere on internet.com:

WebDeveloper Java
Lots of Java information on webdeveloper.com

WDVL Java
Thorough Java resource at the Web Developer's Virtual Library.

ScriptSearch Java
Hundreds of free Java code files to download.

jGuru: Your View of the Java Universe
Customizable portal with online training, FAQs, regular news updates, and tutorials.

 Microsoft RIA Development Center
 IBM Rational Resource Center
 Destination .NET
XML error: not well-formed (invalid token) at line 33
advertisement
Receive Articles via our XML/RSS feed
Receive Articles via our XML/RSS feed

JavaBytes
Internet Cyclone
This powerful, easy-to-use, internet optimizer is for Windows 95, 98, ME, NT, 2000 and XP. It's designed to automatically optimize your Windows settings, boosting your Internet connection up to 200%.

Facebook Wants to Power Web-Wide Apps
OpenSolaris to Support Facebook, OpenSocial
Sun Takes a Shine to Linux in New Web Stack
MySQL: Back to Its Roots via Sun
Ubuntu Founder: Linux Should Focus on Looks
Intel's Building Blocks Thread Open Source
What Lies Ahead for SOA?
Novell Turns ICE Into Kablink
Is Open Source Development Insecure?
JUNOS: Open, but Not Open Source

View Rendering in Java: Templates Out, Groovy Builders In
Getting the Most from Virtualization
Rational Team Concert
IBM® Rational® Quality Management Open Beta
SIP Application Delivery eKit
Rational Requirements Definition and Management Open Beta:
Download IBM Rational Team Concert
Network Know-how: Finding Shortest Paths
Applying SKOS Concept Schemes
Managing an Agile Software Project

Advertising Info  |   Member Services  |   Contact Us  |   Help  |   Feedback  |   Site Map  |   Network Map  |   About



JupiterOnlineMedia

internet.comearthweb.comDevx.commediabistro.comGraphics.com

Search:

Jupitermedia Corporation has two divisions: Jupiterimages and JupiterOnlineMedia

Jupitermedia Corporate Info


Legal Notices, Licensing, Reprints, & Permissions, Privacy Policy.

Advertise | Newsletters | Tech Jobs | Shopping | E-mail Offers