读取js压缩为gzjs格式文件

系统 1780 0
    最近做的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中加入过滤器。
代码如下:
Xml代码 复制代码   收藏代码
  1. < filter >     
  2.        < filter-name > GzipJsFilter </ filter-name >     
  3.        < filter-class > net.kangsoft.util.GzipJsFilter </ filter-class >     
  4.        < init-param >     
  5.            < param-name > headers </ param-name >     
  6.            < param-value > Content-Encoding = gzip </ param-value >     
  7.        </ init-param >   
  8. </ filter >   
  9.     < filter-mapping >   
  10.     < filter-name > GzipJsFilter </ filter-name >   
  11.     < url-pattern > *.gzjs </ url-pattern >   
  12. </ filter-mapping >   
      <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>

    



三、加入过滤类。

代码如下:
Java代码 复制代码   收藏代码
  1. package  net.kangsoft.util;   
  2.   
  3. import  java.io.IOException;   
  4. import  java.util.HashMap;   
  5. import  java.util.Iterator;   
  6. import  java.util.Map;   
  7. import  java.util.Map.Entry;   
  8. import  java.util.Set;   
  9. import  javax.servlet.Filter;   
  10. import  javax.servlet.FilterChain;   
  11. import  javax.servlet.FilterConfig;   
  12. import  javax.servlet.ServletException;   
  13. import  javax.servlet.ServletRequest;   
  14. import  javax.servlet.ServletResponse;   
  15. import  javax.servlet.http.HttpServletRequest;   
  16. import  javax.servlet.http.HttpServletResponse;   
  17.   
  18. public   class  GzipJsFilter   
  19. implements  Filter   
  20. {   
  21. Map headers =  new  HashMap();   
  22.   
  23. public   void  destroy() { }   
  24.   
  25. public   void  doFilter(ServletRequest req, ServletResponse res, FilterChain chain)   
  26.   
  27. throws  IOException, ServletException {   
  28.      if  (req  instanceof  HttpServletRequest)   
  29.       doFilter((HttpServletRequest)req, (HttpServletResponse)res, chain);   
  30.      else   
  31.       chain.doFilter(req, res);   
  32. }   
  33.   
  34. public   void  doFilter(HttpServletRequest request, HttpServletResponse response,   
  35.   
  36. FilterChain chain)   
  37.      throws  IOException, ServletException   
  38. {   
  39.     request.setCharacterEncoding( "UTF-8" );   
  40.      for  (Iterator it =  this .headers.entrySet().iterator(); it.hasNext(); ) {   
  41.       Map.Entry entry = (Map.Entry)it.next();   
  42.       response.addHeader((String)entry.getKey(), (String)entry.getValue());   
  43.     }   
  44.     chain.doFilter(request, response);   
  45. }   
  46.   
  47. public   void  init(FilterConfig config)  throws  ServletException {   
  48.     String headersStr = config.getInitParameter( "headers" );   
  49.     String[] headers = headersStr.split( "," );   
  50.      for  ( int  i =  0 ; i < headers.length; ++i) {   
  51.       String[] temp = headers[i].split( "=" );   
  52.        this .headers.put(temp[ 0 ].trim(), temp[ 1 ].trim());   
  53.     }   
  54. }   
  55. }  
      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>

至此已经大功告成,在我这边测试通过,如大家在运行过程中有问题,请发信息给我。

读取js压缩为gzjs格式文件


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论