ITworld.com
  Search  
Menu Changing the way you view IT
Gunning for Sun
Sign up for XML IN PRACTICE
More Newsletters
 
 

XML IN PRACTICE --- 08/23/2001



Tom Yager

Java can be used many ways in Web applications, from the simple, old- fashioned CGI to the complex J2EE (Java 2 Enterprise Edition) framework. With help from the open-source community, Lutris Technologies Inc. has developed Enhydra (http://www.enhydra.org), a unique, pure-Java framework for enterprise Web applications.
Advertisement
On this topic




Enhydra is a collection of open-source Java projects made commercial by the addition of Lutris' documentation, code samples, and support. These added benefits are worth the scant investment -- $995 per CPU, as compared to J2EE fees of as much as $25,000 per CPU -- if you buy into Enhydra's approach to Web applications. Lower-cost alternatives to J2EE can only do the market good, but at the same time, it is reasonable to question the long-term wisdom of adopting any enterprise Java framework but J2EE.

This latest Enhydra release updates Java compatibility to Java Developer's Kit Version 1.3, adds graphical application creation wizards, enhances the InstantDB Java database, extends support to wireless applications, and strengthens the Kelp development toolset.

To appreciate Enhydra 3.52's uniqueness, you should understand how Sun Microsystems Inc. constructs Web applications. In Sun's Java servlet model, a Web server passes HTTP requests from users to the Java servlet responsible for the requested information. The servlet parses the user's request, interacts with databases and back-end systems as needed, and produces the dynamic Web page that's displayed in the user's browser. An extension of servlets, JSP (Java Server Pages) uses HTML and XML templates to shape the application's output.

Servlets and JSP work very well, but they have been criticized for failing to steer developers toward creating tiered applications. In contrast, Enhydra forces a sharp delineation between an application's presentation and business tiers. Enhydra developers can work independently on business logic and presentation code (in this case, HTML), freeing each developer to focus on his or her strongest skills. Enhydra weaves the separate tiers together at run time.

The key to Enhydra is Lutris' XMLC (XML compiler). Instead of marking HTML and XML documents with special tags that let a presentation engine such as JSP know where to insert data, a developer working with XMLC creates an ordinary, static HTML or XML document that's displayable on any browser. XMLC digests the document and creates an object model that the Java developer uses to produce a dynamic presentation. Aside from being easier to use than JSP and facilitating the advantageous separation of development roles, XMLC extends its capabilities to all HTML/XML dialects, including wireless variants such as WML (Wireless Markup Language) and cHTML (compact HTML).

XMLC's downside is that major changes to the HTML or XML document require it to be recompiled. Conceivably, an Enhydra project could bounce between development teams several times before it's ready for delivery. JSP makes it easier for developers to quickly tweak the presentation layer because the code and HTML share a single file.

Enhydra 3.52 does not include an IDE (integrated development environment). Instead, it enhances existing IDEs, such as Borland Software Corp.'s JBuilder and Oracle Corp.'s JDeveloper, with graphical tools that ease application creation, database connections, and management.

Enhydra's new graphical application wizard generates the template files and directory hierarchy needed for new projects. Supplant the wizard's sample code with some real Java and HTML is simple. The wizard creates a make file you use to rebuild the application each time you change it. The wizard makes the process easier, but the frequent rebuilds mean Enhydra projects take longer than those that use integrated approaches.

Enhydra 3.52 Web applications can run on their own or under an Apache Software Foundation, iPlanet E-Commerce Solutions, or Microsoft Corp. Web server. A stand-alone Enhydra application runs under Enhydra Multiserver, a servlet/JSP host that has a built-in low-volume Web server. Multiserver hosts Enhydra's administrative console. Using the Web interface, you can start, stop, and add new Enhydra applications to a running host. Multiserver includes load balancing and fail-over capabilities.

Enhydra 3.52 delivers an impressive bundle of functionality at a low cost. We like XMLC's clean separation of application tiers, but that's tempered by the need for frequent rebuilds and the chance that HTML/XML documents will fall out of sync with the Java code that manages them. Moreover, some developers may not be keen on learning skills they can't use everywhere.

Lutris delivers a muddled message with Enhydra. The vendor's Web site refers to it as an open-source project, yet Lutris insisted to us that Enhydra is not open-source. As it turns out, there are open-source and commercial versions of Enhydra, but they're not the same. It's a massive jumble that Lutris needs to clarify if it wants the place it deserves in the competitive application server market.

 

Tom Yager is technical director of InfoWorld's Test Center. He can be reached at tom_yager@infoworld.com.

Sponsored links
Locate Hidden Software on business PCs with this free tool
Bring harmony to your mix of UNIX-Linux-Windows computing environments
Top 5 Reasons to Combine App Performance and Security
KODAK i1400 Series Scanners stand up to the challenge
www.itworld.com    open.itworld.com     security.itworld.com     smallbusiness.itworld.com
storage.itworld.com     utilitycomputing.itworld.com     wireless.itworld.com

 
Contact Us   About Us   Privacy Policy    Terms of Service   Reprints  

CIO   Computerworld   CSO   GamePro   Games.net   IDG Connect   IDG World Expo   Industry Standard   Infoworld   ITworld   JavaWorld   LinuxWorld  MacUser   Macworld   Network World   PC World   Playlist  

Copyright © Computerworld, Inc. All rights reserved

Reproduction in whole or in part in any form or medium without express written permission of Computerworld Inc. is prohibited. Computerworld and Computerworld.com and the respective logos are trademarks of International Data Group Inc.