autojs使用阿里云oss上传文件

本文涉及的产品
对象存储 OSS,20GB 3个月
对象存储 OSS,恶意文件检测 1000次 1年
对象存储 OSS,内容安全 1000次 1年
简介: 牙叔教程 简单易懂

牙叔教程 简单易懂


autojs版本


8.8.20-0


访问阿里云oss官网


使用步骤


  1. 开通oss
  2. 创建bucket
  3. 上传文件


上传文件


网页可以直接上传文件,

显然写脚本不会用网页上传文件,

我们自然要用api来上传文件


身份识别


如果要用api来上传文件, 那么必然要有一个凭证,

你有什么资格上传文件, 这就涉及到了权限问题,

凭证一般指的是秘钥,

你不可能把你的秘钥给别人用, 对吧?


万一别人拿你的秘钥霍霍你的oss咋办?

万一删库跑路呢?


秘钥


阿里云oss有一个访问控制RAM,

我们可以创建一个RAM用户, 该用户可以被授予颗粒度非常细的权限,

比如我们只给他上传文件的权限,

不给他下载文件的权限, 也不给他删除文件的权限

我们只给ram用户最小的权限, 同时ram有自己的秘钥,

一定程度上, 这个秘钥可以被公开, 当然, 不公开最好

如果我们删除秘钥, 并且oss的文件设置为私有, 那么别人是下载不了我们的文件的,

只有拥有秘钥, 并且有下载权限, 才能下载文件


创建RAM用户


  1. 前往控制台


  1. 点击创建用户


  1. 填写名称, 选择api访问


  1. 记录ram用户的秘钥


  1. 返回用户页, 就能看见我们创建好的ram用户了


RAM权限


权限规则, 看懂之后, 还算简单,

同时官方提供了RAM策略编辑器, 这个策略我理解就是指的权限,


比如我们给RAM用户,

对bucket名字为autojs-study,

该bucket下的files文件夹,

设置允许上传文件的权限,

那么他就只能上传文件到files文件夹


(enablePath最好打勾)


授权策略例子


该策略是: 允许上传文件到名字为autojs-study的文件夹下的files文件夹

{
  "Version": "1",
  "Statement": [
    {
      "Effect": "Allow",
      "Action": [
        "oss:PutObject"
      ],
      "Resource": [
        "acs:oss:*:*:autojs-study/files/*"
      ],
      "Condition": {}
    },
    {
      "Effect": "Allow",
      "Action": [
        "oss:ListObjects"
      ],
      "Resource": [
        "acs:oss:*:*:autojs-study"
      ],
      "Condition": {
        "StringLike": {
          "oss:Prefix": [
            "",
            "files/*"
          ]
        },
        "StringEquals": {
          "oss:Delimiter": "/"
        }
      }
    }
  ]
}


新建自定义权限策略


  1. 点击创建权限策略



  1. 填写策略名字和策略内容, 内容就是上面刚用策略编辑器生成的策略


  1. 查看创建的策略


给RAM用户设置策略


  1. 点击添加权限


  1. 添加自定义权限


  1. 点击用户名


  1. 此处可以看见添加的策略


使用api方式上传文件

