Android studio打包uniapp插件

一.参考资料与环境准备

二.插件创建流程

  • 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;">
    <button type="primary" @click="test1">领料标签</button>
    </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调用安卓原生插件。
相关推荐
堕落年代11 小时前
Uniapp当中的async/await的作用
前端·javascript·uni-app
堕落年代12 小时前
Uniapp使用onShow语法报before initialization
uni-app
大叔_爱编程12 小时前
wx212基于ssm+vue+uniapp的科创微应用平台小程序
vue.js·小程序·uni-app·毕业设计·ssm·课程设计·科创微应用平台小程序
前端开发呀17 小时前
无所不能的uniapp拦截器
前端·uni-app
weixin_4435664719 小时前
uniapp离线打包提示未添加videoplayer模块
uni-app
快起来搬砖了1 天前
UniApp 页面布局自定义头部导航
前端·javascript·uni-app
zhangyao9403301 天前
uniapp uni-collapse动态切换数据时高度不能自适应
uni-app
老李不敲代码1 天前
榕壹云门店管理系统:基于Spring Boot+Mysql+UniApp的智慧解决方案
spring boot·后端·mysql·微信小程序·小程序·uni-app·软件需求
家里有只小肥猫1 天前
uniApp 设置动态tabs(不是自定义tab哈)
前端·javascript·uni-app