java Web程序使用wro4j合并、压缩js、css等静态资源

在Web项目中,js、css合并压缩,不仅有利于减少Http请求数量、减少宽带资源占用,还能有效的管理各种js、css的引入,使整个项目更加有序。而对于访问用户来说,其更大的好处是增加了页面的打开速度,大大提升了用户体验。

所以,互联网各类网站,会通过各种手段,对静态文件进行合并、压缩,动静分离,使用CDN加速等。以此达到网站访问速度的优化。
everycoding.com官网使用的是Java语言开发。因此使用了Java 方面的第三方Jar:wro4j来压缩Js、CSS。本文主要介绍Java Web程序是如何使用wro4j合并、压缩js、Css等静态资源的。

1.    首先下载wro4j-core.1.6.2.jar,maven管理的项目可使用如下依赖获取架包。

  1. <dependency>
  2. <groupId>ro.isdc.wro4j</groupId>
  3. <artifactId>wro4j-core</artifactId>
  4. <version>1.6.2</version>
  5. </dependency>

2.    配置Js、CSS合并策略。新建wro.xml文件,放置在WEB-INF目录下面
即:/src/main/webapp/WEB-INF/wro.xml。以everycoding官网代码为例,配置详情如下:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <groups xmlns="http://www.isdc.ro/wro" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://www.isdc.ro/wro wro.xsd">
  4. <group name="basic">
  5. <css>/static/css/front.css</css>
  6. <js>/static/js/jquery.js</js>
  7. <js>/static/js/jquery.paging.min.js</js>
  8. <js>/static/js/front/global.js</js>
  9. <js>/static/js/front/search.js</js>
  10. </group>
  11. <group name="custom">
  12. <css>/static/css/front.css</css>
  13. <css>/static/css/comment/comment.css</css>
  14. <css>/static/plugins/syntaxhighlighter/shCore.css</css>
  15. <js>/static/js/front/coding.js</js>
  16. </group>
  17. </groups>

3.    在视图页面引入合并后的js、css.详情可见everycoding.com站点的引入方式

  1. <link href="/static/css/basic.css?minimize=false&v=1433678168807" rel="stylesheet">
  2. <script src="/static/js/basic.js?minimize=false&v=1433524342015"></script>

