不飞则已,一飞冲天;不鸣则已,一鸣惊人。这篇文章主要讲述Ionic2 + cordova + angular2 打包Android APP环境搭建相关的知识,希望能为你提供帮助。
一、前言
前段时间,公司有个APP项目需要支持不同平台,于是采用了Ionic2 + cordova + angular2,在搭建环境过程中遇到了不少问题,刚好最近有时间整理出来。
二、开发环境搭建
参考这个网站步骤搭建:https://github.com/DonaldTdz/Ionic2QuickStart
注意:nodejs 要装6.0 +LTS最新版,不要装8.X的最新版本(https://nodejs.org/en/)
文章图片
Cordova版本要安装6.X版本,目前cordova-android版本最高只能支持到6.X.X
cmd: cnpm install –g ionic cordova@6.x
cmd: ionic –v Cordova –v 查看显示版本号,安装成功
文章图片
文章图片
三、运行一个ionic种子项目
下载地址:https://github.com/DonaldTdz/ionic-seed
用vs code打开终端输入命令:cnpm install
文章图片
Ionic serve 运行项目
文章图片
Web端运行项目成功,开发环境搭建完成
文章图片
下面我们开始打包到Android APP
四、Cordova打包Android平台环境搭建
参考官方说明:
(中文)http://cordova.axuer.com/docs/zh-cn/latest/guide/platforms/android/index.html
(英文)http://cordova.apache.org/docs/en/latest/guide/platforms/android/index.html
注:中文网址信息不是最新,访问速度比较快,英文更新到最新,但访问速度较慢
1、安装Java SDK
java开发工具包(JDK)
安装Java Development Kit (JDK) 7或者最新的。
当在Windows上安装的时候需要根据JDK路径设置
JAVA_HOME
环境变量(参见设置环境变量)文章图片
cmd:Java –version 显示版本号安装成功
文章图片
Java SDK环境变量配置
JAVA_HOME 配置安装目录
文章图片
Path配置:%JAVA_HOME%\\bin
文章图片
添加CLASSPATH : .; %JAVA_HOME%\\lib; (注:如存在这个环境变量,需要检查)
文章图片
2、安装Android SDK Tools
(注:如果需要添加cordova插件,建议安装Android Studio)
Android SDK安装Android Stand-alone SDK或者Android Studio。如果你计划开发一个新的Cordova Android插件或者使用Android平台原生的工具去运行和调试,那么就使用Android Studio吧。否则,Android Stand-alone SDK Tools就足够构建和部署Android应用程序了。
详细的安装说明可以点击上面的安装链接查看。
文章图片
文章图片
3、添加Android SDK包
添加SDK包在安装完Android SDK后,你需要安装任何你希望的目标API级别的SDK包。建议你安装cordova-android(参见上面)支持的最高级别的SDK包。
打开Android SDK Manager (例如,在终端上运行`android),并确保下面已经安装:
- 目标Android版本的Android Platform SDK
- Android SDK build-tools,版本19.1.0或者之上
- Android Support Repository (在"Extras"查找)
先打开刚下载的项目终端运行:cordova platform ls 查看cordova android依赖的android SDK版本
文章图片
对应下面列表依赖android API级别是16-25(http://cordova.apache.org/docs/en/latest/guide/platforms/android/index.html)
文章图片
然后下载对应的依赖包
文章图片
文章图片
文章图片
安装成功后配置环境变量
ANDROID_HOME:
D:\\Program Files\\Android\\android-sdk
文章图片
Path:
D:\\Program Files\\Android\\android-sdk\\platform-tools
D:\\Program Files\\Android\\android-sdk\\tools
文章图片
cmd:android –h 查看如下面表示安装成功
文章图片
五、打包Android APP
1、 添加Android平台
Ionic cordova platform add android
文章图片
文章图片
2、依赖gradle修改到本地
原因是国外网站打包运行时很慢或导致失败,你懂的
下载地址:https://services.gradle.org/distributions/
(注:如下载慢用下载工具如迅雷)
下载版本选择,先搜索distributions/gradle
文章图片
如下我们需要版本:gradle-2.14.1-all.zip,避免下错版本
文章图片
下载完成不用解压,直接拷贝到你项目的下面这个路径:
\\app\\platforms\\android\\gradle(注:如不存在需要建一个,注意拼写错误)
文章图片
打开刚搜索到的文件:\\platforms\\android\\cordova\\lib\\builders\\GradleBuilder.js
将原来的注释掉并修改为本地包../gradle-2.14.1-all.zip
文章图片
3、 打包应用
ionic cordova build android
文章图片
打包完成后会输出一个apk手机安装包文件
文章图片
安装到手机运行成功!!
文章图片
六、应用签名和启动优化
1、生成签名秘钥
签名一个应用首先你应该阅读Android应用签名所需。
使用标志
签名一个应用,你需要下面参数:
参数 | 标志 | 描述 |
---|---|---|
Keystore | --keystore |
用来存储一组key的二进制文件路径 |
Keystore Password | --storePassword |
keystore存储密钥 |
Alias | --alias |
用来指定私有key用来签名 |
Password | --password |
私有key的密码 |
Keystore的类型 | --keystoreType |
默认: 自动检测基于文件扩展名 pkcs12或者jks |
build
或者 run
命令来指定命令行参数。注意: 你应该使用两个中划线
--
来表示这些平台特定参数,例如:cordova run android --release -- --keystore=../my-release-key.keystore --storePassword=password --alias=alias_name --password=password
.cmd 到目录:D:\\projects\\dev\\tz\\saas\\app\\platforms\\android(android平台根目录)
cmd:keytool -genkey -alias tzky.keystore -keyalg RSA -validity 40000 -keystore tzky.keystore
根据输入提示完成输入,生成成功后刷新android平台根目录
文章图片
2、签名应用并打包
cordova build android --release -- --keystore="..\\tzky.keystore" --storePassword=xxxxx --alias=tzky.keystore
(注:自动生成打包配置文件release-signing.properties需要注意tzky.keystore的放置路径要匹配)
手动添加release-signing.properties文件并修改:
文章图片
添加完成后直接运行:cordova build android –release
【Ionic2 + cordova + angular2 打包Android APP环境搭建】
文章图片
文章图片
3、优化启动速度
ionic cordova build android --prod –release
(注意:需要代码优化,如果有错误,根据错误提示修改)
启动优化参考:http://blog.csdn.net/u010564430/article/details/61201769
在config.xml文件中添加如下内容:
< preference name="AutoHideSplashScreen" value="https://www.songbingjia.com/android/false" />
< preference name="FadeSplashScreenDuration" value="https://www.songbingjia.com/android/1000" />
< preference name="SplashScreen" value="https://www.songbingjia.com/android/screen" />
< preference name="ShowSplashScreen" value="https://www.songbingjia.com/android/true" />
< preference name="ShowSplashScreenSpinner" value="https://www.songbingjia.com/android/false" />
< preference name="SplashShowOnlyFirstTime" value="https://www.songbingjia.com/android/false" />
< preference name="FadeSplashScreen" value="https://www.songbingjia.com/android/true" />
推荐阅读
- 安卓Broadcast Receiver(广播消息)应用实例
- Android应用程序访问linux驱动第一步(实现并测试Linux驱动)
- apply()与call()的区别
- Android 解决小米手机Android Studio安装app 报错的问题It is possible that this issue is resolved by uninstalling an
- 全面解读商城购物app开发的开发市场现状
- Android Studio 常用快捷键 for mac
- app 安全测试概览
- JavaFX进度指示器
- JavaFX ProgressBar