let dexPath = files.path("/storage/emulated/0/oss_classes_merge2.dex");
// 这个dex文件是从oss的androidSDK中提取出来的, 
// 只能使用sd卡的路径, 其他路径, 比如apk的内部路径会报错
// let dexPath = files.path("./oss_classes_merge2.dex");
runtime.loadDex(dexPath);
importClass(com.alibaba.sdk.android.oss.ClientConfiguration);
importClass(com.alibaba.sdk.android.oss.ClientException);
importClass(com.alibaba.sdk.android.oss.OSS);
importClass(com.alibaba.sdk.android.oss.OSSClient);
importClass(com.alibaba.sdk.android.oss.ServiceException);
importClass(com.alibaba.sdk.android.oss.common.auth.OSSCredentialProvider);
importClass(com.alibaba.sdk.android.oss.common.auth.OSSStsTokenCredentialProvider);
importClass(com.alibaba.sdk.android.oss.model.PutObjectRequest);
importClass(com.alibaba.sdk.android.oss.model.PutObjectResult);
let endpoint = "oss-cn-beijing.aliyuncs.com";
let ak = "LTAI5tNodPwPEMbPc1CnSBVb";
let sk = "v8uDRNAeWHfMULTtpTDuNTkWeJR33S";
let bucketName = "autojs-study";
let dirName = "files";
let fileName = "testFile";
let credentialProvider = new OSSStsTokenCredentialProvider(ak, sk, "");
log(credentialProvider);
let conf = new ClientConfiguration();
conf.setConnectionTimeout(15 * 1000); // 连接超时,默认15秒。
conf.setSocketTimeout(15 * 1000); // socket超时,默认15秒。
conf.setMaxConcurrentRequest(5); // 最大并发请求书,默认5个。
conf.setMaxErrorRetry(2); // 失败后最大重试次数,默认2次。
let oss = new OSSClient(context, endpoint, credentialProvider, conf);
let filepath = files.path("/storage/emulated/0/脚本/autojs-ali-oss/key.json");
log(filepath);
log(files.exists(filepath));
let put = new PutObjectRequest(bucketName, dirName + "/" + fileName, filepath);
putResult = oss.putObject(put);
log("PutObject", "UploadSuccess");
log("ETag", putResult.getETag());
log("RequestId", putResult.getRequestId());


修改策略内容



声明

部分内容来自网络

本教程仅用于学习, 禁止用于其他用途

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
相关文章
|
6月前
|
机器学习/深度学习 人工智能 专有云
人工智能平台PAI使用问题之怎么将DLC的数据写入到另一个阿里云主账号的OSS中
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。
|
2月前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
5月前
|
存储 机器学习/深度学习 弹性计算
阿里云EMR数据湖文件系统问题之OSS-HDFS全托管服务的问题如何解决
阿里云EMR数据湖文件系统问题之OSS-HDFS全托管服务的问题如何解决
|
6月前
|
消息中间件 分布式计算 DataWorks
DataWorks产品使用合集之如何使用Python和阿里云SDK读取OSS中的文件
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
6月前
|
存储 运维 安全
阿里云OSS的优势
【7月更文挑战第19天】阿里云OSS的优势
254 2
|
6月前
|
存储 API 开发工具
阿里云OSS
【7月更文挑战第19天】阿里云OSS
229 1
|
6月前
|
存储 弹性计算 对象存储
预留空间是什么?阿里云OSS对象存储预留空间说明
阿里云OSS预留空间是预付费存储产品,提供折扣价以锁定特定容量,适用于抵扣有地域属性的Bucket标准存储费用及ECS快照费。通过购买预留空间,如500GB通用预留+100GB标准-本地冗余存储包,用户可优化成本。
260 4
|
6月前
|
人工智能 对象存储
【阿里云AI助理】自家产品提供错误答案。阿里云OSS 资源包类型: 下行流量 地域: 中国内地通用 下行流量包规格: 300 GB 套餐: 下行流量包(中国内地) ,包1年。那么这个是每月300GB,1年是3600GB的流量;还是1年只有300GB的流量?
自家产品提供错误答案。阿里云OSS 资源包类型: 下行流量 地域: 中国内地通用 下行流量包规格: 300 GB 套餐: 下行流量包(中国内地) ,包1年。那么这个是每月300GB,1年是3600GB的流量;还是1年只有300GB的流量?
149 1
|
6月前
|
持续交付 开发工具 对象存储
阿里云云效产品使用合集之构建物如何上传到阿里云OSS
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
6月前
|
缓存 对象存储 数据安全/隐私保护
阿里云OSS, 跨域请求, No ‘Access-Control-Allow-Origin‘
阿里云OSS, 跨域请求, No ‘Access-Control-Allow-Origin‘
857 0