4.    在web.xml中配置wro4j的过滤器,使js、css合并策略生效。代码配置方式如下:
其中,/static/是Everycoding官网放置静态文件的目录,具体配置请参考自身项目

  1. <filter>
  2. <filter-name>WebResourceOptimizer</filter-name>
  3. <filter-class>
  4. ro.isdc.wro.http.WroFilter
  5. </filter-class>
  6. <init-param>
  7. <param-name>debug</param-name>
  8. <param-value>true</param-value>
  9. </init-param>
  10. <init-param>
  11. <param-name>disableCache</param-name>
  12. <param-value>true</param-value>
  13. </init-param>
  14. <!-- <init-param> <param-name>gzipResources</param-name> <param-value>false</param-value>
  15. </init-param> <init-param> <param-name>cacheUpdatePeriod</param-name> <param-value>1</param-value>
  16. </init-param> <init-param> <param-name>modelUpdatePeriod</param-name> <param-value>1</param-value>
  17. </init-param> <init-param> <param-name>minimizeEnabled</param-name> <param-value>true</param-value>
  18. </init-param> -->
  19. </filter>
  20. <filter-mapping>
  21. <filter-name>WebResourceOptimizer</filter-name>
  22. <url-pattern>/static/*</url-pattern>
  23. </filter-mapping>

5.    Web.xml中配置的wro4j属性Debug的作用
Debug:在开发环境,一般设置为true。生产环境设置为false
那么在开发环境中,将debug设置为true有什么好处呢?
原因是:当debug为false时,视图中引入的js、css都是合并压缩过的代码,尤其是Js,不利于我们开发过程中进行断点调试等工作。
如果,我们想在开发过程中,断点调试Js代码,需要将Debug设置为true。同时,视图引入的js代码部分,需要加上参数:minimize=false。表明:合并,但是不压缩js。
如:/static/js/basic.js?minimize=false
需要注意的时,当debug=false时,这个参数的作用将失效。Js、Css在生成环境一定是压缩的状态。

6.    wro4j相关配置属性详解

属性 认值 描述
debug true true代表开发环境,false代表生成环境
minimizeEnabled true 是否压缩资源
gzipResources true True,则表明response将开启gzip
resourceWatcherUpdatePeriod 0 怎样的频率静态资源更新被监控,0表明不监控。      当监控到资源有更新时,则静态资源的缓存失效。      (since    1.4.8)
resourceWatcherAsync false 对异步更新的静态资源的监控,当属性resourceWatcherUpdatePeriod 配置大于0时,这个值才有意义 (since 1.7.3)
cacheUpdatePeriod 0 怎么样的频率刷新缓存。0表示不刷新静态缓存。
modelUpdatePeriod 0 怎样的频率刷新wro.xml合并压缩策略。0表示不刷新。
header   见官网说明
disableCache false 是否禁用静态资源缓存1.7.6之后的版本已废弃
parallelPreprocessing false 是否开启预处理器并行执行,以提高效率
connectionTimeout 2000 外部资源访问的超时时间,1.4.5版本后有效
managerFactoryClassName N/A 默认BaseWroManagerFactory管理
encoding UTF-8 设置读写编码格式
ignoreMissingResources true 为false时,丢失的资源会引发异常产生。True则会忽略这些异常。
ignoreEmptyGroup true 为false时,空引入链接将失败。True,则忽略。1.4.5之后版本有效。
ignoreFailingProcessor false 为true时,有问题的资源将以原生的方式引入。      1.4.7版本后有效。
cacheGzippedContent false 缓存是否使用gzipped的静态内容. since 1.4.4之后版本有效
jmxEnabled true 是否关闭JMX.
mbeanName wro4j JMX    console 见官网

Wro4j的详细用法可参考:http://code.google.com/p/wro4j/wiki/Installation
如果Java Web项目希望使用动静分离的方式单独部署静态文件,可参考:http://everycoding.com/coding/67.html

时间: 2024-10-26 06:03:16

java Web程序使用wro4j合并、压缩js、css等静态资源的相关文章

SpringMVC 无法加载js,css等静态资源文件

最近在一些技术群里看到有些朋友的馈,SpringMVC 无法加载js,css等静态资源文件,运行时报无法找到异常.下面说下原因及解决方法: 由于SpringMVC支持较优雅的Rest风格的URL,url-patten又是配置的支持所有的模式,所以对于静态资源(css,js,html等)也会去进行匹配,一旦匹配失败控制台会抛URI匹配异常. 这种情况下,需要在SpringMVC配置中增加默认的配置 <mvc:default-servlet-handler/> 增加了上面这个配置之后,原来的Req

maven 配置合并压缩JS+CSS

1 <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> 2 <modelV

java web程序 上机考试登陆界面设计实现

今天是java web上机.做一个登陆注册的界面.要求:jsp.mysql数据库,js做一个美观的界面.功能.可以添加 更多啊.我做的界面被老师狠狠的扣了分.问题在于.当用户没有输入任何信息(没有输入用户名和密码)就直接提交的 时候,页面显示500错误,这里改正的方案2点.我是这么想的.1.要么是提交时弹出一个对话框.显示用户名和密码为空!.这里 要注意的是,弹出的对话框不能阻止用户输入信息,弹出后,依然让用户输入.2.要么是提交按钮后依然跳转到本页面.因为一个form表单 只能跳转到一个页面,

java web 程序---购物车选商品,购买,付款

虚函数使用的时机 为什么虚函数不总是适用? 1. 虚函数有事会带来很大的消耗: 2. 虚函数不总是提供所需的行为: 3. 当我们不考虑继承当前类时,不必使用虚函数. 必须使用虚函数的情况: 1. 当你想删除一个表面上指向基类对象,实际却是指向派生类对象的指针,就需要虚析构函数. java web 程序---购物车选商品,购买,付款,布布扣,bubuko.com

java web程序 登陆验证页面 4个页面人性化设置

到这里,快期末考试了,老师不讲课,我心里有苦不想说,也许没有考虑到老师的感受,让老师难堪了 但是我的行为已不再是我可以做的了.不可能了,我只是职业性的机械的做事了. 思路: 1.第一个是form表单,用户输入用户名和密码,点击登陆按钮 a.jsp 2.第二是验证页面,如果不是那个用户名和密码,则显示登陆失败或错误,点击链接重新登陆ok.jsp d.jsp 3.当用户为输入任何数据,即为空的时候,则提示用户先登录,c.jsp 第一个页面,就不写了 验证页面 ok.jsp ? 1 2 3 4 5 6

Java Web 程序员的职业进阶之路

啥也不说了,都在图里了.希望可以给大家的职业规划一些提示,尤其是写了几年程序,却越来越迷茫的同学. Java Web 程序员的职业进阶之路,布布扣,bubuko.com

Java Web 程序猿的职业进阶之路

啥也不说了,都在图里了.希望能够给大家的职业规划一些提示,尤其是写了几年程序,却越来越迷茫的同学. Java Web 程序猿的职业进阶之路,布布扣,bubuko.com

java web 程序---投票系统

1.这里会连接数据库--JDBC的学习实例 一共有3个页面. 2.第一个页面是一个form表单,第二个页面是处理数据,第三个页面是显示页面 vote.jsp ? 1 2 3 4 5 6 7 8 9 10 11 12 <body bgcolor="green">    选择你要投票的人:    <form action="vote_end.jsp">        <input type="radio" name=&q

java web 程序---javabean实例--登陆界面并显示用户名和密码

重点:注意大小写,不注意细节,这点小事,还需要请教 发现一个问题,也是老师当时写的时候,发现代码没错,但是就是运行问题. 大家看,那个java类,我们要求是所有属性均为私有变量,但是方法为公有的,如果方法为不公有的,那么运行就一定有问题,一定声明为public.不写修饰符,就是不对. 这样程序可以运行了,细节.这就是我觉得老师很棒的原因. 一个表单 deng.jsp ? 1 2 3 4 5 6 7 8 <body>   <form action="c.jsp">