百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Uni-app离线打包Android APK详细教程

haoteby 2025-01-09 12:59 1 浏览

一、 准备工作

1、安装JDK,下载地址(可能需要一个oracle账号,大家百度一下或者自行注册一个就行。尽可能选择8或者11,这两个是长期版本)Java SE | Oracle Technology Network | Oracle

2、安装NodeJS,下载地址Node.js (nodejs.org)

3、下载安装Android Studio,下载地址Download Android Studio and SDK tools | Android Developers (google.cn)

4、下载安装HbuilderX HBuilderX-高效极客技巧 (dcloud.io)

5、申请DCloud开发者账号,后期会用到

6、下载离线工程:App离线打包SDK (dcloud.net.cn) ,后期会用到


二、 正式开发及配置

1、 在HbuilderX中新建一个uni-app项目,找到manifset.json这个文件,需要修改的地方

基础配置:有一个AppID,如果没有点击重新获取,或者去DCloud开发者中心创建一个应用后填写此处(源码编辑)

模块配置:勾选需要的模块,一般来说需要什么勾选什么即可

权限配置:关于这一块,大家需要去参考这篇文章(https://ask.dcloud.net.cn/article/36982)

2、去掉HTML5+ Runtime版本提示框,在源码视图中添加以下内容

3、附加:如果是要打包成AAB上传谷歌商店你需要勾选以下内容,同时需要编辑生成的json文件

OK,到这里基础配置基本结束开始你的业务编写即可。

三、 离线打包工程配置及打包

1、 打包所需要的资源:在HbuilderX中,发行=》原生APP本地打包=》生成本地打包APP资源,将生成后的目录(**/APP_ID/www/**)拷贝(选择到APP_ID这个文件夹即可)

2、 解压离线工程至某个目录下,即:**/Android-SDK3.2.12.81096_20211101/HBuilder-Integrate-AS,打开Android Studio,导入此项目(HBuilder-Integrate-AS)

3、 修改simpleDemo/build.gradle配置(密钥签名请跳转第四步骤)

4、 修改simpleDemo/main/AndroidManifest.xml配置,如果是特殊的权限,需要在这个文件中添加对应的权限配置(android key请跳转第四步骤)

5、 修改simpleDemo/ main/res/values/strings.xml配置

6、 修改simpleDemo/ main/res/drawable配置,替换图标LOGO、开屏页

7、 修改simpleDemo/ main/assets/data/dcloud_control.xml配置

8、 修改simpleDemo/ main/assets/data/dcloud_properties.xml配置(去掉HTML5+ Runtime oauth提示)

至此,离线打包项目配置完毕,然后执行:Build=》Build Bundle(s) / APK(s)=》Build APK(s)。打包完毕

四、 签名生成及配置

签名生成:

签名方案一:在Android Studio中依次按照以下截图即可(我在windows中遇到了无法签名的情况,Mac正常,如果你也是,请看方案二)

签名方案二:参考文章(Android平台签名证书(.keystore)生成指南 - DCloud问答

)解决windows无法生成签名的情况,Mac可以直接跳过步骤1

注:如果是windows10,请勿使用cmd,请在系统图标即WIN上右键,运行powershell(管理员),用这个命令窗执行以下命令,否则无效。

1、设置jdk变量 set PATH=%PATH%;"C:\Program Files\Java\jre1.8.0_201\bin"(路径根据jdk安装目录改变,但是必须指定到jre中去) 
2、生成签名文件(如果不是在项目目录下生成的,需要将生成的文件拷贝到simpleDemo目录下)
keytool -genkey -alias testalias -keyalg RSA -keysize 2048 -validity 36500 -keystore test.keystore 
3、查看签名信息 keytool -list -v -keystore test.keystore   Enter keystore password: //输入密码,回车 
4、复制以下两个信息 Alias name + SHA1

android key生成:

进入dcloud开发者后台(https://dev.dcloud.net.cn/)登录自己的账号

应用管理=》我创建的应用=》应用列表=》点击应用名称=》离线打包KEY管理=》填写保存后,复制android对应的值即可

相关推荐

用户界面干货盘点

为了解决大家找资源难的问题,EVGET特别开辟每周盘点用户界面干货的专栏,一网打尽热门的界面资讯、Demo示例、版本升级及下载、移动Web开发,以及各种UI神器推荐。更多资源及工具也可以在用户界面专题...

不仅仅是创意,26款科技小玩意

新科技不断在卖场出现,总是吸引着消费者的眼球。许多很棒的科技小玩意儿被发明,手机、平板、手提电脑、游戏主机、甚至是3D打印都适用。现在的初创公司已经发正在让21世纪打破各种科技壁垒障碍。本文收集26...

FastReport.Net报表设计器如何连接到SQLCe

MicrosoftSQLServerCompactEdition是一个简单的本地关系数据库,不需要安装,并且已与数据库文件建立连接。您不需要管理员权限即可使用基础功能。您也只能“密码”基础功能...

2015年最值得关注的8款用户界面新品

软件界面开发解决方案这一块一直以来是慧都控件(EVGET)的强项,我们有400多款用户界面产品,250多款图表报表产品,此外还提供专业的软件界面定制开发服务,其中DevExpress定制开发、甘特图定...

小贴士:安装TBarCode office的注意事项和相关资源

TBarCodeoffice是一款适用于MicrosoftWord2007、2010等版本,具有强大功能的条码插件。在这里我们介绍一下安装TBarCodeoffice的注意事项和相关资源。安装...

初学者不容错过的修复Bug小技巧

Bug的发生,我想这是每个开发人员几乎每天都要面对的问题,包括历史上非常有名的编程人员,他们依旧要面对Bug。成为一个熟练的程序员并不意味着永远不会犯错误,而是擅于发现错误并能很好地修正错误。当你刚开...

【推荐】一款基于 .NET 开源的支持多厂区、多项目级的MOM/MES系统

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍tmom是一款基于.NET开源、通用的生产制造系统,支持多厂区/多项目级的MOM/MES系统,计划排程...

你不可不知的10个Github功能

Github让全世界的开发人员、设计人员可以在一起工作交流。Github不仅提供大量开源项目、编程语言代码,他也发布过Windows和OSX桌面应用,可以让我们在工作中无缝集成Github。...

Fastreport.Net用户手册(十四):文本编辑

编辑对象的文本,只需双击文本内容,然后会弹出一个文本编辑器。在编辑器右方有一个可以添加至文本中的数据树组件。可以通过鼠标拖拽该组件到需要的地方。在文本中嵌入该组件的另一个方法是双击该组件,然后该组件将...

火狐浏览器开发者专版上手体验

当Mozilla宣布FirefoxDeveloperEdition,我想不少开发者都很高兴,因为第一个大型开发者专用浏览器诞生了。既然是开发者专用版,那么和普通版本肯定是不一样的。早已经迫不及待...

FastReport.Net 2015.3.3 优化了报表解析器

FastReport.Net2015.3.3于近日正式发布。点击FastReport.Net2015.3.3下载试用FastReport.Net最新版本。[Core][Exports]重写保存在...

改变上网体验:10个超赞的Google Chrome扩展

你使用谷歌浏览器浏览网页吗?其实,全世界数以百万的用户都喜欢使用GoogleChrome浏览网页,这也促使其成为全球使用量第二大的Web浏览器。GoogleChrome浏览器具有快速、干净的页面,...

如何在 FastReport Online Designer 中处理报表的 5 个函数

FastReports产品的时代并没有停滞不前。每个月都会添加新的函数和对象,并改进和优化当前的代码。FastReportOnlineDesigner...

Winform应用界面开发技术特点图解

整理一下自己之前的Winform开发要点,以图文的方式展示一些关键性的技术特点,总结一下。...

跨平台的可视化Web报表设计器-FastReport Online Designer

好消息!FastReportOnlineDesigner现在作为一个独立的应用程序发布啦!此前作为FastReport.Net的专业版的一部分的在线设计测试版,现在可以单独或作为FastRepor...