Android studio打包uniapp插件

news2025/4/22 18:21:26

一.参考资料与环境准备

  • 原生工程配置
  • 需要使用到Android studio和HbuilderX
    • 当前测试的as版本-20240301,下载地址:
    • HbuilderX版本:4.36

二.插件创建流程

  • 1.导入下载的UniPlugin-Hello-AS工程(下载地址见参考资料)
    在这里插入图片描述

  • 2.生成jks证书

    • 2.1.通过命令行生成jsk证书,假设jks名称为myjks,则输入以下命令
    keytool -genkeypair -alias myjks -keyalg RSA -keystore myjks.keystore -keysize 2048 -validity 36500 -sigalg SHA256withRSA
    
    • 2.2.将证书格式转一下
    keytool -importkeystore -srckeystore myjks.keystore -srcstoretype PKCS12 -deststoretype JKS -destkeystore myjks.jks
    
  • 使用命令获取SHA1和SHA256两个值(下方第三步中会使用到)

    keytool -list -v -keystore myjks.jks
    
  • 3.在uniapp后台添加离线打包的配置

    • 在后台选择使用HbuilderX创建的项目,选择“离线打包Key管理”,按照下图方式进行配置
      在这里插入图片描述

    • 保存之后选择“创建离线key”,记录生成的key为Android对应的value的值
      在这里插入图片描述

  • 4.打包本地资源
    在这里插入图片描述

    • 将生成的本地资源放入文件夹中(UniPlugin-Hello-AS\app\src\main\assets\apps)
  • 5.删除UniPlugin-Hello-AS自带的module,新建一个module(假设取名为mylibrary)

    • 5.1.更改mylibrary的内容,添加文件
      在这里插入图片描述

    • 5.2.更改mylibrary的build.gradle中内容,

    plugins {
      id 'com.android.library'
    }
    
    android {
      compileSdkVersion 35
      namespace 'com.example.mylibrary'
      defaultConfig {
          minSdk 24
          ndk {
              moduleName "NDK"
              abiFilters 'armeabi', 'x86', 'armeabi-v7a', 'x86_64', 'arm64-v8a'
          }
          testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
          consumerProguardFiles "consumer-rules.pro"
      }
    
      buildTypes {
          release {
              minifyEnabled false
              proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
          }
      }
      compileOptions {
          sourceCompatibility JavaVersion.VERSION_11
          targetCompatibility JavaVersion.VERSION_11
      }
      sourceSets {
          main {
              jni.srcDirs = ['libs']
              jni.srcDirs = ['src/main/jniLibs']
              jniLibs.srcDir 'src/main/jniLibs'
          }
    
      }
    }
    
    dependencies {
      implementation files('src\\libs\\AclasDriverSdk.jar')
      implementation files('src\\libs\\LABLE_USB_SDK_V01.08.jar')
      implementation files('src\\libs\\NeoStraElectronicSDK-3-v1.3_2302281129.jar')
      implementation files('src\\libs\\zxing.jar')
    
      compileOnly fileTree(dir: 'libs', include: ['*.jar'])
      compileOnly fileTree(dir: '../app/libs', include: ['uniapp-v8-release.aar'])
    
    //    compileOnly 'androidx.recyclerview:recyclerview:1.0.0'
    //    compileOnly 'androidx.legacy:legacy-support-v4:1.0.0'
      compileOnly 'androidx.appcompat:appcompat:1.6.1'
      implementation 'com.alibaba:fastjson:1.2.83'
      implementation 'com.facebook.fresco:fresco:1.13.0'
      implementation 'com.github.bumptech.glide:glide:4.16.0'
    
      implementation 'androidx.appcompat:appcompat:1.6.1'
      implementation 'com.google.android.material:material:1.10.0'
      testImplementation 'junit:junit:4.13.2'
      androidTestImplementation 'androidx.test.ext:junit:1.1.5'
      androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1'
    }
    
  • 6.开始写自定义插件的逻辑

    • 新建Java文件, MyPlug.java,文件中定义的两个方法init和printInfo可以由uniapp项目进行调用,后续说明
    public class MyPlug extends UniModule {
      //定义方法一,uniapp项目调用不需要传递参数
      @UniJSMethod
      public void init(UniJSCallback callback) {
          JSONObject data = new JSONObject();
          data.put("code", "success");
          data.put("data", "操作成功");
          callback.invoke(data);
      }
    
      //定义方法二,uniapp项目调用可以传递参数
      @UniJSMethod
      public void printInfo(int markType, String width, String height, String jsonInfo, UniJSCallback callback) throws IOException {
          JSONObject data = new JSONObject();
          data.put("code", "success");
          data.put("data", "操作成功");
          callback.invoke(data);
      }
    }
    
  • 7.更改\UniPlugin-Hello-AS\app\src\main\AndroidManifest.xml中的内容

    将<meta-data
            android:name="dcloud_appkey"
            android:value="开发者需登录https://dev.dcloud.net.cn/申请签名" />
    更改成        
    <meta-data
            android:name="dcloud_appkey"
            android:value="78b2a45f4274af99fa17d63615458ecd" />
    
  • 8.更改\UniPlugin-Hello-AS\app\src\build.gradle中的内容

    applicationId "www.test555.com"	//更改1,www.test555.com为在uniapp后台配置的包名
    //signingConfigs中的jks替换成自己生成的
    signingConfigs {
        config {
            keyAlias 'myjks'
            keyPassword '123456'
            storeFile file('myjks.jks')
            storePassword '123456'
            v1SigningEnabled true
            v2SigningEnabled true
        }
    }
    
    // 添加uni-app插件
    dependencies {
      //...
      // 添加uni-app插件
      implementation project(':mylibrary')
    }
    
  • 9.更改\UniPlugin-Hello-AS\app\src\main\assets\dcloud_uniplugins.json中的内容

