Bea Weblogic Workshop 8.1 (Beta) Jumpstart Guide
Bea Weblogic Workshop 8.1 (Beta) Jumpstart Guide
Trademarks
Copyright © 2003 BEA Systems, Inc. All rights reserved. BEA, Tuxedo, and WebLogic are registered trademarks and BEA
WebLogic Enterprise Platform, BEA WebLogic Server, BEA WebLogic Integration, BEA WebLogic Portal, BEA WebLogic
Platform, BEA WebLogic Express, BEA WebLogic Workshop, BEA WebLogic Java Adapter for Mainframe, and BEA eLink
are trademarks of BEA Systems, Inc. All other company and product names may be the subject of intellectual property rights
reserved by third parties.
COPYRIGHT....................................................................................................................................................... 2
(BONUS) EXERCISE #6: USING XMLBEANS FOR HANDLING XML IN JAVA ...................................... 57
CONCLUSION................................................................................................................................................... 62
In addition to the material covered in this guide, you may want to make use of the wealth
of online resources available to you at the BEA Web site (www.bea.com) including
datasheets, product brochures, white papers, demo software, press releases, and more.
Evaluation Software
Press Releases
The WebLogic Workshop 8.1 visual development environment delivers unprecedented ease-of-
use for J2EE application development. The Design View (shown in Figure 1) provides a
graphical depiction of the application being created so that developers can view and visually edit
the application’s interaction with clients and back-end resources. Moreover, the same visual
development environment is shared by all WebLogic Enterprise Platform 8.1 applications,
dramatically reducing the learning curve for building, testing, and debugging custom controls,
Web services, Web applications, portals, and integration applications.
Furthermore, WebLogic Workshop 8.1 improves the development experience by including many
IDE enhancements such as source code control integration, an enhanced windowing
environment, complete tool configurability, and shared tools and palettes.
BEA WebLogic Workshop’s run-time framework provides the abstraction layer between
developers and complex J2EE system infrastructure. Instead of dealing with time-consuming
API-level infrastructure code, component configuration, and deployment details, developers are
free to use the visual development environment to write procedural Java code where necessary
and access advanced functionality through simple, declarative annotations. The WebLogic
Workshop run-time framework interprets the annotated code to generate the appropriate J2EE
code including standard EJB, JMS, and JDBC components. And in this process, the run-time
framework also manages the design and implementation issues associated with J2EE
architectures, so that applications are implemented on reliable, scalable, and secure enterprise-
class architectures.
WebLogic Workshop
Run-time Framework
The WebLogic Workshop run-time framework – a standard J2EE application that runs on top of
BEA WebLogic Server 8.1 – also represents the convergence layer that unifies all WebLogic
Enterprise Platform application types.
BEA WebLogic Workshop's run-time framework abstracts the developer from the intricate details
of developing and deploying enterprise-class applications in the following ways:
• Java Web Service (JWS) File Support: Introduced in WebLogic Workshop 7.0, Web service
applications are developed as JWS files – standard Java files with a set of Javadoc
annotations that allow developers to specify properties and gain access to key Web service
functionality through simple declarative annotations. This approach conveniently eliminates
the need for developers to worry about SOAP marshalling, Java-to-XML binding, WSDL file
creation, underlying bean deployment, and much more. JWS is in the process of being
standardized through JSR (Java Specification Request) 181.
• Java Page Flow (JPF) File Support: WebLogic Workshop 8.1 Web applications are built
with Java Page Flow, a Java innovation that makes it easy for developers to build enterprise-
class Web applications using a visual approach to specify the flow of pages. Developers can
write business logic in actions that can be called from pages in the application. And to greatly
simplify data accessibility, WebLogic Workshop provides tag libraries plus drag-and-drop
wizards to automate data-binding between pages and data elements (including fields, lists,
trees, grids, etc.) from any database, Web service, or Java Control. In addition, the run-time
framework automatically provides support for details such as sessions and state-
management, and ultimately creates Java Page Flow applications on an underlying MVC
(model-view-controller) architecture leveraging Struts.
• Java Controls (JCX/JCS) File Support: Java Controls enable developers to access back-
end enterprise resources through a simplified interface already familiar to many developers.
Instead of calling a series of J2EE API calls, developers can implement methods and handle
events to access information from assets such as databases, external web services and EJB
components. Customization of controls can be performed by simply setting properties. The
run-time framework also makes Java Controls extensible so that all users can write their own
Java Controls
In WebLogic Workshop 8.1, Java Controls provide developers the ability to easily connect with
existing data, systems, applications, and business logic. Java Controls are visual components
with methods and properties that handle all of the J2EE details in connecting to an external
resource or piece of business logic. Developers interact with controls by handling events and
settings properties. Workshop also makes it easy to build custom controls using the similar,
simplified Java code approach available elsewhere in Workshop. These characteristics empower
developers to declaratively specify behavior and then focus on handling events and calling
methods with standard procedural Java code instead of learning APIs. Moreover, Java Controls
provide best-practices for accessing resources and application logic to ensure that resources are
optimally used.
BEA WebLogic Workshop 8.1 comes with a set of built-in Java Controls including the following:
• Web Service Control lets developers access Web services as local objects without worrying
about any of the lower-level Web service protocol details. The developer need only specify
• Timer Control helps developers program in an asynchronous world. The Timer Control can
be used to implement message timeouts, poll web services to determine completion, and
coordinate multiple asynchronous message replies.
• And many more: WebLogic Workshop 8.1 adds many more built-in Java Controls to make it
easy for developers to connect to and use IT assets, including FTP, eMail, Tuxedo, Portal,
Integration Controls, and more.
In addition to the suite of built-in Java Controls mentioned above, BEA WebLogic Workshop 8.1
also makes the Java Controls model extensible so that all users (including ISVs) can build
custom Java Controls – re-usable business logic components that seamlessly plug into the
Workshop development environment. To create a custom Java Control, developers simply use
familiar visual designers to specify the interface (i.e. the methods and events supported), set
properties to dictate run-time behavior, and write the business logic using procedural Java code
to implement these methods.
The extensible nature of Java Controls makes them the ideal model for deploying service-
oriented architectures in which business logic components are created as independent modules
that can be used and re-used to service multiple types of end-user applications. The many
benefits of using Java Controls to promote this type of efficient, modular design for software
reuse include the following:
• Java Controls are able to describe themselves at design-time so that developers can gain a
visual representation of server-side business logic in the familiar Workshop development
environment.
• Java Controls expose a set of simple properties by which a user can implement advanced
run-time functionality such as asynchronous communication, security roles, lifecycle events,
transaction support, etc. Authors of custom controls have the freedom to populate the
Properties sheet for the benefit of the controls’ downstream users.
• Java Controls are easily packaged and distributable as standard JAR files. Moreover Java
Controls are nestable so it is easy for them to become the component of re-use.
• Java Controls enable connectivity to any IT asset, ISV application, or piece of business logic
while preserving the developer’s abstraction from the majority of the infrastructure complexity.
This means developers can largely focus on procedural Java instead of J2EE or other
vendor-specific APIs.
As a result, Java Controls are a compelling way to encapsulate business logic in reusable
components that become the central building blocks for all WebLogic Platform applications.
The visual development environment, run-time framework, and Java Controls together enable
BEA WebLogic Workshop’s simplified programming model. Importantly, this innovative
development approach is unified such that developers need only learn a single programming
model to build and integrate the full suite of WebLogic Platform applications including Web
services, Web applications, portals, and integration applications.
The JumpStart exercises require that you install both WebLogic Workshop 8.1 beta and the
JumpStart Kit. You will need:
• BEA WebLogic Workshop 8.1 beta – You can install the program from CD or download at:
http://commerce.bea.com/showproduct.jsp?family=WLW&major=8.1&minor=-1
• JumpStart Kit (BEA_WebLogicWorkshop81_JumpStartKit.zip) – Includes this guide as well
as project files required for the JumpStart Exercises. This zip file can be downloaded from
the BEA WebLogic Workshop website at:
http://www.bea.com/framework.jsp?CNT=step_2.htm&FP=/content/new_releases/products/w
orkshop/get_started/
Once you have these files, the process of installing BEA WebLogic Workshop 8.1 and preparing
for the JumpStart Exercises consists of the following steps:
• Double-click on platform810_win32.exe. This starts the BEA WebLogic Platform 8.1
installation program and will install BEA WebLogic Workshop 8.1™.
• Click Next to progress past the Welcome screen
• Read and accept the License Agreement, and select Next to continue
• Select Next while leaving the default choice of c:\bea as your BEA Home Directory
• Select the default selection for “Typical Installation” and click Next
• Select Next while leaving the default choice of C:\bea\weblogic81b as the Product Directory
• Select Next to begin the installation process, which will take approximately 15 minutes
• On the Installation Complete dialog box, clear the checkboxes at the bottom of the screen (no
need to install XMLSpy or use the configuration wizard at this time) and click Done
This example involves a fictitious company named Avitek, a major consumer electronics firm.
Avitek has a proprietary, home-grown order management system. Today, only a limited number
of authorized distributors are able to electronically submit product orders to Avitek, with all other
forms of order entry being done manually. Avitek maintains a number of databases and back-
end computing resources that are an integral component of the firm’s operations. Any initiative to
extend the current order management system would be required to leverage the existing IT
infrastructure which has been developed piece-meal over the last twenty years. This need for
application integration had rendered prior attempts at modernization too complex and certainly
too expensive.
Recently, many of Avitek’s major competitors have introduced additional channels of distribution.
To remain competitive in its industry, Avitek must respond by increasing its channel offerings as
well. First, Avitek wants to offer all electronics distributors the opportunity to easily connect with
Avitek’s Order Entry System via standards-based Web services. Second, Avitek desires to
capitalize on the growing demand for e-commerce by offering a hosted Web application that
allows end-users to purchase certain items on-line directly from Avitek. To be successful, Avitek
must ensure that these applications have the following features:
• Standards-based to ensure interoperability with the largest number of distributors
• Flexible to allow changes to the system and the information exchanged between
partners over time
• Integrates with existing data, systems, applications, and business logic required for
executing order management processes
• Designed to accommodate the latency and service disruptions associated with dealing
with legacy systems and external data sources
• Reliable, available, and scalable to meet the demands of its expanding user base and
maintain their industry reputation for quality.
Because Avitek needs to move quickly to build and extend its new Order Entry System, and
many of their key J2EE architects are already busy maintaining the core infrastructure, Avitek is
planning to rely on its existing staff of application developers to build this new system. Since
many of these developers may not be experts in J2EE, the chosen technology platform will need
to be accessible by these developers, but at the same time support the rock-solid reliability,
availability, and scalability that Avitek’s partners and customers demand.
To meet these requirements, Avitek has decided to use BEA WebLogic Workshop 8.1 to help
solve the pressing business problem at hand, and improve the project’s time-to-value. A diagram
of the planned Avitek Order Entry System is provided below in Figure 5.
Web-based
Customers
This JumpStart Guide will take you through the steps of building an enterprise-class Order Entry
System that will increase Avitek’s business efficiency, customer responsiveness, and market
presence.
In the first exercise, you will become familiar with the Workshop development environment and
set-up the application workspace for the subsequent exercises.
In the second exercise, you will create a custom Java Control that asynchronously integrates with
both the Avitek Customer Database and the Avitek Order Database and also implements the
necessary business logic to perform order management functions.
In the third exercise, you will leverage the custom control you built to create an asynchronous,
secure, and loosely-coupled enterprise-class Web service that empowers Avitek to instantly
expose advanced Order Entry functionality to thousands of potential business partners.
In the fourth exercise, you will again leverage the custom control, but this time to build, test, and
deploy a Web application with dynamic JSP/HTML user interface thereby enabling Avitek to
effectively reach the millions of potential customers who prefer to shop online.
For evaluators interested in further exploring features of BEA WebLogic Workshop, we have also
provided two bonus exercises that highlight additional product capabilities. Exercise 5
demonstrates the ability to quickly build “starter” Web applications from a Java Control – in this
case an application to administer the Avitek Order Database. Exercise 6 demonstrates the
power of XMLBeans for elegantly handling XML data and documents in applications created
using BEA WebLogic Workshop 8.1.
Figure 6: Create a new Workshop application based on the provided Order Entry Demo template
Now is a good time to get acquainted with the WebLogic Workshop 8.1 visual development
environment, as shown in Figure 7. The environment hosts a number of visual designers
corresponding to the application type being created. If you have opened Admin.jws as instructed
above, you are seeing the JWS designer for working with a Web services application. In the
center of the screen is the Design View which provides developers with a graphical
representation of the Web service. The canvas displays the operations available to clients via
arrows on the left-side of the canvas, and Java Controls to interface with back-end resources and
business logic are shown via arrows on the right-side of the canvas. The Design View is
surrounded by a number of dockable and configurable windows to aid the developer’s progress.
For example, the Application Window provides easy access and viewing of resources contained
in the active application and the Property Editor enables the developer to quickly set properties
on the controls and methods.
The Avitek Order Entry System will require integrating with two databases: one for customers and
a second for orders. For the purposes of this demonstration, you need to ensure the database
tables are properly established. For your convenience, handy administrative methods to
configure the database resources are provided via the Admin.jws Web services application.
Figure 8. Use the toolbar to start the Admin.jws Web service application
If you have not already done so, you will be prompted to start the WebLogic Server, which
you should do now. Note that starting the WebLogic Server may take a few minutes to
complete. (Note: Do not shut down the “Starting WebLogic Server” window as this action
would shut down the server as it is starting up. You may however hide the window by
clicking the Hide button.)
Automated Deployment
After the Admin.jws application is built, it will be automatically deployed to the BEA WebLogic
Server 8.1 and the Workshop Test Browser will automatically appear. This is evidence of
WebLogic Workshop’s automated deployment and integrated testing features that you will have
an opportunity to explore in more detail in Exercise #3.
Create and load the sample databases using the Admin Web service. In the Workshop Test
Browser, invoke the Setup method by clicking on the Setup button as shown in Figure 9.
This method will create and load the Customers and Orders database tables with sample
data that you will use for the duration of the evaluation. The Setup method leverages Java
Controls for connecting with these two databases; you will learn more about Java Controls
in subsequent exercises as well.
o Note: If you are running this example for the second time and want to clean out old
test data, first select the Reset method, then perform the Setup function.
Figure 9. The Workshop Test Browser displays the convenient test client interface
To see a Java Control in action, let’s explore the Database Controls for Avitek resources that
were pre-defined in the Order Entry Demo template.
In the Application Window, navigate into the CRMSystem folder and double-click on the
CustomerDB.jcx file. This loads the Avitek Customer Database control in the Design View.
As shown in Figure 10, the CustomerDB control, like all Java Controls, is viewable via a visual
representation in the Design View that shows its methods and events on the left-side of the
canvas.
Figure 10. The CustomerDB Java Control depicted visually in the Design View
To better understand how the database control allows developers to easily leverage any SQL
database without knowing JDBC API commands, try the following:
Double-click on the arrow icon associated with the insertCustomerObject method. This
brings up a dialog box (shown in Figure 11) in which any developer can simply map SQL
parameters to the corresponding Java method definition. This is an example of how a
Java Control can hide the complexities of J2EE from the developer – most application
developers know SQL, but many do not know (or want to know) JDBC. Hit Cancel when
you are done exploring the SQL/Interface Editor.
The Database Control is one of the standard Java Controls that come pre-packaged with
WebLogic Workshop 8.1. Other built-in Java Controls provide easy access to major enterprise
resources such as EJB components, Web services, and JMS queues. All these controls are
consistent in their ease-of-use and ability to prevent developers from needing to write complex,
object-oriented J2EE infrastructure code to accomplish necessary integration objectives. You
can see the controls that are built-in to Workshop by clicking on the New button in the data
palette.
Beyond the built-in Java Controls, WebLogic Workshop 8.1 offers an extensible controls
architecture so that developers have the ability to create reusable components of business logic
that can integrate with any enterprise resource, ISV application, or piece of business logic.
Custom Java Controls can leverage built-in Java Controls and are themselves nestable and
easily reusable. Moreover, any Java Control can be incorporated in any and all projects
spanning across Web services, Web applications, and other WebLogic Platform applications.
To create a custom Java Control for the CRM System:
Close the CustomerDB control in the Design View. To get started with building a new
control, right-click on the CRMSystem project folder in the Application Window, and select
New → Java Control.
Figure 13. Drag-and-drop the Customer Database control to the CRMControl canvas
Similarly, drag-and-drop the OrdersDB.jcx item from the Application Window to the
CRMControl canvas.
With just these two simple drag-and-drop operations, you have already completed the process of
integrating your custom CRMControl with Avitek’s databases – without writing a line of code!
The Design View will reflect these additions as shown in Figure 14.
Figure 14. The Design View reflects database control additions to CRMControl
To provide the desired functionality for CRMControl, you need to provide access to three
methods of the Customer Database control: findAllCustomersArray, findCustomerByID,
and insertCustomerObject. Simply find the matching entries in the Data Palette (shown in
Figure 15) and drag each from the Data Palette on to the CRMControl in the Design View.
This provides a quick and easy mechanism to extend the existing functionality available in
the control. These methods can be later customized if additional business logic is required.
The CRMControl will be updated in the Design View as shown below in Figure 16:
In addition to the three pass-through methods, you need to add a new method that allows a client
of the custom CRMControl to submit a new order and do the appropriate processing with the
Customer and Order databases.
The createOrder method will need to accept information about an order and its associated
customer, proceed to create a new customer record in the Customer database if an appropriate
record does not already exist, and finally add the relevant order details into the Order database.
Implementing this desired business logic and integrating with Avitek’s databases will naturally
require some code:
From the Design View, click on the createOrder hyperlink to view this method in the Source
View.
Figure 18. Hyperlinks make it easy to switch from Design View to Source View
The Source View provides a convenient environment for writing the necessary Java code
directly to the source file. You need to add the following code for the createOrder method:
Note that the functionality required from CRMControl was easily written in a few lines of
procedural Java code and that communicating with the back-end databases was similar to
working with any local Java class; as shown here, the developer can always abstracted from the
low-level J2EE complexity to maximize developer productivity.
Asynchronous Controls
Because Avitek may need to process large volumes of orders simultaneously, you want to make
sure the CRMControl can capture all of these requests reliably, regardless of load. After all, if
Avitek loses order requests, they lose business! A good architectural approach in these
scenarios is to implement an asynchronous solution. For example, rather than having an
external client submit an order request and just wait indefinitely (and possibly unreliably) for order
processing to compete, the CRMControl places all incoming order requests on a reliable queue,
where it is guaranteed to remain until the CRMControl is ready to process the request.
Supporting asynchronous communication is an important component of building scalable and
reliable enterprise-class applications, however it has typically been a very arduous task due to
the need for complex programming and a required understanding of J2EE technologies such as
Message-Driven Beans (MDB) and JMS Queues. Fortunately BEA WebLogic Workshop 8.1
makes implementing asynchrony as simple as setting a property. To demonstrate, you will now
create a new method that will offer all clients asynchronous access to the custom CRMControl.
From the Design View, insert a new method by dragging the Method icon from the Palette
window onto the CRMControl in the Design View. This time, specify the name of the new
method as createOrderAsynch.
With the createOrderAsynch method active (click on the arrow icon associated with the
method if it is not already active), access the Property Editor and simply set the Message-
Buffer Enable property to True as shown in Figure 20.
You will notice that the Design View is automatically updated with a queue icon in front of
createOrderAsynch to indicate that this method will communicate in asynchronous mode.
Figure 21. The Design View adds a queue icon to reflect asynchronous mode
As a result, the createOrderAsynch method can not simply respond to the calling client as the
CreateOrder method did. Instead, you will create a Callback that will allow the CRMControl to
notify the client after createOrderAsynch has finished processing the submitted order.
To create a new callback, drag the Callback icon from the Palette window onto the
CRMControl in the Design View. Specify the name of the new callback as orderResponse.
Figure 22. Create a new Callback by dragging-and-dropping the appropriate icon from the Palette Window
As you did previously with the CreateOrder method, you will need to also provide the business
logic for the createOrderAsynch method.
Switch to the Source View by clicking on the createOrderAsynch hyperlink.
Fortunately the business logic required for createOrderAsynch mirrors the code already
provided for createOrder, so you just need to modify the following two lines of code:
Figure 23. The automatic syntax checker provides real-time alerts to source code errors
Workshop’s in-line syntax checking and notification makes it easy for developers to fix mistakes
while they are coding in the same context rather than waiting until compile-time. The reason for
this particular error is that your invocation of the orderResponse callback doesn’t match the
declaration that was automatically created by Workshop when you added the orderResponse
operation in the Design View.
To make this simple fix, scroll down in the Source View to the orderResponse declaration,
and add a parameter named message of type String. When you are done the declaration
will look like this:
As you might expect, you will now see a graphical depiction of the orderEntryService application
in the Design View, which for now is just an empty canvas. Generally, if you wished to
incorporate any built-in Java Controls in a Web service application, you could just select the
appropriate control option from the Control Palette. Thanks to your work in the previous exercise,
you will only need to leverage the custom CRMControl in this orderEntryService Web service.
To leverage the CRMControl, select its icon from the Application Window and drag it on to
the orderEntryService canvas in the Design View.
Figure 26. To add access to CRMControl, simply drag its icon on to the orderEntryService.jws canvas
Figure 27. The Design View shows CRMControl as a back-end resource in orderEntryService.jws
Next, you need to create methods which will be invokable by clients of this Web service
application. Once again, this is made very easy for you because BEA WebLogic Workshop 8.1
automatically generates “pass-through” methods for accessing the CRMControl.
To add the desired methods, simply drag the createOrderAsynch and orderResponse
entries from the Data Palette to the orderEntryService canvas. These pass-through
methods allow for convenient exposure of the CRMControl methods via this Web service
application.
Figure 28. The createOrderAsynch and orderResponse operations are exposed to clients
With the client-facing methods and back-end resources in place, now is a good opportunity to
explore additional features in WebLogic Workshop 8.1 that help to build enterprise-class Web
services. For example, asynchrony, loose coupling, strong message-level security, and reliable
“once and only once” messaging are all very important features for building reliable and scalable
Web services that help customers solve real business problems. Not surprisingly, Avitek would
want to take advantage of some of these advanced architectural features.
In the real world, most Web services applications cannot immediately return a response. They
may need to access a legacy system, contact a third party, or involve a human user. These
operations are asynchronous in nature, so it is important to make support for asynchronous Web
services as easy as possible. With BEA WebLogic Workshop 8.1, making the orderEntryService
asynchronous is as simple as setting a few properties:
With the createOrderAsynch method active in the Design View (if necessary, activate it by
clicking on the arrow icon for the method), access the Property Editor to see the various
customizations available. Set the Message Buffer Enable property to True. This will result
in a queue icon being added to the method’s visual representation.
Figure 29. Use the Property Editor to declaratively specify complex application functionality
As you already saw in the previous exercise, enabling the message-buffer property will cause for
a JMS queue and the associated messaging infrastructure to be implemented at run-time. Note
that in this case, the queue is established between the orderEntryService application and its
clients, whereas in the previous exercise, the CRMControl implemented an asynchronous
method for interaction between the CRMControl and its clients, which in this case is the
orderEntryService application. As a result, there are effectively two levels of asynchrony for
optimal application scalability and efficiency.
With the createOrderAsynch method still active, locate the Conversation section in the
Property Editor, and set the phase to Start. This setting will be reflected with a green
triangle added to the method’s visual representation.
Finally, click on the orderResponse callback in the Design View, and change its
Conversation phase to Finish. This setting will be reflected with a red square added to the
callback’s visual representation.
Figure 30. Use WebLogic Workshop’s conversation metaphor to manage asynchronous communications
These conversation settings are based on Workshop’s conversation metaphor for asynchronous
communications. These settings help the application keep track of messages flowing back and
forth and make sure that all the messages that are part of the same conversation go to the right
place (i.e. the calling client). Moreover, conversations will automatically store any state
associated with the conversation in a robust reliable way (using entity EJBs) – developers simply
need to declare variables in a JWS class to take advantage of this capability. By establishing the
Figure 31. The Source View is synchronized for seamless two-way editing
Notice the source code annotations that are located above the method’s declaration, within the
JavaDoc annotations. It is these code annotation that get interpreted by the Workshop run-time
framework at deployment-time; WebLogic Workshop then automatically enables this functionality
in the resulting application by implementing standard J2EE components. This remarkable
capability, coupled with the event-based visual design environment, is what makes it easy for all
developers, not just J2EE experts, to work productively on the WebLogic Enterprise Platform.
It should be noted that WebLogic Workshop does not generate code – the developer never needs
to understand or debug code they have not written. Instead, properties and their resulting
annotations declare functionality that is supported by the run-time framework in a container
approach.
In just these few steps, you have now created a powerful Web service application that Avitek can
immediately deploy to the universe of distributors to enable automated ordering over existing
Internet infrastructure. Note that the innovative WebLogic Workshop programming model and
run-time framework abstracted you from the minutiae of SOAP marshalling, Java-XML mapping,
bean deployment, WSDL file creation, and much more. In this manner, developers are free to
focus on handling events and writing business logic, making them dramatically more productive.
Figure 32. WebLogic Workshop 8.1 generates a test client to quickly test any application
The Overview screen in the Workshop Test Browser automatically provides a basic description of
the Web service and the methods it exposes. It also allows clients to easily download a WSDL
file, source code for a Java Control to access the orderEntryService application, or Java proxy
code to use in any Java environment for building a client for this Web service. Moreover, clicking
on the Console tab will enable the developer to see what types of services and components this
Web service is accessing.
To test the orderEntryService application, select the Test XML tab.
The Workshop Test Browser provides a free-text box that is pre-loaded with the skeleton
structure of the XML message that the orderEntryService expects as incoming order information.
You can either manually type in values into the Workshop Test Browser, or more
conveniently, paste in the sample order information provided for you in the JavaOrder.xml
file. You can locate this file in the Application Window project tree. Click the
createOrderAsynch button.
Figure 33. Submit a sample order for a customer named Bob Smith
Figure 34. The Workshop Test Browser helps track all the messages used in testing the Web service
Recall that the createOrderAsynch method you are testing is asynchronous, and accordingly, it
starts a conversation, as indicated at design-time. Not surprisingly, the Message Log shows that
a new conversation has automatically been started. BEA WebLogic Workshop will automatically
track all related messages under the corresponding Conversation ID, which is visible in your
Message Log as well as in the SOAP headers of the messages being sent.
Hit the Refresh link in the Workshop Test Browser to view any subsequent messages that
have been exchanged between the test client and your Web service during this
asynchronous conversation. Soon, you will see the order confirmation appear from the
orderResponse client callback, as shown in Figure 35.
After confirming the order is acknowledged in the test client, close the Workshop Test
Browser and return to the WebLogic Workshop visual development environment.
Another important feature of BEA’s architecture for enterprise-class Web services is loose
coupling. Loosely-coupled applications are flexible and can accommodate change over time,
which is especially important when Web services are used to integrate different applications that
are normally built by different teams using different technologies and platforms. The key to
loose-coupling is to enable a separation between a Web service’s public contract and it’s private
implementation. Since Web services communicate using XML-based documents and WebLogic
Workshop application development is done in Java, it is critical to provide easy, intelligent and
flexible mapping between XML and Java to ensure true loose-coupling.
To help with loose coupling, BEA WebLogic Workshop 8.1 provides deep support for XML
Schema and XQuery, state-of-the-art technologies for working with XML in Java. In the next few
steps, you will incorporate a schema definition that provides the structure and constraints on the
Purchase Order messages that business partners will use to submit automated orders to Avitek.
You will also gain exposure to XQuery technology, which is sometimes referred to as “SQL for
XML” because it provides a robust mechanism to access data directly from XML documents,
much like SQL provides a mechanism for accessing data in traditional databases. Fortunately,
BEA WebLogic Workshop handles for you the complex work of writing custom XQuery
expressions.
You need to first import the appropriate schema file into the AvitekDemo application. In the
Applications Window, right-click on the Schemas folder, and choose Import. Browse to the
purchase-order.xsd file that you previously saved in the c:\workshop81demo folder, and
click Import.
Figure 36. Import the XML Schema Definition (XSD) file to use in XQuery mapping
BEA WebLogic Workshop automatically compiles and interprets the provided schema file to learn
the structure of messages expected for the orderEntryService application. (You can see the
results of this compilation in the Build pane underneath the Design View.)
Next, you will need to provide the “mapping” of the data fields in the incoming XML message to
elements in the Java data structures that will be used to hold the data for the application to
process.
From the Design View of orderEntryService.jws, click on the createOrderAsynch method’s
arrow icon to make this method active.
Scroll down in the Property Editor until you see the XQuery property under the Parameter-
XML heading. Click on the … button to launch the XQuery Editor as shown in Figure 37.
In the left-side pane of the XQuery Editor, expand the tree structure to locate the
createOrderAsynch schema entry as shown in Figure 38. You need to specify this
definition as the “source schema” so highlight it and click Create.
Next appears a visual mapping tool to visually map fields from the source schema (based on the
chosen schema definition) to the target schema (the parameters defined by the
createOrderAsynch method declaration which are the Customer and Order data structures).
Mapping fields between the two schema is as simple as drawing lines connecting source fields to
target fields:
Connect customer-number first to c.custId and then to o.custID
Connect firstname to c.name and lastname also to c.name
Connect address, city, state, zip, and phone fields to the matching fields in the c data
structure
BEA WebLogic Workshop 8.1 (beta)™ JumpStart Guide Page 36 of 64
Connect order-number to o.orderID
Connect tv-order:quantity to o.flatScreenQty
Connect camera-order:quantity to cameraQty
When you are finished with these mappings, the XQuery Mapper screen should appear as shown
in Figure 39.
Figure 39. WebLogic Workshop enables visual mapping between Source (XML) and Target (Java)
You can use the visual tool for speed as shown above, or directly access the XQuery source
code by clicking on the XQuery tab. Each of the visual mapping actions is translated into the
matching XQuery expression.
Select the XQuery tab at the top of the XQuery Mapper window to view the mapping in its
native XQuery format. For aesthetic completeness, insert some whitespace into the name
mapping by specifying a space (“ “) between the first name and last name. The modified
line should read as follows:
<ns1:name>{concat($input/ns0:purchase-
order/ns0:customer/ns0:firstname," ",$input/ns0:purchase-
order/ns0:customer/ns0:lastname)}</ns1:name>
Click OK in the XQuery Mapper tool, and OK in the XQuery Editor to return to the Design
View.
With these additions for ensuring a loosely-coupled Web service, you can now test your revised
orderEntryService Web service application:
As before, uses the menus to select Debug Start, or hit the Start icon on the menu bar.
Click on the Test XML tab. Notice that the XML skeleton provided now is slightly different
from last time. This is because the orderEntryService application is now expecting an XML
message that conforms to the createOrderAsynch schema definition you specified.
For convenience, an XML message conforming to the expected schema has been provided
in the PurchaseOrderMessage.xml file, accessible in the Application Window. Paste the full
contents of this XML message into the SOAP body field of the test client and click
CreateOrderAsynch.
After invoking the asynchronous method, you will need to click the Refresh link in the
Workshop Test Browser to collect subsequent messages in the conversation. Soon, you
should receive the client callback in the Message Log which confirms the order.
Figure 42. The order for John Doe is acknowledged by the orderEntryService application
Congratulations! You just built, deployed, and tested an enterprise-class Web service in a
matter of minutes using BEA WebLogic Workshop 8.1!
The key requirement for using BEA WebLogic Workshop to build server-side applications with
dynamic JSP/HTML user interfaces is understanding a new Java innovation introduced with
WebLogic Workshop 8.1 – Java Page Flow. A Java Page Flow is simply a set of related
JavaServer Pages and a companion Java controller class. A JavaServer Page (JSP) gives you a
convenient way to present dynamically generated content via a web browser. JSPs are able to
provide dynamic content because they are not purely HTML; instead, JSP pages include Java
code that provides the dynamic content. And the Java controller class (denoted by a file’s .JPF
suffix) provides the navigational and behavioral control that spans across the related JSP pages.
These components work together to help build enterprise-class, standards-based Web
applications.
Figure 43. The Flow View provides a visual depiction of the Web application
You should see in front of you the Controller.jpf file being displayed via the default Flow View.
The Controller.jpf file is the Java class that contains the business logic for the Web application
Get
Start Submit Finish
Customer
Order Order Order
Status
Existing Specify
Which
Customer
To create this Web application, you will benefit from the ability to re-use the CRMControl you
built-in Exercise #2 to handle interfacing with Avitek’s databases. Moreover, several components
of the Web application have been pre-defined for you. In fact, the Flow View of the Controller.jpf
provides a visual depiction of the pre-defined pages and actions, and should resemble the
diagram in Figure 44.
To complete the Order Entry Web application, you will need to add some missing actions and
provide the necessary business logic therein. In particular, notice in the Flow View the missing
links between the WizOne.jsp icon and the WizTwoNew.jsp/WizTwoExisting.jsp icons.
Figure 45. Notice the gaps remaining in the Java Page Flow application
Based on the user response provided by the radio button selection, the Web application needs to
process some business logic and determine in which path the user should be taken. This
functionality will be implemented in WizOneAction, which is a method in Controller.jpf that gets
automatically invoked after the user submits a response in the WizOne.jsp page.
Locate the WizOneAction icon in the Flow View, it is adjacent to the WizOne.jsp icon and
should appear fainter than the other icons. To instantiate this action, right-click on the
WizOneAction icon and choose Create.
Figure 47. Activate the WizOneAction element using convenient pop-up menu commands
The next step is to define the Form Bean associated with WizOneAction. A Form Bean is the
mechanism that communicates data between a page (i.e. WizOne.jsp) and its associated Action
(i.e. WizOneAction). Since the WizOne.jsp page allows a user to identify oneself as a “new” or
“existing” customer, you need the Form Bean associated with WizOneAction to hold this piece of
information.
Right-click on the WizOneAction icon, and select Generate Form Bean. This automatically
brings up the Form Bean Editor.
Figure 48. Add a String field to the Form Bean to capture the user’s status
The Form Bean is now complete and will convey the customerType value to WizOneAction.
Depending on the value (i.e. new or existing customer), WizOneAction will determine which page
a particular user is taken to next. Accordingly, you need to visually connect the newly created
WizOneAction with the subsequent pages in the application flow.
Draw a link between WizOneAction and WizTwoNew.jsp. This is done by simply clicking
just to the right of the WizOneAction icon (the mouse pointer should change to have a link
underneath the arrow as shown in Figure 49) and drag a link (keep the mouse button
depressed) towards WizTwoNew.jsp. Change the link’s label (in the yellow box) to new.
Figure 49. Visually drag links to connect pages in the Flow View
Similarly, drag a link from WizOneAction to WizTwoExisting.jsp, and label its link as
existing.
Figure 50. The Flow View displays the specified navigational logic
With Web applications in WebLogic Workshop 8.1, you can also take advantage of the
Action View by clicking on the corresponding tab near the bottom of the canvas.
Figure 51. The Action View displays the methods and resources in Controller.jpf
The Action View should look very familiar to the Design View you experienced while building the
custom control and the Web service: there are methods on the left-side and resources on the
right-side. With a Web application, the methods represent the Actions that are defined to control
the application’s behavior. Clicking on any Action’s name will take you to the synchronized code
in the Source View:
From the Action View, click on the WizOneAction hyperlink to switch over to the Source
View and view the underlying Java code for this Action.
Figure 52. The code annotations are color-coded for enhanced visibility
Within the WizOneAction method, you need to replace the single line of default code with
the following lines to determine the type of user being handled and then execute the
appropriate section of the if/else logic branch. When you are finished, the method will
appear as follows:
/**
* @jpf:action
* @jpf:forward name="existing" path="WizTwoExisting.jsp"
* @jpf:forward name="new" path="WizTwoNew.jsp"
*/
Automated Data-Binding
WizOneAction is now complete. You are almost ready to test the Web application, however there
is one more important task remaining:
Return to the Flow View of Controller.jpf, locate the WizTwoNew.jsp file, and double-click
on it to open it.
You will now see the WizTwoNew.jsp loaded in WebLogic Workshop’s JSP editor. The editor
enables developers to create complex JSP forms using tags and properties, and supports a
Design View that provides drag-and-drop, WYSIWYG functionality. As provided to you, the
WizTwoNew page is nearly empty, so you need to make the necessary additions to the page so
that it can collect information from a new customer; this data will then need to be stored in
Avitek’s databases. Fortunately, WebLogic Workshop makes this easy with drag-and-drop data-
bound forms that can automatically connect user interface elements with back-end resources:
Locate the WizTwoAction icon in the Data Palette and drag it on to the WizTwoNew page in
the Design View.
Figure 54. Select the appropriate fields to include on the form using the Form Wizard
Figure 55. Adjust the fields to the desired position for the form
The JSP editor will update the WizTwoNew.jsp page to display the fields you just added, as
shown in Figure 56.
Figure 56. WebLogic Workshop 8.1 provides a JSP editor with WYSIWYG functionality
This completes the development required for the Avitek Order Entry System Web application so
now you can test the application. Once again, you can take advantage of WebLogic Workshop’s
automated deployment and integrated test harness that makes iterative development a breeze:
Save and close the WizTwoNew.jsp file and return to the Controller.jpf file. Click the Start
icon (or Debug Start without Debugging) to automatically deploy the Order Entry Web
application and bring up the Workshop Test Browser. Note that, as with any Web
application, loading the first view of a JavaServer Page (JSP) takes longer than all future
views because the presentation code is being compiled on the first pass.
From the starting page in the Workshop Test Browser, click Start Entering An Order! to
begin the Avitek Order Entry System.
Figure 57. The entry-page for the Avitek Order Entry System
Figure 58. The application uses simple UI elements to collect information on the customer’s status
Thanks to the business logic you entered in the WizOneAction method, you will be properly
navigated towards the “new customer” path and will have a chance to enter in your
information. Here you will see the data-bound form that you created on the WizTwoNew
page. Fill in the fields as indicated in Figure 59 and click the WizTwoAction button.
Figure 59. The form collects the relevant information for the new customer in this example
Figure 60. The application now collects the appropriate order information
It is that simple for any new customer to come to Avitek’s web-site and start making orders for
televisions and digital cameras! Just to make sure that the customer’s information was handled
properly, let’s walk through the Order Entry System one more time:
Figure 61. The application confirms the initial order, and allows the user to start another order
This takes you back to the starting page. Click on Start Entering An Order! as before.
You will now see a list of all the customers that are currently in the Avitek Customer
database. You should see a line item for “Billy Bob” (or other name) you added in the
previous steps. Also note that you will see entries for Bob Smith and John Doe, which
correspond to the orders in JavaOrder.xml and PurchaseOrderMessage.xml, respectively,
that were submitted in Exercise #3.
Figure 63. The application displays all the records in the Customer Database
Congratulations – the Order Entry System Web application is complete! BEA WebLogic
Workshop 8.1 makes user-interface development easy because all you needed to do was specify
logic, navigation, and data – the WebLogic Workshop 8.1 run-time framework handles all the low-
level details and helps to boost your productivity.
The following step allows you to specify if this new Page Flow is to be built from scratch or
if it is to be based on a Java Control. You will want to use a Database Control (that still
needs to be defined) so select the Database Control radio box and click the New button to
launch the Database Control Wizard.
Provide OrdersAdminDB as the Name and leave the default Data Source
cgSampleDataSource to indicate that you will create a new table in the database that is
embedded with WebLogic Platform. Click Next.
Figure 65. Use the Database Control Wizard to create and configure the new control
Figure 66. Specify the CAJUN schema and the ORDERS table as the data of interest
The next step in the Database Control Wizard lets you see the available columns in the
Orders table. These default settings are correct so just select Next.
You would like the new primary keys to be automatically generated by the database (the
default selection) so just click Create to complete the Database Control Wizard.
This returns you to the original Page Flow Wizard dialog box. But now that you have
successfully created the Database Control upon which the new Web application will be
based, you can specify the OrdersAdminDB as the Database Control and click Next.
Figure 67. Return to the Page Flow Wizard, and select OrdersAdminDB as the basis for the new Page Flow
Figure 68. Customize the actions permitted in the new Page Flow application
You will now see the new orderAdminController Page Flow appear in the Flow View:
Figure 69. WebLogic Workshop 8.1 automatically defines the appropriate pages, flows, and actions required
To see the new Web application in action, click the Start icon to deploy the application and
invoke the integrated test harness. The first screen to appear will display all the records
currently in the Orders database as shown in Figure 70.
Figure 70. The Grid View displays all the order records in the Avitek Orders database
If you select the Edit link on a particular record, you are taken to the Edit View and have
the ability to modify or delete a record.
Figure 71. The application provides administrators the ability to easily edit or delete existing order records
Congratulations! You have built a full-fledged Web application with core functionality
from an underlying, standard database table in only a few minutes!
Figure 72. Use the Property Editor to re-launch the XQuery Mapping Editor
Next, click Delete to remove the existing transformation you created in Exercise #3. Click
OK to return to the Design View.
To incorporate XMLBeans in the createOrderAsynch method, just click on its hyperlinked
name to switch to the Source View.
Figure 73. Click on the hyperlinked method name to switch to Source View
Figure 74. WebLogic Workshop 8.1 includes a convenient Auto-Import feature in the Source View
Insert the following lines of code to use XMLBeans to extract the necessary pieces of
information from the underlying XML to fill-in the important fields of the Customer and Order
data structures. When finished, the method should appear as follows:
/**
* @common:operation
* @common:message-buffer enable="true"
* @jws:conversation phase="start"
*/
public void createOrderAsynch(PurchaseOrderDocument podoc)
{
Customer c = new Customer();
Order o = new Order();
PurchaseOrder po = podoc.getPurchaseOrder();
c.name = po.getCustomer().getFirstname() + " " +
po.getCustomer().getLastname();
c.custId =
po.getCustomer().getCustomerNumber().intValue();
BEA WebLogic Workshop 8.1 (beta)™ JumpStart Guide Page 58 of 64
o.custID = c.custId;
o.orderID =
po.getOrderData().getOrderNumber().intValue();
o.cameraQty =
po.getOrderData().getCameraOrder().getQuantity();
o.flatScreenQty =
po.getOrderData().getTvOrder().getQuantity();
cRMControl.createOrderAsynch(c,o);
}
While typing the lines above, you will likely get Auto-Import messages and you may need to
specify for Workshop to import CRMSystem.Customer and CRMSystem.Order.
Figure 75. The test client tracks the asynchronous conversation and shows the order acknowledgement
As you can see, WebLogic Workshop 8.1 makes it easy to use XMLBeans to manipulate the
XML. While this scenario only demonstrated extracting data from the underlying XML document
using the Java interfaces, you could just as easily have traversed the raw XML using a Cursor
API, or have used the suite of “setter” functions to extend or modify the XML message.
Importantly, Workshop automatically ensures that any changes to the XML document is in
compliance with the submitted schema that defines the expected structure. This preservation of
XML fidelity combined with its ease-of-use is the key benefit of using XMLBeans to create
loosely-coupled applications.
To help determine whether XQuery mapping or the XMLBeans approach is correct for your
application, an important consideration is the nature of processing: end-point or way-point. In
BEA WebLogic Workshop 8.1 (beta)™ JumpStart Guide Page 59 of 64
end-point processing, the program is an end point for the XML. Its job is either to extract from the
XML the information it needs to do its job or else to create an XML document from scratch. The
application can do complex procedural things with the document, and it is acceptable for the
application to discard information in the incoming XML document that it does not need. On the
other hand, in way-point processing, the program acts on an XML document as that document
flows through a process. In this case the program shouldn't be "lossy," since it doesn't know
what functions precede or follow it in the business process. In these cases, preservation of the
full XML fidelity is critical. As you might guess, it is these way-point applications that are
particularly well-suited to XMLBeans whereas end-point applications may only require XQuery
mapping. Often both are acceptable alternatives and the issue becomes one of developer
choice.
Congratulations! You have now completed all the exercises in the JumpStart Guide.
Application Server:
BEA WebLogic Workshop 8.1 Application Developer Edition requires BEA WebLogic Server 8.1
BEA WebLogic Workshop 8.1 Platform Edition also requires BEA WebLogic Portal 8.1 and/or BEA
WebLogic Integration 8.1
BEA Systems,Inc.
23 1 5 N orth First Stre et
Sa n Jo s e, CA 95 1 3 1 U.S.A.
T elep h o ne: + 1.4 08. 57 0.8 0 0 0
F ac simile: +1. 40 8.5 7 0.8 9 01
www. be a.c o m