autojs之阿里-对象存储OSS-SDK的使用

2024-01-14 13:48

本文主要是介绍autojs之阿里-对象存储OSS-SDK的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用场景

autojs使用阿里云对象存储OSS

效果展示

  1. 上传文件
    在这里插入图片描述

  2. 对象存储中上传的文件

在这里插入图片描述

原理

  1. 安卓跑通对象存储的SDK, 导出dex

  2. autojs使用dex, 就可以使用对象存储

对象存储官方文档

https://help.aliyun.com/document_detail/32042.html?spm=a2c4g.11186623.6.1315.28d246a1Z7rNFy

知识点

  1. 安卓申请读写sd卡权限
  2. AndroidManifest.xml 添加权限
  3. 网络安全配置允许明文传输
  4. 权限申请回调
  5. 创建子线程执行网络操作
  6. accessKeyId, String secretKeyId, String securityToken的获取
  7. 多个dex合并为一个dex, 不合并dex的话, 会出错

代码讲解

  1. 安卓申请读写sd卡权限

    ActivityCompat.requestPermissions(this, PERMISSIONS_STORAGE, REQUEST_EXTERNAL_STORAGE);
    
  2. AndroidManifest.xml 添加权限

    android:networkSecurityConfig="@xml/network_security_config"
    
  3. 网络明文传输network_security_config.xml

    <?xml version="1.0" encoding="utf-8"?>
    <network-security-config><base-config cleartextTrafficPermitted="true" />
    </network-security-config>
    
  4. 创建子线程执行网络操作

    new Thread(new Runnable() {public void run() {}
    })
    
  5. accessKeyId, String secretKeyId, String securityToken的获取

    // npm install @alicloud/pop-core --save
    const Core = require("@alicloud/pop-core");//构建一个阿里云客户端, 用于发起请求。
    //构建阿里云客户端时,需要设置AccessKey ID和AccessKey Secret。
    var client = new Core({accessKeyId: "xxx",accessKeySecret: "xxx",endpoint: "https://sts.aliyuncs.com",apiVersion: "2015-04-01",
    });//设置参数。
    var params = {RegionId: "cn-beijing",RoleArn: "acs:ram::188xxx",RoleSessionName: "external-username",
    };var requestOption = {method: "POST",
    };//发起请求,并得到响应。
    client.request("AssumeRole", params, requestOption).then((result) => {console.log(JSON.stringify(result));},(ex) => {console.log(ex);}
    );
  6. 多个dex合并为一个dex, 不合并dex的话, 会出错

    手机上用mt管理器合并两个dex文件

  7. build.gradle

    dependencies {...implementation group: 'com.squareup.okhttp3', name: 'okhttp', version: '4.9.0'implementation  'com.aliyun.dpa:oss-android-sdk:2.9.5'
    }
    
  8. gradle sync之后, 点击菜单中的 build / Make Moule
    dex文件位置: D:\script\asProject\UseAliOss\app\build\intermediates\dex\debug
    合并的两个dex文件就在这个文件夹里面

  9. 合并dex之后, aj就可以导入dex文件了

    let dexPath = files.path("classes_merge.dex");
    runtime.loadDex(dexPath);
    
  10. 上传文件

    credentialProvider = new OSSStsTokenCredentialProvider(ak, sk, token);
    conf = new ClientConfiguration();
    conf.setConnectionTimeout(15 * 1000); // 连接超时,默认15秒。
    conf.setSocketTimeout(15 * 1000); // socket超时,默认15秒。
    conf.setMaxConcurrentRequest(5); // 最大并发请求书,默认5个。
    conf.setMaxErrorRetry(2); // 失败后最大重试次数,默认2次。
    oss = new OSSClient(context, endpoint, credentialProvider, conf);
    let filepath = files.path("./project.json");
    put = new PutObjectRequest("autojs-test", "xxxxxxxxxxxxxxx", filepath);
    putResult = oss.putObject(put);
    

微信公众号 AutoJsPro教程

在这里插入图片描述

QQ群

747748653

完整源码

点击查看完整源码

这篇关于autojs之阿里-对象存储OSS-SDK的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/605366

相关文章

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

MySQL之InnoDB存储页的独立表空间解读

《MySQL之InnoDB存储页的独立表空间解读》:本文主要介绍MySQL之InnoDB存储页的独立表空间,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、独立表空间【1】表空间大小【2】区【3】组【4】段【5】区的类型【6】XDES Entry区结构【

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、