YUI Compressor完成代码混淆示例
Posted asin929
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了YUI Compressor完成代码混淆示例相关的知识,希望对你有一定的参考价值。
YUI Compressor相关信息
混淆单个js
一般命令,
java -jar yuicompressor-x.y.z.jar myfile.js -o myfile-min.js
若出现编码错误,就加上编码参数,比如你的文件的编码是utf-8编码,则命令如下,
java -jar yuicompressor-x.y.z.jar myfile.js -o myfile-min.js --charset utf-8
混淆多个js
如下脚本实现的功能:将工程中src/main/webapp/assets/js
目录下的所有js完成混淆,并覆盖掉原来的js。。当然,yuicompressor包得放在工程目录下。
- 执行命令:
cd your-project-dir; ant -buildfile js_confuse.xml
- 脚本内容:
<?xml version="1.0" encoding="utf-8"?>
<project name="MyTask" basedir="." default="compress-js">
<property name="src.dir" value="./src/main/webapp/assets/js" />
<target name="compress-js">
<apply executable="java" parallel="false" failonerror="true" dest="$src.dir" append="false" force="true">
<fileset dir="$src.dir" includes="**.js" />
<arg line="-jar" />
<arg path="yuicompressor-2.4.8.jar" />
<arg line="--charset utf-8" />
<srcfile />
<arg line="-o" />
<mapper type="glob" from="*.js" to="*.js" />
<targetfile />
</apply>
</target>
</project>
错误分析
混淆test.js
文件时,报错
[apply] [ERROR] in test.js
[apply] 110:10:invalid property id
该文件的第110行内容是float: false,
,
参照Stack Overflow–Compression issues with JQuery file in YUI Compressor,由于float
同时是js和css的关键字,故YUI会将其区分不开,需改为"float": false,
。
参考
以上是关于YUI Compressor完成代码混淆示例的主要内容,如果未能解决你的问题,请参考以下文章
JS代码压缩使用YUI Compressor对js文件进行压缩处理
如何在 Ant 构建脚本中为 javascript 和 css 使用 YUI Compressor