{
  "nativePlugins": [
    {
      "hooksClass": "",
      "plugins": [
        {
          "type": "module",
          "name": "testPlug",
          "class": "com.example.mylibrary.MyPlug"
        }
      ]
    }
  ]
}
  • 10.更改\UniPlugin-Hello-AS\app\src\main\data__UNI__F089EA2\dcloud_control.xml中的内容
<hbuilder>
<apps>
    <app appid="__UNI__F089EA2" appver=""/>
</apps>
</hbuilder>

  • 11.使用Android studio 生成mylibrary的arr文件
    在这里插入图片描述

  • 12.uniapp项目引入插件

    • 按照截图的格式创建好文件夹和对应的文件(保持名称一致)
      在这里插入图片描述

    • package.json的配置如下

    {
      "name": "testPlug",
      "id": "testPlug",
      "version": "1",
      "description": "这里是描述",
      "_dp_type":"nativeplugin",
      "_dp_nativeplugin":{
          "android": {
              "plugins": [
                  {
                      "type": "module",
                      "name": "testPlug",
                      "class": "com.example.mylibrary.MyPlug"
                  }
              ],
              "integrateType": "aar",
              "dependencies": [],
              "compileOptions": {  
                  "sourceCompatibility": "11",
                  "targetCompatibility": "11"
              },
              "minSdkVersion": "24"
          }
      }
    }
    
    • 将11中生成的arr文件放入到nativeplugins\testPlug\android文件夹下
    • uniapp项目要添加本地插件的依赖
  • 13.uniapp项目使用插件

<template>
	<view style="margin: 80rpx 20rpx;">
		<div style="margin-top: 15rpx;">
			<button type="primary" @click="test1">领料标签</button>
		</div>
	</view>
</template>

<script>
	// 1.引入插件
	let testPlugModule = uni.requireNativePlugin("testPlug")
	export default {
		data() {
			return {
				title: 'Hello'
			}
		},
		onLoad() {
			this.inits();
		},
		methods: {
			inits() {
            	//2.调用插件方法,不传递参数
				testPlugModule.init((res) => {
					uni.showToast({
						title: res.data,
						icon: "none"
					})
				})
			},
			test1() {
				//缺少原料字段
				var beanInfo1 = {
					itemId: "12345678",
					itemCode: "999",
					itemName: "毛豆",
					itemBarcode: "0123456789",
					chargeBy: "王德发"
				}
				var jsonBean = JSON.stringify(beanInfo1);
				console.log("查看参数信息 jsonBean = ", jsonBean)
			
				this.info1 = jsonBean
                //3.调用插件方法,传递参数
				testPlugModule.printInfo(1,this.width,this.height, jsonBean, (res) => {
					uni.showToast({
						title: res.data,
						icon: "none"
					})
				})
			},
		}
	}
</script>

<style>
	.content {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}

	.logo {
		height: 200rpx;
		width: 200rpx;
		margin-top: 200rpx;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 50rpx;
	}

	.text-area {
		display: flex;
		justify-content: center;
	}

	.title {
		font-size: 36rpx;
		color: #8f8f94;
	}
