ionic代码压缩与代码混淆

ionic工程发布之前的最后一步,即代码压缩(获取更好的性能)以及代码混淆(以免源码被有心者轻易获取)。包括以下步骤:

(cordova hook)检查javascript:这一步需要在代码压缩和代码混淆之前进行以保证javascript代码无错误

(gulp task)将html页面代码转换为angular的JS代码:这一步起到了混淆html页面代码的作用

(gulp task)启用angular严格依赖注入:这一步需要在代码混淆之前进行以保证angular的依赖注入没有问题

(gulp task)组合js代码以及组合css代码:这一步起到了混淆js代码以及css代码的作用

(cordova hook)代码丑化、压缩、混淆:最后一步 -

为完成上述任务,我们需要同时使用gulp tasks以及cordova hooks。当执行ionic serve时,gulp tasks会被执行。当执行ionic buildAndroid/iOS或ionic run android/ios时,cordova hooks会被执行。


首先注意,本文说明的工程目录结构如下,读者需要根据不同的工程进行路径修改


检查javascript

1.这一步需要用到jshint以及async,可以使用npm安装:

$ npm install jshint --save-dev

$ npm install async --save-dev

2.复制cordova hooks文件:

此文件下载,并复制到$PROJECT_DIR/hooks/before_prepare文件夹里。特别注意需要给予此文件“可执行”的权限,即

$ chmod +x file_name

注意:此文件负责检测$PROJECT_DIR/www/js/目录下的js文件是否有误,请根据自己工程的实际情况对此文件进行修改:

如我的工程中有2个存放js文件的路径:$PROJECT_DIR/www/js目录和$PROJECT_DIR/www/patchjs目录,则我需要对上述文件进行如下修改:

varfoldersToProcess = ['js'];

替换为:

varfoldersToProcess = ['js','patchjs'];

3.测试:

终端执行:

$ ionic build android/ios

若成功,则可在终端输出中看到工程中js文件是否有错误,并指出错误/警告的行、列数以及错误/警告的原因:

检查无误


将html页面代码转换为angular的JS代码

这一步对html页面代码的混淆是将html页面代码处理成angular的js代码(保存到一个js文件中)。

1.这一步需要用到gulp-angular-templatecache。可以使用npm安装:

npm install gulp-angular-templatecache --save-dev

2.修改gulpfile.js文件:

vartemplateCache =require('gulp-angular-templatecache');

varpaths = {    sass: ['./scss/**/*.scss'],    templatecache: ['./www/templates/**/*.html']};

gulp.task('templatecache',function(done){gulp.src('./www/templates/**/*.html')      .pipe(templateCache({standalone:true}))      .pipe(gulp.dest('./www/js'))      .on('end', done);});

gulp.task('default', ['sass','templatecache']);

gulp.task('watch',function(){gulp.watch(paths.sass, ['sass']);  gulp.watch(paths.templatecache, ['templatecache']);});

3.修改ionic.project文件:

"gulpStartupTasks": ["sass","templatecache","watch"]

4.在app.js中增加templates模块依赖:

angular.module('starter', ['ionic','starter.controllers','templates'])

5.在index.html中引入templates.js文件:

注意:这里的templates.js文件是下一步生成的。

6.测试:

$ ionic serve

或者

$ gulp templatecache

执行完毕,在$PROJECT_DIR/www/js目录下将生成templates.js文件,此文件中将包含对html页面代码的转换结果。

7.改变templateUrl路径:

打开$PROJECT_DIR/www/js/templates.js文件,我们可以看到类似于下面的代码:

$templateCache.put("login.html", ...

大家可以看到,此时的login.html前面没有templates路径前缀,其他的html文件也是类似的,所以我们之前在js中使用templateUrl指定的html文件路径便需要作出相应变化—-去除templates路径前缀:

首先,我们要知道哪里会使用到templateUrl属性,可能有如下几种情况:

1.app.js中使用$stateProvider.state()定义路由时;

2.类似于$ionicPopover的控件或自定义的directives中到;

我们以情况1为例说明修改的过程:

app.js之前可能的情况:

.state('login', {    url:"/",    templateUrl:"templates/login.html",    controller:'LoginCtrl'});

修改之后则为:

.state('login', {    url:"/",    templateUrl:"login.html",    controller:'LoginCtrl'});

其他的也类似地进行修改。


启用angular ng-strict-di

在我们进行代码压缩之前,我们需要启用angular的ng-strict-di,即严格依赖注入,使用ng-strict-di使得工程中依赖注入不会有问题,更多关于ng-strict-di可以看这里

1.首先通过npm安装gulp-ng-annotate

$ npm install gulp-ng-annotate --save-dev

2.其次,修改gulpfile.js文件:

varngAnnotate =require('gulp-ng-annotate');

varpaths = {    sass: ['./scss/**/*.scss'],      templatecache: ['./www/templates/**/*.html'],      ng_annotate: ['./www/js/*.js']};

gulp.task('ng_annotate',function(done){gulp.src('./www/js/*.js')      .pipe(ngAnnotate({single_quotes:true}))      .pipe(gulp.dest('./www/dist/dist_js/app'))      .on('end', done);});

gulp.task('default', ['sass','templatecache','ng_annotate']);

gulp.task('watch',function(){gulp.watch(paths.sass, ['sass']);    gulp.watch(paths.templatecache, ['templatecache']);    gulp.watch(paths.ng_annotate, ['ng_annotate']);});

3.修改ionic.project文件:

"gulpStartupTasks": ["sass","templatecache","ng_annotate","watch"]

4.重新定位index.html里js的文件:

5.在ng-app标签下加入directive:ng-strict-di:

6.测试

$ ionic serve

$ gulp ng_annotate

上面的执行过程将会生成$PROJECT_DIR/www/dist/dist_js/app文件夹,并且其中包含了严格符合注入标准的工程js文件。


合并js文件以及css文件

1.通过npm安装gulp-useref

$ npm install gulp-useref --save-dev

2.其次,修改gulpfile.js文件:

varuseref =require('gulp-useref');

varpaths = {    sass: ['./scss/**/*.scss'],      templatecache: ['./www/templates/**/*.html'],      ng_annotate: ['./www/js/*.js'],      useref: ['./www/*.html']};

gulp.task('useref',function(done){varassets = useref.assets();    gulp.src('./www/*.html')      .pipe(assets)      .pipe(assets.restore())      .pipe(useref())      .pipe(gulp.dest('./www/dist'))      .on('end', done);  });

gulp.task('default', ['sass','templatecache','ng_annotate','useref']);

gulp.task('watch',function(){gulp.watch(paths.sass, ['sass']);    gulp.watch(paths.templatecache, ['templatecache']);    gulp.watch(paths.ng_annotate, ['ng_annotate']);    gulp.watch(paths.useref, ['useref']);  });

3.修改ionic.project文件:

"gulpStartupTasks": ["sass","templatecache","ng_annotate","useref","watch"]

4.修改index.html文件,对需要合并的js文件和css文件进行处理:

注意:可能有些外部的css文件或js文件不想被处理,那么就保持原状即可。

5.测试

$ ionic serve

$ gulp useref

上面的执行过程会生成以下文件:

$PROJECT_DIR/www/dist/index.html

$PROJECT_DIR/www/dist/dist_css/styles.css

$PROJECT_DIR/www/dist/dist_js/app.js

其中后面2个文件,即是被合并过后的文件。

注意:新版本的gulp-useref没有assets()方法,所以可能会出现错误,大家可以用gulp-useref的2.1.0版本,即第一步安装时使用:

$ npm install gulp-useref@2.1.0--save-dev


最后一步

1.使用npm安装cordova-uglify以及mv:

$ npm install cordova-uglify --save-dev

$ npm instal mv --save-dev

2.复制cordova hooks文件:

这些文件添加至$PROJECT_DIR/hooks/after_prepare文件夹中。并且要注意这些文件中的有关路径的操作,是对应于前几步中的路径的,如果工程结构不一样,请自行调整这些文件中有关路径的部分。特别注意需要给予此文件“可执行”的权限,即

$ chmod +x file_name

1

1

现在,我们就可以生成处理完成的文件了:

$ ionic build android/ios

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容