This section discusses how to setup and configure a Click web application and covers the following topics:
The Click configuration files include:
![]() |
<web-app> <servlet> <servlet-name>ClickServlet</servlet-name> <servlet-class>net.sf.click.ClickServlet</servlet-class> <load-on-startup>0</load-on-startup> </servlet> <servlet-mapping> <servlet-name>ClickServlet</servlet-name> <url-pattern>*.htm</url-pattern> </servlet-mapping> </web-app>
The ClickServlet performs as much work as possible at startup to improve performance later on. The Click start up and caching strategy is configured with the Click application mode element in the "click.xml" config file, covered next.
By default the ClickServlet will attempt to load the application configuration file using the path: /WEB-INF/click.xml
If this file is not found under the WEB-INF directory, then ClickServlet will attempt to load it from the classpath as /click.xml.
See Click DTD for the click-app XML definition.
A complete Click configuration example is available here which can be used as a quick reference when configuring Click.
A basic Click app config file is provided below:
<click-app>
<pages package="com.mycorp.page"/>
<mode value="profile"/>
</click-app>
An example of an advanced config file is:
<click-app charset="UTF-8" locale="de">The rest of this chapter cover Click configuration in detail.
<pages package="com.mycorp.banking.page">
<page path="index.htm" classname="Home"/>
</pages>
<pages package="com.mycorp.common.page"/>
<format classname="com.mycorp.util.Format"/>
<mode value="profile"/>
<log-service classname="net.sf.click.extras.service.Log4JLogService"/>
</click-app>
<!ELEMENT click-app (pages*, headers?, format?, mode?, controls?, file-upload-service?, log-service?, template-service?)> <!ATTLIST click-app charset CDATA #IMPLIED> <!ATTLIST click-app locale CDATA #IMPLIED>The charset attribute defines the character encoding set for:
For example the folliwing configuration sets the application character set to UTF-8 and the default Locale as German (de):
<click-app charset="UTF-8" locale="de"> .. </click-app>
<!ELEMENT pages (page*)> <!ATTLIST pages package CDATA #IMPLIED> <!ATTLIST pages automapping (true|false) "true"> <!ATTLIST pages autobinding (true|false) "true">The pages element can specify a default package name which is prepended to the classname of any pages defined.
The pages element also defines the automapping attribute which is discussed in the Page Automapping topic.
<click-app>With multiple pages elements, pages are loaded in the order of the page elements, with manual page elements being loaded before automapped pages. Once a page template has been mapped to a Page class it will not be replaced by a subsequent potential match. So pages elements at the top take priority over lower pages elements.
<pages package="com.mycorp.banking.page"/>
<pages package="com.mycorp.common.page"/>
</click-app>
<!ELEMENT page (header*)> <!ATTLIST page path CDATA #REQUIRED> <!ATTLIST page classname CDATA #REQUIRED>Each page path must be unique, as the Click application maps HTTP requests to the page paths.
The Click application will create a new Page instance for the given request using the configured page classname. All pages must subclass Page and provide a public no arguments constructor, so they can be instantiated.
Pages can also define header values which are discussed in the next topic.
When the Click application starts up it will check all the page definitions. If there is a critical configuration error the ClickSerlvet will log an ERROR message and throw an UnavailableException. If this occurs the click application will be permanently unavailable until the error is fixed and the web app is restarted.
Automapping will attempt to associate each page template (*.htm) and JSP file in the web application (excluding those under the WEB-INF and click directories) to a Page class. Automapped pages are loaded after the manually defined pages are loaded, and manually defined pages takes preference. When automapping is enabled the Click application will log the page mappings when in debug or trace mode.
For example given a page path to class mapping:
com.mycorp.page.Home => com.mycorp.page.Search => com.mycorp.page.contacts.Contacts => com.mycorp.page.security.Login => com.mycorp.page.security.Logout => com.mycorp.page.security.ChangePasswordThis could be configured manually by setting the => automapping attribute to "false" and using the package prefix, for example:
<click-app> <pages package="com.mycorp.page" automapping="false"> <page path=" " classname="Home"/> <page path=" " classname="Search"/> <page path=" " classname="contacts.Contacts"/> <page path=" " classname="security.Login"/> <page path=" " classname="security.Logout"/> <page path=" " classname="security.ChangePassword"/> </pages> </click-app>Using automapping you only need to define the Home page which doesn't automatically map to index.html.
<click-app> <pages package="com.mycorp.page" automapping="true"> <page path=" " classname="Home"/> </pages> </click-app>Note automapping is true by default, so it could be omitted from the configuration file.
The page template name to classname convention is:
change-password.htm => ChangePassword change_password.htm => ChangePassword changePassword.htm => ChangePassword ChangePassword.htm => ChangePasswordWhen automapping pages, if a class cannot be found Click will attempt to add the 'Page' suffix to the classname if not already present and map this. For example:
customer.htm => CustomerPage change-password.htm => ChangePasswordPage
In these situations you can use the pages excludes element.
<!ELEMENT excludes (#PCDATA)> <!ATTLIST excludes pattern CDATA #REQUIRED>For example if our application uses the TinyMCE JavaScript library we could configure our pages automapping to exclude all .htm files under the /tiny_mce directory.
<click-app> <pages package="com.mycorp.page"> <excludes pattern="/tiny_mce/*"/> </pages> </click-app>The excludes pattern can specify multiple directories or files using a comma separated notation. For example:
<click-app> <pages package="com.mycorp.page"> <excludes pattern="/dhtml/*, /tiny_mce/*, banner.htm, about.htm"/> </pages> </click-app>HTM files excluded from Page automapping are handled by an internal Page class with caching headers enabled.
public class EmployeePage extends Page {In the example above the employeeForm and myTable controls were not added to the page. Also note that Form and Table does not have their names defined.
public Form employeeForm = new Form();
public Table myTable = new Table();
}
When autobinding is enabled, ClickServlet will create a new Page and add the public controls to the page. In the example above the employeeForm and myTable will be added to the page, as if you had invoked, addControl(employeeForm) and addControl(myTable).
The control's names were not defined so ClickServlet will set their names to the value of their field/variable name. In this case the Form name will be set to employeeForm while the Table name will set to myTable.
The above example is thus a shorthand way of writing the following:
public class EmployeePage extends Page {You can turn this behaviour off by setting the autobinding attribute to false, for example:
private Form employeeForm = new Form();
private Table myTable = new Table();
public void onInit() {
employeeForm.setName("employeeForm");
addControl(employeeForm);
myTable.setName("myTable");
addControl(myTable);
}
}
<click-app> <pages package="com.mycorp.page" autobinding="false"/> </click-app>
<!ELEMENT headers (header*)>The header element defines header name and value pairs which are applied to the HttpServletResponse.
<!ELEMENT header (#PCDATA)> <!ATTLIST header name CDATA #REQUIRED> <!ATTLIST header value CDATA #REQUIRED> <!ATTLIST header type (String|Integer|Date) "String">Page headers are set after the Page has been constructed and before onInit() is called. Pages can then modify their headers property using the setHeader() method.
<click-app> <pages> .. </pages> <headers> <header name="Pragma" value="no-cache"/> <header name="Cache-Control" value="no-store, no-cache, must-revalidate, post-check=0, pre-check=0"/> <header name="Expires" value="1" type="Date"/> </headers> </click-app>Alternatively you can define your headers individually in pages or for all application pages by setting header values. For example to switch off caching in the login page, note the value for a Date type should be a long number value:
<page path="login.htm" classname="com.mycorp.page.Login"> <header name="Pragma" value="no-cache"/> <header name="Expires" value="1" type="Date"/> </page>If you wanted to enable caching for a particular page you could set the following page cache control header. This will mark the page as cachable for a period of 1 hour after which it should be reloaded.
<page path="home.htm" classname="com.mycorp.page.Home"> <header name="Cache-Control" value="max-age=3600, public, must-revalidate"/> </page>To apply header values globally define header values in the headers element. For example:
<click-app> <pages> .. </pages> <headers> <header name="Pragma" value="no-cache"/> <header name="Cache-Control" value="no-store, no-cache, must-revalidate, post-check=0, pre-check=0"/> <header name="Expires" value="1" type="Date"/> </headers> </click-app>
<!ELEMENT format (#PCDATA)>
<ATTLIST format classname CDATA #FIXED "net.sf.click.util.Format">
By default all Click pages are configured with a
net.sf.click.util.Format
object. The format object is made available in the Velocity page templates using the name
$format.
To specify a custom format class configure a format element in the click-app descriptor. For example:
<click-app> .. <format classname="com.mycorp.util.CustomFormat"/> </click-app>
<!ELEMENT mode (#PCDATA)> <ATTLIST mode value (production|profile|development|debug|trace) "development">By default Click applications run in development mode, which switches off page template caching, and the logging level is set to INFO.
To change the default application mode configure a mode element in the click-app descriptor. For example to specify production mode you would add the following mode element:
<click-app> .. <mode value="production"> </click-app>The application mode configuration can be overridden by setting the system property "click.mode". This can be use in the scenario of debugging a problem on a production system, where you change the mode to trace by setting the following system property and restarting the application.
-Dclick.mode=traceThe Click Application modes and their settings for Page auto loading, template caching and logging levels are:
Application mode | Page auto loading | Template caching | Click logging level | Velocity logging level |
---|---|---|---|---|
production | No | Yes | WARN | ERROR |
profile | No | Yes | INFO | ERROR |
development | Yes | No | INFO | ERROR |
debug | Yes | No | DEBUG | ERROR |
trace | Yes | No | TRACE | WARN |
Page auto loading is a very handy feature for rapid development as you do not have to restart you application server to pick up new pages.
[Click] [debug] GET http://localhost:8080/quickstart/home.htm [Click] [trace] invoked: HomePage.<<init>> [Click] [trace] invoked: HomePage.onSecurityCheck() : true [Click] [trace] invoked: HomePage.onInit() [Click] [trace] invoked: HomePage.onGet() [Click] [trace] invoked: HomePage.onRender() [Click] [info ] renderTemplate: /home.htm - 6 ms [Click] [trace] invoked: HomePage.onDestroy() [Click] [info ] handleRequest: /home.htm - 24 msAny unhandled Throwable errors are logged by the ClickServlet.
Note that Click Extras also provide log adaptors for Log4J and the JDK Logging API.
When an application is not in production mode the error page displays detailed debugging information. When the application mode is production no debug information is displayed to prevent sensitive information being revealed. This behaviour can be changed by modifying the deployed click/error.htm page template.
<!ELEMENT controls (control*)>The control registers Control classes which will have their onDeploy() method invoked when the click application starts.
<!ELEMENT control (#PCDATA)> <!ATTLIST control classname CDATA #REQUIRED>For example to have a CustomField control deploy its resources on application startup, you would add the following elements to your click.xml file:
<click-app> .. <controls> <control classname="com.mycorp.control.CustomField"/> </controls> </click-app>
You can modify these support files and Click will not overwrite them. These files include:
For example to customize the control styles you can place a customized copy (or even a brand new version) of control.css under the /click folder in your web project:
/webapp/click/control.cssWhen Click starts up it will not override your copy of control.css with its own default version.
Different controls might deploy different stylesheet, javascript or image files, however the above principle still applies. By placing a customized copy of the stylesheet, javascript or image under the /click folder, you will override the default resource.
Be aware that some of the more complex controls (checklist, colorpicker, tree), deploys resources to subfolders under /click, for example /click/checklist/*.
A control's Javadoc will normally indicate what resources are deployed for that control.
It is generally easier to work with unpacked WARs and most servlet containers do just that. However some contains such as WebLogic (at least version 10) does not. To enable WebLogic to unpack the WAR go to the Admin Console > server node > Web Applications tab and check the Archived Real Path Enabled parameter.
If Click cannot deploy resources because of restricted file system permissions, warning messages will be logged.
If your application server does not unpack the WAR/EAR or has restricted permissions, you will need to package up these auto deployed files in your web applications WAR file. To do this you should run you application on a development machine without these restrictions and then package up the deployed files into the WAR/EAR before deployment.
Click supports two ways of deploying pre-configured resources (templates, stylesheets, JavaScript etc.) from a Jar to a web applications.
When Click starts up, it scans each Jar in the classpath for specially marked entries starting with 'META-INF/web/'. (Please note that even though Click will scan the entire classpath it is strongly recommended to host your Jar files inside your WAR lib folder e.g. WEB-INF/lib. Sharing Jars on the classpath can lead to class loading issues.)
Click will then copy all files found under 'META-INF/web/' to the web application folder.
For example, given a Jar file with the following entries:
Thus if the web application is called 'webapp', the files will be deployed as 'webapp/mycorp/edit_customer.js' and 'webapp/mycorp/edit_customer.css'.
Option #2 is especially useful when you need to deploy a large number of resources from a Jar. Note, only Jars placed under the 'WEB-INF/lib' folder will be deployed.