JavaScript(JS) 压缩 / 混淆 / 格式化 批处理工具
JavaScript(JS) 压缩 / 混淆 / 格式化 批处理工具
发布时间:2016-12-30 来源:查字典编辑
摘要:昨天分享了http://jscompress.sinaapp.com/这个小工具后,发现大家还是很喜爱的。因此今天我把它json化了.用js...

昨天分享了http://jscompress.sinaapp.com/这个小工具后,发现大家还是很喜爱的。

因此今天我把它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 u538bu7f29u5b8cu6210.","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教程学习
热门Javascript教程学习
编程开发子分类