咱们都知道,浏览器上是能够看到前端的html和js代码的,因此若是遇到隐私心比较强的老板,你就冷不丁的会接受到一个代码加密的需求,当接受到这个需求的时候你怎么完成?那我但愿个人这篇博客能够帮助到你。css
首先,告诉你的老板,严格意义上的加密是不存在的,可以实现的只有对前端代码进行压缩混淆,增长阅读难度。html
本篇教程全篇描述的,就是对代码进行混淆的手段,从而知足老板提出的加密需求。前端
为了保证本篇教程真实可用,我将使用一台新的Windows系统,从无到有进行演示,同时将操做流程记录在这里,供你参考,也但愿可以帮你跳过一些坑,若是你遇到什么问题,请留言讨论。node
若是你没安装过node,请跟着教程走,若是你安装过,请直接跳到下一节。git
下载地址:http://nodejs.cn/download/es6
直接下载安装,安装的过程是傻瓜式的下一步,惟一能够改变的是安装位置。github
安装完成后打开cmd命令行,查看版本号是为了确认是否安装成功。npm
切换到项目根目录:json
安装gulp插件包:npm install --save-dev gulpgulp
效果如图:
别急,还有不少包,命令一条一条刷起来:
npm install --save-dev del
npm install --save-dev gulp-concat
npm install --save-dev gulp-header
npm install --save-dev gulp-if
npm install --save-dev gulp-minify-css
npm install --save-dev gulp-htmlmin
npm install --save-dev gulp-rename
npm install --save-dev gulp-replace
npm install --save-dev gulp-uglify
npm install --save-dev gulp-babel
npm install --save-dev babel-preset-es2015
npm install --save-dev @babel/core
npm install --save-dev @babel/preset-env
插件安装完成后,咱们的前期工做就作完了。
咱们会发现项目目录中多个一个node_modules目录和package-lock.json文件,json文件中是咱们的插件列表,node_modules目录中是咱们安装的插件包。
index.html是个人主入口文件,src目录就是个人项目中存放代码的目录,也就是我要压缩加密构建的目录。
src里有三个子目录,controller存放独立的js处理前端业务逻辑,style存放css样式文件,view存放html页面。
在编写脚本以前,我须要直白的告诉你,若是你的JS里有ES6语法,正常打包是打不了的,不过咱们的前期工做已经把处理这个问题的工具包也一块儿安装了,可是也仅限于处理单独的JS文件。
若是你是HTML代码里嵌JS,而且JS里有ES6语法,那么须要把JS代码拎出来作成单独的JS,或者手动将ES6写法改为ES5。
总之,若是你打包报错,很大多是ES6语法致使,其次是文件路径错误。
回到咱们的项目根目录,建立一个gulpfile.js文件,这个是固定的文件名:
引入包:
var gulp = require('gulp'); var uglify = require('gulp-uglify'); var babel = require('gulp-babel'); var minifyCss = require("gulp-minify-css"); var htmlmin = require('gulp-htmlmin'); var header = require('gulp-header'); var del = require('del');
定义一个目标目录:
var destDir = './dist';
定义一个注释,由于我但愿在压缩后的代码中第一行添加一点注释:
var note = ['/** 小样,看源码?想得美! */\n <%= js %>', {js: ';'}];
监放任务:
gulp.task('minjs', function () { //定义路径 var src = [ './src/**/*.js' ]; gulp.src(src) .pipe(babel({presets: ["@babel/env"], plugins: []}))//es6转es5 .pipe(uglify())//压缩 .pipe(header.apply(null, note))//添加头部注释 .pipe(gulp.dest(destDir));//将压缩后的内容输出到目标目录 });
minjs就是咱们自定义的任务名,也就是说 咱们在命令行输入gulp minjs 这行命令,这段代码就会执行。
若是只输入gulp命令,它会自动去找名为default的任务。
var src = ['./src/**/*.js']; 就是咱们想要抓取的文件,使用了通配符,你几乎必定会有需求像下面这样写:
var src = [ './src/**/*.js' , '!./src/config.js' , '!./src/lib/extend/*.js' ];
感叹号的意思是排除。
这里说明一下destDir只会代替通配符以前的目录路径,好比说我这里的destDir定义的是./dist,那么 ./src/controller/admin.js 压缩后的路径就是 ./dist/controller/admin.js。
好了,打开命令行,输入命令:gulp minjs
查看项目,js文件已经压缩成功了。
任务的监听和压缩JS是没有差异的,只不过压缩任务用gulp-minify-css插件来完成。
gulp.task('mincss', function () { var src = [ './src/style/*.css' ]; gulp.src(src).pipe(minifyCss()).pipe(gulp.dest(destDir + '/style')); });
输入命令:gulp mincss
查看项目也没有任何问题:
很是智能的它会把css中的注释给你删掉。
压缩HTML能够传入不少参数指定相应的行为:
gulp.task('minhtml', function () { var options = { removeComments: true,//清除HTML注释 collapseWhitespace: true,//折叠空白 minifyJS: true,//压缩页面JS minifyCSS: true//压缩页面CSS }; var src = [ './src/views/**/*', ]; gulp.src(src) .pipe(htmlmin(options)) .pipe(gulp.dest(destDir + '/views')); });
更多参数请移步这里来看:https://github.com/kangax/html-minifier/blob/gh-pages/README.md
输入命令:gulp minhtml
压缩后的HTML:
所有压成一行,文件中的css和js也一并压缩了。
可是咱们总不多是打个包要跑多条命令吧,那多麻烦,如今咱们就整合整合,让这些任务合并成一个任务。
咱们建立一个task对象,把各个任务的内容放进去,而且加一个清理dist目录的方法,和一个move方法负责将没有被压缩的文件复制过去。
//任务列表 var task = { //清理dist目录 clear:function () { del(['./dist/*']); }, minjs:function () { //定义路径 var src = [ './src/**/*.js' ]; gulp.src(src) .pipe(babel({presets: ["@babel/env"], plugins: []}))//es6转es5 .pipe(uglify())//压缩 .pipe(header.apply(null, note))//添加头部注释 .pipe(gulp.dest(destDir)); }, mincss:function () { var src = [ './src/style/*.css' ]; gulp.src(src).pipe(minifyCss()).pipe(gulp.dest(destDir + '/style')); }, minhtml:function () { var options = { removeComments: true,//清除HTML注释 collapseWhitespace: true,//折叠空白 minifyJS: true,//压缩页面JS 若是你确信你的HTML页面中的js不包含有es6语法,那么能够压缩js 不然仍是得把js抽离成单独的文件进行压缩 minifyCSS: true//压缩页面CSS }; var src = [ './src/**/*', ]; gulp.src(src) .pipe(htmlmin(options)) .pipe(gulp.dest(destDir)); }, move: function () { //复制文件夹 没有被压缩的文件就在这里复制 gulp.src('./src/**/*.png').pipe(gulp.dest(destDir)); } };
咱们在压缩js的时候说了,若是只是gulp命令,它会去找名为default的任务,咱们就在default任务里遍历task对象,将其中的方法轮流执行一遍。
gulp.task('default', function () { for (var key in task) { task[key](); } });
这样,咱们只须要一个gulp命令,也就走完了整个构建流程。
同时,咱们将单个的任务指向task中对应的方法:
gulp.task('clear',task.clear); gulp.task('minjs',task.minjs); gulp.task('mincss',task.mincss); gulp.task('minhtml',task.minhtml); gulp.task('move',task.move);
不管是单独处理一个环节,仍是整个构建流程,咱们均可以很方便的完成。
最后,感谢阅读。 PS:欢迎关注,有粉必回。