# 使用NW将我们开发的网站打包成桌面应用
>[info] NW.js 是Node.js 开发的桌面应用打包工具
> 你可以使用node语言开发桌面应用 我这里只是介绍如何将网站包一个本地应用的壳
> NW而且打包了谷歌浏览器 兼容性更好 但骨子里 他还是网站程序
## NW.js 下载
下载网址 https://nwjs.io/downloads/
推荐下载 Windows 32-bit 和 Mac OS X 64-bit
>[danger] 不要用win64位 一个是兼容性不好老系统不一定兼容
> 另外就是win64位打包的软件达到200多M 而32位程序打包后文件大小减少一半
## 解压文件 创建子项目文件夹
解压后的结构如下: win32版
![](https://box.kancloud.cn/ede79a8763bf8ff9e116062567867c5d_607x569.png)
注意 :这三文件夹不是nw自带的
![](https://box.kancloud.cn/40d37d5da00dba80aa3044d522ac6882_617x76.png)
## 创建 node.js 项目文件夹
现在我在里面建一个mikkle文件夹
这个文件夹将是我们新的node.js项目文件夹
![](https://box.kancloud.cn/2a83d5a47129b033d07b528127f54ef9_598x451.png)
## 创建NODE项目配置文件
在项目文件中 创建package.json
可以继续使用PHPSTORM 注意编码和格式
![](https://box.kancloud.cn/b49dee3d3d8903b49d342d38c6602bda_563x433.png)
>[danger] 这个文件要求苛刻编码utf-8 不能有多余的逗号 不要中文 引号必须双引号
~~~
{
"name": "mikkle'snw",
"version": "1.0.0",
"main": "index.html",
"window": {
"width": 1024,
"height": 768,
"title": "mikkle'nw"
}
}
~~~
>[info] ndex.html 就是你的Node项目的入口文件
>当然你也可以用index.js 用node语言开发
>![](https://box.kancloud.cn/7772f865e293aa9e2ad0edf8b269f124_662x243.png)
## 创建index.html文件
~~~
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Mikkle'Nw.js</title>
</head>
<body>
<script>
window.location.href = "http://www.mikkle.cn";
</script>
</body>
</html>
~~~
>[success] 就是就是一个简单的跳转
>这里你可以根据你的需求开发自己的项目文件
>
## 打包项目文件
将项目文件打包成zip格式 并重命名
![](https://box.kancloud.cn/308a7b04bd166d994921952d2a8803d6_619x159.png)
注意一定进入到项目文件夹打包 mikkle.zip 要包含你的所有NODE项目文件
![](https://box.kancloud.cn/21b916cb5d97f52ea2623700635a835d_427x142.png)
包一个壳 就俩文件
## 将zip文件重命名 并copy到主目录
![](https://box.kancloud.cn/1fc0f10948d0e6864033efeff6f0bbc3_711x450.png)
## 将mikkle.nw拖到nw.exe即可执行
![](https://box.kancloud.cn/1b1d0d90d39e2db7d75996968b6d6bf1_650x428.png)
![](https://box.kancloud.cn/7f91fd74b8ec997a9cbe4b9dae215ca8_1040x807.png)
## 打包文件mikkle.nw+nw.exe文件
使用win命令行
进入主项目文件夹 执行以下命令
![](https://box.kancloud.cn/904dde0dc970d894b0a5aa0f9567eaf3_469x290.png)
~~~
copy /b nw.exe+mikkle.nw mikkle.exe
~~~
>[info] copy /b是打包成二进制文件
>nw.exe+mikkle.nw 顺序不要反了
>mikkle.exe文件是你要生成的文件名字 随意的 这东西可以改
## mikkle.exe文件就可以运行项目了
![](https://box.kancloud.cn/0852b95717085dd2bdd0b93f67157974_660x466.png)
## 使用Enigma Virtual Box打包成单体exe
* Enigma Virtual Box 下载地址 http://enigmaprotector.com/en/downloads.html
* 自己下载后并安装运行
![](https://box.kancloud.cn/bcb5a5023cf3c23a38d2a3ca883128ff_782x549.png)
* 选择项目运行文件
>[danger] Input File Name选择刚才生成的mikkle.exe
> Output File Name自动会生成输出文件。你也可以选择不同的输出目录
> ![](https://box.kancloud.cn/f37d65398b5cfa188619585a68857d49_754x141.png)
* 添加项目附送文件
添加所有把项目文件
![](https://box.kancloud.cn/2ffa91d655b0396836304c0d0f1c3f8b_1537x622.png)
![](https://box.kancloud.cn/5f2b0485ff97dce31a8de422710dfbba_497x303.png)
>[danger] 注意可以不包括 mikkle目录 mikkle.exe mikkle.nw 和mikkle.exe
* 点击右下角的"Process"按钮
![](https://box.kancloud.cn/3c186bea098bf591075e6ae1df7d10cb_772x543.png)
* 最后copymikkle_boxed.exe给顾客即可
![](https://box.kancloud.cn/2b406c05b420c9fa994d2c160a87f5a0_1077x663.png)
感谢大家关注 交流请加QQ群 321449759
![](https://box.kancloud.cn/3499008a08e64306c68873288092a057_286x340.png)
- 序言及更新日志
- 前言一 开发PHP必备的环境(你可以不看)
- LinUX系统ThinkPHP5链接MsSQL数据库的pdo_dblib扩展
- centos7.2挂载硬盘攻略
- Centos系统Redis安装及Redis的PHP扩展安装
- Centos系统增加Swap(系统交换区)的方法
- 前言二 开发PHP软件配置和介绍(你依然可以不看)
- 数据库SQL文件
- 本地Git(版本控制)的搭建
- GIT远程仓库的克隆和推送
- Git常用命令
- PHP面向对象思想实战经验领悟
- PHP面向对象实战----命名空间
- PHP面向对象实战----继承
- 基类实战--底层方法封装
- 基类实战--构造函数实战
- 基类实战--析构函数的使用
- TP5实战开发前篇---控制器(controller)
- 控制器中Request类的使用
- 控制器中基类的使用
- TP5实战开发前篇---模型篇(model)
- TP5实战开发前篇---验证器篇(Validate)
- TP5实战课程入门篇---花拳绣腿
- 模块以及类的文件的建立
- Api开发------单条信息显示
- Api开发---单条信息复杂关联显示
- Api开发---查询信息缓存Cache的应用
- TP5实战技巧---开发思路 引路造桥
- TP5实战技巧---整合基类 化繁为简
- TP5实战课程入门篇---数据操作
- Api开发---数据的添加和修改
- API开发---快速开发API通用接口
- TP5专用微信sdk使用教程
- THINKPHP5微信SDK更新记录及升级指导
- TP5专用SDK 微信参数配置方法
- 微信公众号推送接口对接教程
- 微信推送接口对接示例含扫描登录微信端部分
- TP5专用微信支付SDK使用简介
- TP5专用支付宝支付SDK使用说明
- 使用NW将开发的网站打包成桌面应用
- TP5高阶实战课程 进阶篇概述
- 进阶篇一 实战开发之习惯及要求
- 进阶篇二 实战开发之控制器
- 控制器基类之控制器基类使用方法
- 控制器基类之控制器基类常用方法分享
- 控制器基类之构造函数的使用方法
- 进阶篇三 实战开发之权限控制
- TP5实战源码 --- 全局用户信息验证类Auth
- TP5实战源码 --- 微信Auth实战开发源码
- 进阶篇四 实战开发之模型
- 模型基类之模型基类的用途
- 模型基类之常用数据处理方法
- 模型逻辑层之实战代码(含事务)
- 模型实战开发之模型常用方法
- 模型实战源码 --- 乐观锁的应用
- 模型实战技巧---Model事件功能的使用
- 模型事件实战应用---数据库操作日志
- 进阶篇五 实战开发之缓存(Cache)
- TP5实战源码---应用缓存获取城市信息
- TP5实战源码---应用缓存获取分类详情
- 进阶篇六 TP5类库的封装和使用
- DataEdit快捷操作类库
- ShowCode快捷使用类库
- 阿里大于 短信API接口 TP5专用类库
- DatabaseUpgrade数据库对比及更新类库
- AuthWeb权限类使用说明
- 进阶篇七 服务层的应用
- 服务层源码示例
- 服务层基类源码
- 进阶篇八 应用层Redis数据处理基类
- Redis服务层基类源码
- 进阶篇九 使用Redis类库处理一般的抢购(秒杀)活动示例
- 进阶篇十 某大型项目应用本Redis类源码示例(含事务 乐观锁)
- 进阶篇十一 逻辑层的应用
- 逻辑层基类源码
- 进阶篇 服务层代码示例
- 高阶实战课程 进阶篇持续新增中
- 高阶篇一 TP5命令行之守护任务源码
- TP5实战源码 --- 命令行
- TP5实战源码 --- 通过shell建立PHP守护程序
- 高阶篇二 使用Redis队列发送微信模版消息
- 高阶篇二 之 Worker队列基类源码
- 高阶篇三 TP5实战之Redis缓存应用
- Redis实战源码之Hash专用类库源码
- Redis实战源码之Model类结合
- Redis实战源码之模型Hash基类源码
- Redis实战源码之Hash查询使用技巧
- Redis实战源码之 shell脚本中redis赋值和取值
- 高阶篇四 Swoole的实战应用
- swoole基类代码
- Swoole扩展WebsocketServer专用类
- 基于Swoole的多Room聊天室的程序
- Swoole守护服务shell源码
- 高阶篇五 命令行异步多进程队列类的应用
- tp_worker类源码
- WorkerBase
- WorkerCommand
- WorkerRedis
- Redis类
- CycleWorkBase
- WorkerHookBase异步钩子
- 队列日志SQL
- 高阶篇六 定时执行队列类库以及使用方法
- 定时队列类库源码
- 高阶篇七 异步执行循环队列类库以及使用教程
- CycleWorkBase源码
- 高阶实战课程 进阶篇持续新增中
- Extend便捷类库源码库
- 阿里相关类库
- SendSms--验证码API接口文件
- 权限相关类库目录
- AuthWeb 权限验证类库
- Redis便捷操作类库(20171224更新)
- Redis
- Tools工具类库集
- Curl类库
- DataEdit
- Rand类库
- ShowCode类库
- Upload类库
- 附件集合
- 附件一:微信支付 实战开发源码
- 微信支付类库源代码
- Common_util_pub.php
- DownloadBill_pub.php
- JsApi_pub.php
- NativeCall_pub.php
- NativeLink_pub.php
- OrderQuery_pub.php
- Refund_pub.php
- RefundQuery_pub.php
- SDKRuntimeException.php
- ShortUrl_pub.php
- UnifiedOrder_pub.php
- Wxpay_client_pub.php
- Wxpay_server_pub.php
- WxPayConf_pub.php
- 微信支付回调页面源码
- 附件二 顺丰快递BSP接口实战开发源码
- 顺丰快递BSP接口实战开发源码
- 顺丰BSP基类
- 顺丰BSP基础代码
- 顺丰BSP下单接口
- 顺丰BSP查单接口
- 顺丰BSP确认/取消接口
- 附件三 APP注册登陆接口源码(含融云平台接口)
- 附件四 TP5订单Model(含事务 获取器 修改器等方法)
- 附录五 RSA加密解密
- Rsa文件源码
- 附件六 阿里大于短信接口
- 附件七 AES加解密类
- AES加解密类源码
- 附件八 TP5路由设置源码
- 附件九 TP5 Excel导入导出下载便捷类库
- Excel类库TP5源码
- 附件十 TP5便捷操作Redis类库源码
- TP5源码 Redis操作便捷类库
- 附件十一 TP5源码 上传文件入库类源码
- 上传类Upload源码
- Upload类上传配置文件
- 存储图像文件的数据库SQL文件
- 存储文件的数据库SQL文件
- 附件十二 TP5 图片处理增强类 支持缩略图在线显示
- 附件十三 微信推送消息接口类库源码
- 附件十三 微信推送消息接口类库源码 之 基类
- 附件十四 存储微信昵称的处理方法