</style>

  • 14.重新执行步骤4,然后测试
    在这里插入图片描述

三.总结

  • 按照上方流程则可以实现uniapp调用安卓原生插件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2334531.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

App Cleaner Pro for Mac 中 Mac软件卸载工具

App Cleaner Pro for Mac 中 Mac软件卸载工具 一、介绍 App Cleaner & Uninstaller Pro Mac破解&#xff0c;是一款Mac软件卸载工具&#xff0c;残余垃圾清除工具&#xff01;可以卸载应用程序或只删除不需要的服务文件&#xff0c;甚至可以删除以前删除的应用程序中的文…

开发规范——Restful风格

目录 Restful Apifox 介绍 端口号8080怎么来的&#xff1f; 为什么要使用Apifox? Restful 如果请求方式是Post&#xff0c;那我就知道了要执行新增操作&#xff0c;要新增一个用户 如果请求方式是Put&#xff0c;那就代表我要修改用户 具体要对这些资源进行什么样的操…

大模型——Llama Stack快速入门 部署构建AI大模型指南

Llama Stack快速入门 部署构建AI大模型指南 介绍 Llama Stack 是一组标准化和有主见的接口,用于如何构建规范的工具链组件(微调、合成数据生成)和代理应用程序。我们希望这些接口能够在整个生态系统中得到采用,这将有助于更轻松地实现互操作性。 Llama Stack 定义并标准化…

利用阿里云企业邮箱服务实现Python群发邮件

目录 一、阿里云企业邮箱群发邮件全流程实现 1. 准备工作与环境配置 2. 收件人列表管理 3. 邮件内容构建 4. 附件添加实现 5. 邮件发送核心逻辑 二、开发过程中遇到的问题与解决方案 1. 附件发送失败问题 2. 中文文件名乱码问题 3. 企业邮箱认证失败 三、完整工作流…

08-JVM 面试题-mk

文章目录 1.JVM 的各部分组成2.运行时数据区2.1.什么是程序计数器?2.2.你能给我详细的介绍Java堆吗?2.3.能不能解释一下方法区?2.3.1常量池2.3.2.运行时常量池2.4.什么是虚拟机栈?2.4.1.垃圾回收是否涉及栈内存?2.4.2.栈内存分配越大越好吗?2.4.3.方法内的局部变量是否线…

PostgreSQL技术大讲堂 - 第86讲:数据安全之--data_checksums天使与魔鬼

PostgreSQL技术大讲堂 - 第86讲&#xff0c;主题&#xff1a;数据安全之--data_checksums天使与魔鬼 1、data_checksums特性 2、避开DML规则&#xff0c;嫁接非法数据并合法化 3、避开约束规则&#xff0c;嫁接非法数据到表中 4、避开数据检查&#xff0c;读取坏块中的数据…

从宇树摇操avp_teleoperate到unitree_IL_lerobot:如何基于宇树人形进行二次开发(含Open-TeleVision源码解析)

前言 如之前的文章所述&#xff0c;我司「七月在线」正在并行开发多个订单&#xff0c;目前正在全力做好每一个订单&#xff0c;因为保密协议的原因&#xff0c;暂时没法拿出太多细节出来分享 ​但可以持续解读我们所创新改造或二次开发的对象&#xff0c;即解读paper和开源库…

告别 ifconfig:为什么现代 Linux 系统推荐使用 ip 命令

告别 ifconfig&#xff1a;为什么现代 Linux 系统推荐使用 ip 命令 ifconfig 指令已经被视为过时的工具&#xff0c;不再是查看和配置网络接口的推荐方式。 与 netstat 被 ss 替代类似。 本文简要介绍 ip addr 命令的使用 简介ip ifconfig 属于 net-tools 包&#xff0c;这个…

MySQL——MVCC(多版本并发控制)

目录 1.MVCC多版本并发控制的一些基本概念 MVCC实现原理 记录中的隐藏字段 undo log undo log 版本链 ReadView 数据访问规则 具体实现逻辑 总结 1.MVCC多版本并发控制的一些基本概念 当前读&#xff1a;该取的是记录的最新版本&#xff0c;读取时还要保证其他并发事务…

Gateway-网关-分布式服务部署

前言 什么是API⽹关 API⽹关(简称⽹关)也是⼀个服务, 通常是后端服务的唯⼀⼊⼝. 它的定义类似设计模式中的Facade模式(⻔⾯模式, 也称外观模式). 它就类似整个微服务架构的⻔⾯, 所有的外部客⼾端访问, 都需要经过它来进⾏调度和过滤. 常⻅⽹关实现 Spring Cloud Gateway&a…

