`
kangsoft
  • 浏览: 70500 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

读取js压缩为gzjs格式文件

阅读更多
    最近做的Ext项目Ext的插件都比较大,对于网页的浏览速度也是非常不容乐观的,于是就需要对所加载的js文件进行优化,其中一个方法就是对于较大的js文件可以进行压缩。压缩成gzjs格式,但是gzjs后缀名的文件又不能被浏览器所认识,得需要对服务器端做些处理。

一、将js格式文件压缩成gzjs格式。使用gzip.exe打包压缩后的JS文件,最后生成xx.js.gz,把xx.js.gz文件改成xx.gzjs。压缩实例: ext-all.js (610KB), gzip.exe压缩后为ext-all.gzjs(168KB)。
附:gzip使用方法,在命令行下输入: gzip -9 ext-all.js ext-all.js.gz
修改ext-all.js.gz的后缀名ext-all.gzjs(注:也可以通过gzip -h命令查看帮助)
下载地址:http://www.gzip.org

二、在项目web.xml中加入过滤器。
代码如下:
<filter> 
      <filter-name>GzipJsFilter</filter-name> 
      <filter-class>net.kangsoft.util.GzipJsFilter</filter-class> 
      <init-param> 
          <param-name>headers</param-name> 
          <param-value>Content-Encoding=gzip</param-value> 
      </init-param>
</filter>
   <filter-mapping>
   <filter-name>GzipJsFilter</filter-name>
   <url-pattern>*.gzjs</url-pattern>
</filter-mapping>



三、加入过滤类。

代码如下:
package net.kangsoft.util;

import java.io.IOException;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class GzipJsFilter
implements Filter
{
Map headers = new HashMap();

public void destroy() { }

public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)

throws IOException, ServletException {
    if (req instanceof HttpServletRequest)
      doFilter((HttpServletRequest)req, (HttpServletResponse)res, chain);
    else
      chain.doFilter(req, res);
}

public void doFilter(HttpServletRequest request, HttpServletResponse response,

FilterChain chain)
    throws IOException, ServletException
{
    request.setCharacterEncoding("UTF-8");
    for (Iterator it = this.headers.entrySet().iterator(); it.hasNext(); ) {
      Map.Entry entry = (Map.Entry)it.next();
      response.addHeader((String)entry.getKey(), (String)entry.getValue());
    }
    chain.doFilter(request, response);
}

public void init(FilterConfig config) throws ServletException {
    String headersStr = config.getInitParameter("headers");
    String[] headers = headersStr.split(",");
    for (int i = 0; i < headers.length; ++i) {
      String[] temp = headers[i].split("=");
      this.headers.put(temp[0].trim(), temp[1].trim());
    }
}
}

四、在需导入js的页面head里面添加导入文件,如:<script type="text/javascript"

src="js/ext3/ext-all.gzjs"></script>

至此已经大功告成,在我这边测试通过,如大家在运行过程中有问题,请发信息给我。
3
0
分享到:
评论
4 楼 814687491 2012-08-03  
谢谢,能使用,不是在你这复制的。不过还是参考了你的程序
3 楼 xiaolait31 2010-06-30  
我出现这样的情况
压缩过后,
在客户的机器上出现不能解析js,
2 楼 yiminghe 2010-02-25  
查查容器,很多都内建支持gzip的,配置一下就可以了
1 楼 超级潜水员 2010-02-25  
也不用修改扩展名为gzjs吧,直接使用js就行了.
这样html 啥代码都不用修改,自己再为.js加上header:Content-Encoding=gzip

相关推荐

    js文件压缩成gzjs格式的方法和工具

    NULL 博文链接:https://xiaoxinshome.iteye.com/blog/2181645

    gzip批量压缩js为gzjs文件

    windows下批量压缩js文件为gzjs

    读取JS紧缩gzjs格局文件

    Ext项目Ext的插件都斗劲大,对于网页的浏览速度也是很是不容乐观的,于是就须要对所加载的js文件进行优化,此中一个办法就是对于较大的js文件可以进行紧缩。紧缩成gzjs格局,然则gzjs后缀名的文件又不克不及被浏览器...

    Gzjs转换js

    之前有下载过一个项目学习,但是里面js都是压缩为gzjs导致无法查看,后来自己纠结好久才得以打开,于是干脆写了工具拿出来分享。 注:开发环境为:win7 64bit + JDK1.7,未在其他jre版本进行测试。

    文件压缩与合并工具

    里面包含两个工具,一个是文件压缩工具,一个是文件...压缩工具的功能:能够将js文件进行压缩,压缩成.gzjs格式的文件。文件合并工具的功能:能够将多个js文件合并成一个js文件。合并压缩过后可以提供程序的访问速度

    readz:poc,在浏览器上读取一个 gzip 格式的文件

    阅读 建造 安装浏览器 $ npm install -g browserify 安装 deps $ npm install ...删除一个gzip文件 观察 仍然有Uncaught Error: close is pending流完成时Uncaught Error: close is pending (已)

    开启TOMCAT6的GZIP压缩

    开启TOMCAT6的GZIP压缩功能,在客户端请求网页后,从服务器端将网页文件压缩,再下载到客户端,由客户端的浏览器负责解压缩并浏览。相对于普通的浏览过程HTML ,CSS,Javascript , Text ,它可以节省40%左右的流量。...

    gzip的Windows版 gzip.exe

    gzip的Windows版,展开由gzip压缩的文件。gzip压缩文件有gzip.exe gzip.doc Readme Copying 四个子文件夹。 gzip 的Window版的gzip, 也就是gzip124xN.exe. 下载 gzip 的Window版的gzip, 也就是gzip124xN.exe。

Global site tag (gtag.js) - Google Analytics