blob: 6e3e117c1ea8143fc9e8259effba4af9a531e13f [file] [log] [blame]
//
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
//
= Creating and Running an Application Client on the GlassFish Server
:jbake-type: tutorial
:jbake-tags: tutorials
:jbake-status: published
:icons: font
:syntax: true
:source-highlighter: pygments
:toc: left
:toc-title:
:description: Creating and Running an Application Client on the GlassFish Server - Apache NetBeans
:keywords: Apache NetBeans, Tutorials, Creating and Running an Application Client on the GlassFish Server
This tutorial shows how to create a simple application client and access an Enterprise JavaBean (EJB) deployed to GlassFish server 3. In this tutorial you will first create an enterprise applications that contains a simple session bean and a Java class library project that contains a remote interface for the session bean. You will then create an application client that accesses the session bean through the remote interface in the class library. The class library JAR that contains the remote interface is added to the classpath of the enterprise application and the application client.
*Tutorial Exercises*
* <<Exercise_10,Creating the Java Class Library>>
* <<Exercise_20,Creating an EJB Module>>
* <<Exercise_22,Creating the Session Bean>>
* <<Exercise_23,Adding a Business Method>>
* <<Exercise_24,Deploying the Enterprise Application>>
* <<Exercise_30,Creating the Application Client>>
* <<Exercise_32,Adding the Class Library>>
* <<Exercise_30,Running the Application Client>>
*To follow this tutorial, you need the following software and resources.*
|===
|Software or Resource |Version Required
|link:https://netbeans.org/downloads/index.html[+NetBeans IDE+] |7.2, 7.3, 7.4, 8.0, Java EE version
|link:http://www.oracle.com/technetwork/java/javase/downloads/index.html[+Java Development Kit (JDK)+] |version 7 or 8
|GlassFish Server Open Source Edition |3.x, 4.x
|===
*Prerequisites*
This document assumes you have some basic knowledge of, or programming experience with, the following technologies:
* Java Programming
* NetBeans IDE
You can download link:https://netbeans.org/projects/samples/downloads/download/Samples/JavaEE/EntAppClientEE6.zip[+a zip archive of the finished project+]. If you are using GlassFish 3.0 use link:https://netbeans.org/projects/samples/downloads/download/NetBeans%20IDE%206.8/JavaEE/entappclient.zip[+the zip archive for the NetBeans IDE 6.8 project.+]
== Creating the Java Class Library
In this section you will create a Java Class Library project that will contain the remote interface for the EJB. The remote interface behaves as an API for the EJB that is used by clients to communicate with the EJB.
The library JAR is easy to distribute to any clients that may need to call the EJB. Clients that want to access the EJB only need to add the library JAR to the project classpath. The EJB implementation uses the same JAR to implement the interface.
1. Choose File > New Project (Ctrl-Shift-N; ⌘-Shift-N on Mac) and select Java Class Library in the Java category. Click Next.
2. Type *EJBRemoteInterface* for the Project Name. Click Finish.
image::images/appclient-newclasslibrary.png[title="New Class Library project wizard"]
When you click Finish, the IDE creates a Java Class Library project. In the next section you will create a Java EE enterprise application and an EJB module. You will then use a wizard to create a session bean and the remote interface for your session bean in the Class Library project. The application client will access the session bean via the interface in the class library.
== Creating an EJB Module
In this section you will create an enterprise application and an EJB module. When you create an EJB, the EJB should be created as part of an enterprise application and packaged as an EAR archive and deployed in to the server.
=== Creating the Enterprise Application
In this section you will use the New Project wizard to create an enterprise application containing an EJB module. The wizard provides an option to create an EJB module when you create the application.
1. Choose File > New Project and select Enterprise Application in the Java EE category. Click Next.
2. Type *EntAppEJB* for the Project Name. Click Next.
3. Select GlassFish Server for the Server.
4. Confirm that Create EJB Module is selected and deselect Create Web Application Module. Click Finish.
image::images/appclient-newentappejb.png[title="Create EJB Module is selected in the New Enterprise Application wizard"]
When you click Finish, the IDE creates an enterprise application and an EJB module. In the Projects window, you can see that the EJB Module project is listed under the Java EE Modules node of the enterprise application project.
image::images/appclient-projects-entappejb1.png[title="Projects window showing open projects"]
You can see that three types of projects are now listed in the Projects window: class library, enterprise application and EJB module.
=== Creating the Session Bean
In this exercise you will use a wizard to create a session bean in the EJB module project. In the wizard you will also create a remote interface for the session bean in the Class Library project.
1. Right-click the EJB module project and choose New > Session Bean.
2. Type *MySession* for the EJB Name.
3. Type *ejb* for the Package.
4. Select Stateless for the Session Type.
5. Select the Remote option for Create Interface.
6. Select the *EJBRemoteInterface* project from the dropdown list. Click Finish.
image::images/appclient-wizard-newsessionbean.png[title="New Session Bean wizard"]
When you click Finish, the IDE creates the session bean in the ``ejb`` package in the EJB module and opens the class in the editor. You can see that ``MySession`` implements the ``MySessionRemote`` interface and that the EJBRemoteInterface JAR was added as a library of the EJB module.
The wizard also creates a remote interface named ``MySessionRemote`` in the ``ejb`` package of the EJBRemoteInterface project. The IDE automatically adds the Java EE 6 API Library that is required for the EJB interface.
image::images/appclient-projects-entappejb2.png[title="Projects window showing the session bean and remote interface"]
=== Adding a Business Method
In this exercise you will create a simple business method in the session bean that returns a string.
1. Right-click in the editor of MySession and choose Insert Code (Alt-Insert; Ctrl-I on Mac) and select Add Business Method.
2. Type *getResult* for the Method Name and String for the Return Type. Click OK.
3. Make the following changes to modify the ``getResult`` method to return a String.
The class should look like the following.
[source,java]
----
@Stateless
public class MySession implements MySessionRemote {
public String getResult() {
return *"This is My Session Bean"*;
}
}
----
. Save your changes.
You now have an enterprise application with a simple EJB that is exposed through a remote interface. You also have an independent class library that contains the EJB interface that can be distributed to other developers. Developers can add the library to their projects if they want to communicate with the EJB that is exposed by the remote interface and do not need to have the sources for the EJB. When you modify the code for the EJB, you only need to distribute a JAR of the updated class library if any of the interfaces change.
When you use the Add Business Method dialog, the IDE automatically implements the method in the remote interface.
=== Deploying the Enterprise Application
You can now build and run the enterprise application. When you run the application, the IDE will deploy the EAR archive to the server.
1. Right-click the EntAppEJB enterprise application and choose Deploy.
When you click Deploy, the IDE builds the enterprise application and deploys the EAR archive to the server. If you look in the Files window you can see that the EJBRemoteInterface JAR is deployed with the application.
In the Services window, if you expand the Applications node of GlassFish Server you can see that EntAppEJB was deployed.
== Creating the Application Client
In this section you will create an enterprise application client. When creating the application client, the project needs the EJBRemoteInterface Java class library as a library in order to reference the EJB.
When you run the enterprise application, the IDE will package the application client and the Java class library JAR in the EAR archive. Library JARs must be packaged in an EAR with the application client if you want to access the JARs from the application client.
=== Creating the Enterprise Application
In this exercise you will use the New Project wizard to create an application client project. If you are deploying to GlassFish 3.1 or 4.x you can create and run an application client as a standalone project. The application client no longer needs to be deployed and run as part of an enterprise application.
NOTE: If you are deploying to GlassFish 3.0.1, you need to create the application client as a module in an enterprise application project and run the enterprise application.
1. Choose File > New Project and select Enterprise Application Client in the Java EE category. Click Next.
2. Type *EntAppClient* for the Project Name. Click Next.
3. Select GlassFish Server for the Server. Click Finish.
Note that you do not need to add the project to an enterprise application.
image::images/appclient-wizard-newentappclient.png[title="Create Application Client selected in the New Project wizard"]
When you click Finish, the IDE creates the application client project and opens ``Main.java`` in the editor.
=== Adding the Class Library
The class library that contains the remote interface now needs to be added to the classpath of the project to enable the application client to reference the EJB. The class library project is open, so you can use the Call Enterprise Bean dialog to help you generate the code to call the EJB.
If the class library project is not open, you can add the class library to the project in the Projects window by right-clicking the Libraries node and locating the JAR of the EJBRemoteInterface project.
1. Expand the Source Packages node of the EntAppClient project and open ``Main.java`` in the editor.
2. Right-click in the source code and choose Insert Code (Alt-Insert; Ctrl-I on Mac) and select Call Enterprise Bean to open the Call Enterprise Bean dialog.
3. Expand the EntAppEJB project node and select MySession. Click OK.
image::images/appclient-callenterprise.png[title="Call Enterprise Bean dialog"]
The dialog automatically selects Remote as the interface type. When you click OK, the IDE adds the following annotation to ``Main.java`` .
[source,java]
----
@EJB
private static MySessionRemote mySession;
----
The IDE also automatically adds EJBRemoteInterface as a project Library.
. Modify the ``main`` method to retrieve the String of the ``getResult`` method via the MySessionRemote interface. Save your changes.
[source,java]
----
public static void main(String[] args) {
*System.err.println("result = " + mySession.getResult());*
}
----
== Running the Application Client
You can now run the application client by building and deploying the EntAppClient project.
1. Right-click the EntAppClient project in the Projects window and choose Run.
Alternatively, you can expand source package and right-click the ``Main.java`` class and choose Run File.
When you click Run, the IDE builds the application client project and deploys the JAR archive to the server. You can see the message from the application client in the Output window.
image::images/appclient-buildoutput.png[title="The result in the Output window"]
If you want to create additional EJBs, you can simply add the new remote interfaces of the EJBs to the EJBRemoteInterface class library project.
link:/about/contact_form.html?to=3&subject=Feedback:%20Creating%20an%20Application%20Client[+Send Us Your Feedback+]
== Next Steps
For more information about using NetBeans IDE to develop Java EE applications, see the following resources:
* link:javaee-intro.html[+Introduction to Java EE Technology+]
* link:javaee-gettingstarted.html[+Getting Started with Java EE Applications+]
* link:../../trails/java-ee.html[+Java EE &amp; Java Web Learning Trail+]
You can find more information about using EJB Enterprise Beans in the link:http://download.oracle.com/javaee/6/tutorial/doc/[+Java EE 6 Tutorial+].
To send comments and suggestions, get support, and keep informed on the latest developments on the NetBeans IDE Java EE development features, link:../../../community/lists/top.html[+join the nbj2ee mailing list+].