Docker部署MySQL大小写不敏感配置与数据迁移实战20250409

Docker部署MySQL大小写不敏感配置与数据迁移实战 &#x1f9ed; 引言 在企业实际应用中&#xff0c;尤其是使用Java、Hibernate等框架开发的系统&#xff0c;MySQL默认的大小写敏感特性容易引发各种兼容性问题。特别是在Linux系统中部署Docker版MySQL时&#xff0c;默认行为可…

面试题之网络相关

最近开始面试了&#xff0c;410面试了一家公司 问了我几个网络相关的问题&#xff0c;我都不会&#xff01;&#xff01;现在来恶补一下&#xff0c;整理到博客中&#xff0c;好难记啊&#xff0c;虽然整理下来了。在这里先祝愿大家在现有公司好好沉淀&#xff0c;定位好自己的…

[春秋云镜] Tsclient仿真场景

文章目录 靶标介绍&#xff1a;外网mssql弱口令SweetPotato提权上线CSCS注入在线用户进程上线 内网chisel搭建代理密码喷洒攻击映像劫持 -- 放大镜提权krbrelayup提权Dcsync 参考文章 考点: mssql弱口令SweetPotato提权CS注入在线用户进程上线共享文件CS不出网转发上线密码喷洒…

数据集 handpose_x_plus 3D RGB 三维手势 - 手工绘画 场景 draw picture

数据集 handpose 相关项目地址&#xff1a;https://github.com/XIAN-HHappy/handpose_x_plus 样例数据下载地址&#xff1a;数据集handpose-x-plus3DRGB三维手势-手工绘画场景drawpicture资源-CSDN文库

deskflow使用教程:一个可以让两台电脑鼠标键盘截图剪贴板共同使用的开源项目

首先去开源网站下载&#xff1a;Release v1.21.2 deskflow/deskflow 两台电脑都要下载这个文件 下载好后直接打开找到你想要的exe desflow.exe 然后你打开他&#xff0c;将两台电脑的TLS都关掉 下面步骤两台电脑都要完成&#xff1a; 电脑点开edit-》preferences 把这个取…

详解MYSQL表空间

目录 表空间文件 表空间文件结构 行格式 Compact 行格式 变长字段列表 NULL值列表 记录头信息 列数据 溢出页 数据页 当我们使用MYSQL存储数据时&#xff0c;数据是如何被组织起来的&#xff1f;索引又是如何组织的&#xff1f;在本文我们将会解答这些问题。 表空间文…

[Windows] 音速启动 1.0.0.0

[Windows] 音速启动 链接&#xff1a;https://pan.xunlei.com/s/VONiGZhtsxpPzze0lDIH-mR9A1?pwdxu7f# [Windows] 音速启动 1.0.0.0 音速启动是一款桌面管理软件&#xff0c;以仿真QQ界面的形式结合桌面工具的特点&#xff0c;应用于软件文件夹网址的快捷操作。

Hyper-V 虚拟机配置静态IP并且映射到局域网使用

环境 win11hyper-v麒麟v10 配置 编辑文件 vi /etc/sysconfig/network-scripts/ifcfg-eth0文件内容 GATEWAY 需要参考网络中配置的网关地址 TYPEEthernet PROXY_METHODnone BROWSER_ONLYno BOOTPROTOstatic DEFROUTEyes IPV4_FAILURE_FATALno IPV6INITyes IPV6_AUTOCONFyes …

操作系统基础:06 操作系统历史

我们前面已经讲过了操作系统的基本轮廓、启动过程以及系统调用等相关内容&#xff0c;就如同揭开了钢琴的盖子&#xff0c;对操作系统有了初步的表面认识。从现在起&#xff0c;我们要更深入地剖析操作系统&#xff0c;就像分解钢琴一样&#xff0c;探究其各个部分的构成、原理…

【大模型微调】如何解决llamaFactory微调效果与vllm部署效果不一致如何解决

以下个人没整理太全 一、生成式语言模型的对话模板介绍 使用Qwen/Qwen1.5-0.5B-Chat训练 对话模板不一样。回答的内容就会不一样。 我们可以看到例如qwen模型的tokenizer_config.json文件&#xff0c;就可以看到对话模板&#xff0c;一般同系列的模型&#xff0c;模板基本都…