Difference between revisions of "User talk:Svaitsis.gss"

From OpenKM Documentation
Jump to: navigation, search
(Implementing a Java Client Web Service to consume OpenKM W/S Using Eclipse Part B)
(Implementing a Java Client Web Service to consume OpenKM W/S Using Eclipse Part B)
Line 77: Line 77:
 
[[File:eclipse_dynamic_web_project4.png]]
 
[[File:eclipse_dynamic_web_project4.png]]
  
Select the option <i>Generate web.xml deployment descriptor.<i>
+
Select the option <i>Generate web.xml deployment descriptor.</i>
  
 
Click <b>Next</b>
 
Click <b>Next</b>
  
 
[[File:eclipse_dynamic_web_project5.png]]
 
[[File:eclipse_dynamic_web_project5.png]]
 +
 
Click <b>Finish</b> to finish the wizard. When wizards finishes, you should have the following project created in your project space:
 
Click <b>Finish</b> to finish the wizard. When wizards finishes, you should have the following project created in your project space:
 +
 
[[File:eclipse_created_dynamic_web_project.png]]
 
[[File:eclipse_created_dynamic_web_project.png]]
  
 
<b>Step 2</b> Creating the Web Service Client Library inside the Project.
 
<b>Step 2</b> Creating the Web Service Client Library inside the Project.
 
# Click on your project head node in the project's tree view to select the project.
 
# Click on your project head node in the project's tree view to select the project.
 
 
# Right click on the project and from the options  New -> Other. From the Wizards menu that appears, select the Web Services -> Web Service Client
 
# Right click on the project and from the options  New -> Other. From the Wizards menu that appears, select the Web Services -> Web Service Client
 
 
# Click Next
 
# Click Next
  
Line 107: Line 107:
 
Check the Option Overwrite files without warning.
 
Check the Option Overwrite files without warning.
  
Click <b>Finish</b> to finish the wizard. When wizards finishes, you should have a new package created inside your project sources: <b>com.openkm.ws.endpoint</b>
+
Click <b>Finish</b> to finish the wizard.  
 +
When wizards finishes, you should have a new package created inside your project sources: <b>com.openkm.ws.endpoint</b>
  
 
Those are the classes to support your client.
 
Those are the classes to support your client.
  
 
<b>Step 3</b> Creating the Web Service Client Class (your code)
 
<b>Step 3</b> Creating the Web Service Client Class (your code)
 +
 +
# Click on the <b> src </b> of your Project to select it. Right click and from the options select New->Package. Create a package like for example gr.uit.openkm.clients 
 +
# Select to the last node of the package (clients) to select it.  Right click and from the options select New->Class. Create a new Java Class and call it AuthTester.java. This will be your client implementation.
 +
# Add

Revision as of 22:02, 12 February 2011

Implementing a Java Client Web Service to consume OpenKM W/S Using Eclipse Part A

Michael Mountrakis Solutions Architect @UIT.GR


The first part describes how we can compile the WSDL from our OpenKM installation using the wsimport utility that comes with JDK1.6 and above. The produced client library JAR file is then imported in the Eclipse IDE in order to assist our development.

The example starts with a simple MSDOS batch file that generates the client library JAR to support the OpenKM Java Client like the one given in the official Wiki Web Services page

http://wiki.openkm.com/index.php/Java_client

The create_okm_client.bat is the following one:

rem set your javahome and your openKM host
set javahome=C:\jdk1.6.0_21
set okmhost=http://office.uit.gr:8888/OpenKM
rem -----------------------------------------
echo Creating OpenKM Clients
set wsimport=%javahome%\bin\wsimport.exe
set jar=%javahome%\bin\jar.exe 

echo Deleting old clients if exist.
del /f okm-ws-client.jar

%wsimport% -p com.openkm.ws.client %okmhost%/OKMAuth?wsdl
%wsimport% -p com.openkm.ws.client %okmhost%/OKMDocument?wsdl
%wsimport% -p com.openkm.ws.client %okmhost%/OKMFolder?wsdl
%wsimport% -p com.openkm.ws.client %okmhost%/OKMSearch?wsdl
%wsimport% -p com.openkm.ws.client %okmhost%/OKMNotification?wsdl
%wsimport% -p com.openkm.ws.client %okmhost%/OKMRepository?wsdl

echo Packaging to a jar 
%jar% cvf okm-ws-client.jar com

echo Deleting temporary directory  
del /f /s /q com

We run the program as a command line in the MS DOS prompt. Uppon successful completion, the file okm-ws-client.jar will be produced.

Next step is to add the okm-ws-client.jar to your Eclipse project:

Eclipse.png

Implementing a Java Client Web Service to consume OpenKM W/S Using Eclipse Part B

Michael Mountrakis Solutions Architect @UIT.GR


The second part describes how to create a simple OpenKM Client using Eclipse only, without the wsimport utility.

Step 1

Now the first step is to create a new Dynamic Web Project in Eclipse IDE. Select from Left Upper Menu: File -> New -> Other

From the Wizards menu that appears, select the Web->Dynamic Web Project

Eclipse new dynamic web project.png


Follow the steps of the Dynamic Web Project Wizard

Eclipse dynamic web project2.png

Follow the steps of the Dynamic Web Project Wizard

  1. Give your project a name, I named it MyOpenKmClient
  2. Give your project a run-time. I have chosen the jboss-4.2.3.GA that comes with the OpenKM
  3. Give your project a dynamic web module version. For that just leave the default 2.5
  4. Don't select EAR deployment
  5. Click Next

Eclipse dynamic web project3.png

Click Next

Eclipse dynamic web project4.png

Select the option Generate web.xml deployment descriptor.

Click Next

Eclipse dynamic web project5.png

Click Finish to finish the wizard. When wizards finishes, you should have the following project created in your project space:

Eclipse created dynamic web project.png

Step 2 Creating the Web Service Client Library inside the Project.

  1. Click on your project head node in the project's tree view to select the project.
  2. Right click on the project and from the options New -> Other. From the Wizards menu that appears, select the Web Services -> Web Service Client
  3. Click Next

Eclipse select web service client.png

Follows the client creation screen

Eclipse create web service client.png

In this screen, put the URL of the OpenKM service you want to implement. For the example, I have used our OpenKM installation at UIT, and the service I need to write a client for is the OKMAuth listening to the following URI: http://office.uit.gr:8888/OpenKM/OKMAuth?wsdl

The easiest way to test if your OpenKM service is listening, open the Mozilla (or any other browser) and put the service's URL: http://localhost:8080/OpenKM/OKMAuth?wsdl or any other URL. Notice that in UIT's URL we run OpenKM to a different port 8888. Then hit return, and the browser will return the Web Service's WSDL file:

Also put the Assemble Bar to the Assemble Client level.

Check the Option Overwrite files without warning.

Click Finish to finish the wizard. When wizards finishes, you should have a new package created inside your project sources: com.openkm.ws.endpoint

Those are the classes to support your client.

Step 3 Creating the Web Service Client Class (your code)

  1. Click on the src of your Project to select it. Right click and from the options select New->Package. Create a package like for example gr.uit.openkm.clients
  2. Select to the last node of the package (clients) to select it. Right click and from the options select New->Class. Create a new Java Class and call it AuthTester.java. This will be your client implementation.
  3. Add