Create a Web service from an enterprise bean (EJB)
Prerequisites:
- Create an Enterprise Application project.
- Create an EJB project.
- Create or import an enterprise bean into your EJB project.
- Deploy your enterprise bean.
- Create a Web project:
- If you are using the Apache Jakarta Tomcat servlet container as your server, install it, configure an instance of it, and create a Web project targeted to it.
- If you are using a WebSphere server, create a dynamic Web project targeted to the appropriate server.
Start the server before running the Web service wizard since it may take several minutes to start the WebSphere Application Server depending on the speed of your computer. To start the server, select it in the Servers view...
Window | Show View | Servers | Start
The Web Service wizard assists you in creating a new Web service, configuring it for deployment, and deploying the Web service to a server. Once your Web service is deployed, the wizard assists you in generating the client proxy and sample application to test the Web service. When you have completed testing, you can publish your Web service to a UDDI Business Registry using the Export wizard.
For more information on EJB application development, refer to EJB tools.
Note: Rational Developer products support enterprise bean Web service creation from stateless session enterprise beans.
The Web service you are creating acts as a client to the enterprise bean. The enterprise bean must be deployed before launching the Web service wizard.
To create a Web service from an enterprise bean:
- Switch to the J2EE perspective (Window > Open Perspective > J2EE).
- In the Project Explorer view, select the Web project in which you want to create the Web service.
Alternatively, you can launch the Web Service wizard from the J2EE perspective by selecting the enterprise bean from which you will create your Web service and following the remaining steps.
- Click File > New > Other. Select Web Services in order to display the various Web service wizards. Select the Web Service wizard. Click Next.
- Web Services page: select EJB Web service from the Web service type drop down list. You can optionally choose to do the following:
- Start the Web service in a Web project - if you do not select this option you will have to manually start the Web service. You must select this option to enable the other options on this page.
- Launch the Web Services Explorer to publish your Web service to a UDDI registry.
- Generate a Java bean client proxy to the Web service. The Java bean client proxy that is generated provides a remote procedure call interface to the Web service.
- Test the Web service - this allows you to test the Web service in the Web Service Explorer before a proxy is generated.
- Send the Web service traffic through the TCP/IP Monitor, which allows you to watch the SOAP traffic generated by the Web service and to test this traffic for WS-I compliance.
- Service Deployment Configuration page: specify the server and client deployment settings.
- Click Edit and select the IBM SOAP run-time environment and select the server on which you want to run your Web service and Web service client. If you want to use the IBM WebSphere run-time environment or the Apache Axis 1.0 run-time environment, refer to the appropriate task.
- Select the EJB project, router project, and EAR for your Web service. The wizard will create these for you if they do not already exist.
- Select the type and name of project in which you want the Web service client created. If you enter the name of an existing project, the project type field must match that of the existing project. If you enter a name of a project that does not already exist, the wizard will create the project for you. Note that the only project type supported for Axis and SOAP run-time clients is a Web project. If you want the client to be created in a Java, EJB, or Application Client project, select the WebSphere run-time environment for your client.
- Select an existing EAR or enter a unique name to associate the Web service client with a different EAR than the Web service EAR. Note: Selecting different EARs for the Web service and Web service client can reduce the chance of encountering run time errors, but will use more system resources.
- Web Service EJB Configuration panel: click Browse EJB Beans. This allows you to browse the J2EE perspective for an enterprise bean.
- In the Browse Enterprise Beans dialog box select the Enterprise Application project that contains your enterprise bean and the EJB project. Then select your enterprise bean and EJB project. Click OK. The EJB configuration, such as JNDI provider URL, JNDI initial context factory, EJB JNDI name, EJB home interface class name, and EJB remote interface path name is automatically completed. Click Next.
Note: The Browse Enterprise Beans dialog box displays only the Enterprise Application projects that contain the selected Web project. The dialog can only be used to select those enterprise beans and EJB Projects that are contained in the same Enterprise Application project as the Web project.
- Web Service Java Bean Identity panel: specify the Web service URI, and the scope. You can optionally select to use static methods and secure SOAP. You can modify the document and folder names listed on this page, or accept the default names.
- Web Service Java Bean Methods panel: select the methods to expose and select the input and output encoding styles. If you want to review the the Java to XML mappings, select Show Server Type Mappings.
- Web Service Java to XML Mappings page: if you have chosen to review the mappings, you can see them here. Alternately, customize your mappings by selecting Edit and use a customized mapping.
- Web Service Test page: If you selected to test the Web service, select the test facility for the generated Web service, and click Launch. This will open the Web service in the Web Services Explorer. Select the operation you want to test, enter the required information, and click Go. The result will display in the Status pane. When you have tested the Web service, close the browser window and click Next.
- Web Service Binding Proxy Generation panel: if you have selected to generate a proxy, select the binding and proxy options.
- Web Service Client Test page: Use this page to select the following options:
- Select your test facility. You can test the generated proxy in the Universal Test Client or the Web Service Explorer, or you can generate a sample Web service JSP.
- If you selected to test the proxy through a JSP, you can select the folder where the JSP will be located, and you can select the methods that will be included in the JSP.
- Select Run test on server to start the server for you automatically.
- Web Service Publication page: Select whether or not you want to publish this Web service to a UDDI registry. Click Finish.
After the Web service has been created, the following may occur depending on the options you selected:
- If you have selected to test the generated proxy using Web service JSPs, the proxy is launched in a Web browser at the following URL: http://localhost: port/WebProjectClient/sampleBeanName/ WebService/TestClient.jsp You can use this sample application to test the Web service by selecting a method, entering a value for the method, and clicking Invoke. The result of the method will display in the results pane.
- If you have selected to test the generated proxy using the Universal Test Client, it will be launched in a browser window at the following URL: http://localhost:9080/UTC/preload?object=proxy.soap. ProxyNameProxy In the Reference pane, under Object References, expand the proxy to display the methods of the Web service. Click the method you want to test, enter a value in the Parameters pane, and click Invoke. The result will be generated below.
- If you have selected to test the Web service using the Web Services Explorer, the Explorer will open. Select the operation you want to test, enter the required information, and click Go. The result will display in the Status pane.
- If you have selected to publish the Web service, the Web Services Explorer is launched displaying the page required to publish your Web service to the IBM UDDI Test Registry. Follow the instructions in Publishing the Web service to complete this task.
Important: If your methods contain types, not supported by the sample, such as arrays, indexed properties, and collections, the methods will be omitted from the sample and you will receive a warning message.
Once you have created your Web service from an enterprise bean, you may test the methods of your Web service, using the Universal Test Client, and then publish your Web service to a UDDI Business Registry. For more information on testing and publishing your applications, refer to the Server tools documentation.
For more information on EJBs, refer to the EJB application development documentation.
Related Concepts
Tools for Web services development
Web services development
Web services run-time environments
Related Tasks
Developing Web services
Using the Web Services ExplorerRelated Reference
Deployment properties
Mapping properties
WSDL documents