I am looking to improve front-end performance of my application, so I used YSlow tool in Firefox. When I ran this tool for my app, in the YSlow grade tab it showed up a issue \'
I recommend to use a Servlet Filter (since servlet 2.3 spec)
A gzip filter is well documented, so there is no need to reinvent the wheel:
Also, some servlet containers can do gzip on the fly. Take a look at this related question.
I recommend to use Granule Tag lib the http://code.google.com/p/granule/
It gzip and combine javascripts wrapped by g:compress tag
code sample is:
<g:compress> <script type="text/javascript" src="common.js"/> <script type="text/javascript" src="closure/goog/base.js"/> <script> goog.require('goog.dom'); goog.require('goog.date'); goog.require('goog.ui.DatePicker'); </script> <script type="text/javascript"> var dp = new goog.ui.DatePicker(); dp.render(document.getElementById('datepicker')); </script> </g:compress> ...
To improve client side performance of Java EE web application, WebUtilities java library can be helpful.
Here is the link :: https://github.com/rpatil26/webutilities.
It is also available through maven central.
Since version 0.0.4 it helps with following performance practices.
You normally configure it at appserver/servletcontainer level. I don't know which one you're using, so here's just a Tomcat targeted example. In the /conf/server.xml
configure the <Connector>
component as follows:
<Connector compression="on">
That's all. Just add compression="on"
. The other servers provides a comparable setting. consult its documentation for details. Often it's exactly the same because they're built on top of Tomcat.
For more YSlow hints in Java EE webapplication perspective you may find this blog article more useful.
Are you sure you are trying to compress JS and CSS rather than trying to minify it? Generally JS and CSS are cached by the browser after the first visit provided your caching headers are set correctly by your web server. In practice I have found that minifying JS and CSS is usually good enough for the initial download by the browser.
There are many JS minifiers. For example one is located here.