JavaScript(JS) 压缩 / 混淆 / 格式化 批处理工具_javascript技巧
程序员文章站
2022-05-25 16:19:57
...
昨天分享了 http://jscompress.sinaapp.com/ 这个小工具后,发现大家还是很喜爱的。
get={type},{type} 为可选的 compress (压缩) format (格式化) shuffle(混淆)
code=(code),(code) 为必要的源代码. JavaScript的源代码
type={compress},{compress} 注意该参数只有压缩的时候生效,可选 1(默认压缩) 2(YUI压缩) 3(GC压缩)
如果执行成功则返回结果:
因此今天我把它json化了.用json传输数据,也开放了api
本工具所有的功能实现都是由 http://jscompress.sinaapp.com/api 处理.(包括现在可以使用的这个在线压缩)
所有的数据交换均由 HTTP POST 输入处理后由 json 作为数据输出格式.
API参数 : http://jscompress.sinaapp.com/api?get={type}&code=(code)&type={compress only}
get={type},{type} 为可选的 compress (压缩) format (格式化) shuffle(混淆)
code=(code),(code) 为必要的源代码. JavaScript的源代码
type={compress},{compress} 注意该参数只有压缩的时候生效,可选 1(默认压缩) 2(YUI压缩) 3(GC压缩)
例:使用 CURL... POST
http://jscompress.sinaapp.com/api?get=compress&code=var a=1;var b=2;&type=2
如果执行成功则返回结果:
{"code":"var a=1,b=2;\n","original_size":"16 Byte","now_size":"13 Byte","status":"Closure Compiler \u538b\u7f29\u5b8c\u6210.","minify":"81.25%"}
然后我写了一个php文件,可以调用这个网站的api,把整个目录所有的js文件压缩或者混淆,格式化后保存到一个新目录。
这样就对那些懒上传文件的同学们基于方便了~~
直接下载地址: jstools.rar
高亮显示
代码如下:
<?php /* /## js 合并和压缩PHP脚本...可用于本地或者服务器. /## 本工具只能处理utf-8编码的 *.js 文件.否则会接收不到结果 @ 风吟 (fengyin.name) @ http://jscompress.sinaapp.com/ */ set_time_limit(0); function JsTools($options = array( 'basepath' =>'./', //需要处理的脚本路径... 'compiled' =>'./compiled/', //处理后新文件的路径... 'type' =>'compress', //可选 compress (压缩) format (格式化) shuffle (混淆) 'is_merger' =>true, // 是否需要把全部文件合并再进行处理 (压缩,格式化,混淆) 'engine' =>'1'//此项只对 type 为 compress 时有效,1(默认) 2 (yui) 3(Closure Compiler) /* yui 和 Google Closure Compiler 压缩是不可逆的,一般情况下使用默认即可 不推荐使用混淆. */ )){ if (is_dir($options['basepath'])) { if ($dh = opendir($options['basepath'])) { while (($file = readdir($dh)) !== false) { if (strpos($file, '.js') !== false && strpos($file, '.min.js') === false) { $js[] = $file; } } closedir($dh); } } if ($options['is_merger']) { foreach($js as $jsfile) { $jscode.= file_get_contents($jsfile).';'; } $jscode = json_decode(api($jscode, $options['type'], $options['engine']), true); file_put_contents($options['compiled'].'all.min.js', $jscode['code']); } else { foreach($js as $jsfile) { $jscode = json_decode(api(file_get_contents($jsfile), $options['type'], $options['engine']), true); file_put_contents($options['compiled'].str_replace('.js', '.min.js', $jsfile), $jscode['code']); } } } function api($code, $type, $engine) { $ch = curl_init('http://jscompress.sinaapp.com/api'); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, 'get='.$type.'&code='.urlencode($code).'&type='.$engine); $output = curl_exec($ch); curl_close($ch); return $output; } JsTools(); ?>
以上就是JavaScript(JS) 压缩 / 混淆 / 格式化 批处理工具_javascript技巧的内容,更多相关内容请关注PHP中文网(www.php.cn)!
上一篇: php计算排列组合的方法示例代码
推荐阅读
-
js对数字的格式化使用说明_javascript技巧
-
XmlUtils JS操作XML工具类_javascript技巧
-
扩展JS Date对象时间格式化功能的小例子_javascript技巧
-
js 实现css风格选择器(压缩后2KB)_javascript技巧
-
js为数字添加逗号并格式化数字的代码_javascript技巧
-
js 金额格式化来回转换示例_javascript技巧
-
js 数值项目的格式化函数代码_javascript技巧
-
用js来格式化字符串示例模仿css_javascript技巧
-
js为数字添加逗号并格式化数字的代码_javascript技巧
-
js的压缩及jquery压缩探讨(提高页面加载性能/保护劳动成果)_javascript技巧