Web technologies/2014-2015/Laboratory 10

There are cases when it is better to offer window-based application to end-users rather than web-based ones. Applications which cannot be rendered as web-based are good examples.

The simplest way to achieve this is to publish your application on a website either as an applet or as a Java Web Start application.

Java Applets
Applets allow users to run Java applications embedded inside their browsers.

There are several steps required in order to offer a fully functional applet to users:


 * code the applet
 * embed the applet in the HTML code

Coding the Applet
Applets are nothing else than Java classes which extend the Applet (AWT) or JApplet (SWING) base class:

The Applet and JApplet classes provide a simple framework for working with applets. This framwork includes the following methods:


 * init - used for initialising the Applet. Works as a constructor
 * start - used when some after-init operations are required
 * stop - used together with start. It suspends the applet's execution when the user is not using it
 * destroy - additional garbage collector. Most applets do not need it as most of the work is done in the stop method

Embedding the Applet inside HTML code
Embedding an applet inside a HTML page is straightforward. Users need only use the   tag in order to offer this feature:

Some of the most used attributes for the tag are:


 * code - the Java class of the applet
 * codebase - the path to the applet. Can be omitted if the applet is in the same folder as the HTML page
 * name - the name of the Applet. Can be used for inter-applet communication
 * height - the height of the applet in pixels
 * width - the width of the applet in pixels
 * etc.

Applets can be customized by specifying parameters through the   tag. For instance one can specify the image an applet could use, its font and color, etc:

Links:


 * Applet Tutorial
 * Free Java Applets

Java Web Start
Java Web Start (or better known as javaws) allows user to start Java applications directly from the Internet by using a browser as an intermediary. A specific requirement is for applications to be signed by trusted authorities.

NOTE: Contrary to applets, javaws eliminates some of the security restrictions on the former and allows applications perform operations such as file manipulation.

In order to deploy a javaws application you need to do the following (for Linux users, altough for Windows the steps are similar):


 * create a jar archive using either ant or jar as tools. Be sure to place all your files (java classes, images, text files, etc.) inside it. Also be sure to maintain the relative file paths used in the application for accessing them. Be sure you give proper access rights to any file (image or text placed in the jar) your application will use (chmod +r).
 * sign the jar using a digital certificate. In order to do this you must first generate one by using the keytool command followed by the jarsigner command. Don't forget to remember the password that you have provided as it will be necessary later. Also store in a safe place your certificate file. The following code fragment exemplifies how these commands can be used (from a shell window):

You can create the jar from the command line by running:

NOTE: The keytool and the jarsigner are found inside the JRE folder.


 * create a JNLP (Java Network Launching Protocol) file. It specifies how to launch Java Web Start applications and consists of a set of rules defining how exactly to implement the launching mechanism. The following code fragment shows an example for jnlp file called example.jnlp handling a jar named example.jar:

NOTE: we can notice that the JOGL jars are grabbed at runtime from the site. In this way we need not bother moving them also to the web server


 * Move your jar, jnlp and other dependent jars to the web server. In our case we will use an Apache Tomcat Server but any other server can be used. The files need to be moved to the $CATALINA_HOME/webapps/yourApp/ directory so that both the jar and the jnlp file should be located on the same level. For any additional libraries create a lib/ directory and place them inside. In our example we could move the example.jar and example.jnlp to $CATALINA_HOME/webapps/example-jnlp/


 * Restart the web server and enter the following URL in your favourite browser: http://ipaddress:8080/yourApp/yourJNLPfile.jnlp. If everything goes fine you should see your application running. As an alternative you could use the command: javaws http://localhost:8080/yourApp/yourJNLPfile.jnlp from command line. In our example we simply need to call http:// :8080/example-jnlp/example.jnlp.

NOTE: You do not need to restart your web server each time you modify the jar.

IMPORTANT: When reading files be sure to use an InputStreamReader as follows, or the application will not work:

IMPORTANT the same applies for binary files such as images:

or:

NOTE: The filepath variable must point to a path relative to the package folders. For example given the following jar structure:


 * file.jar
 * mypackage
 * *.class
 * META-INF
 * certificate files
 * images
 * *.jpg

the filepath variable is "images/*.jpg".

Links:


 * Java Ant
 * Java WebStart
 * JNLP

Exercises

 * Create simple webpage which offers the following:
 * a menu page for accessing three predefined applets. The applets can be found at http://www.echoecho.com/freeapplets.htm page.
 * a page which allows users to run a Java Application using javaws. The application should display a single image. (See http://stackoverflow.com/questions/299495/java-swing-how-to-add-an-image-to-a-jpanel for details on how to display an image using SWING)

NOTE The website should be HTML 4.01 strict valid