# Async Cow Python 七牛异步SDK > gitee链接 >github链接

本SDK基于官方SDK改造而成,但又对其进行了进一步封装,简化了相关操作
例如:
- 1、不需要使用者关心token问题

- 2、简化了相关导包和引用,并且保持接口一致

- 3、实现了异步IO,引入协程概念,IO层面引入aiohttp,aiofiles等,使得本SDK适用于异步编程

感谢您的星星

[官方SDK请见] https://developer.qiniu.com/kodo/1242/python

## 组织:

QQ群: 614714752

## Install

python解释器版本要求:> 3.6
```bash
# 标准安装
pip install async_cow

# 从官方源安装,你能获取最新版本SDK
pip install async_cow -i https://pypi.python.org/simple
```

## Usage

### 初始化

在你需要的地方
```python
from async_cow import AsyncCow, ClientCow
cow = AsyncCow(<ACCESS_KEY>, <SECRET_KEY>)
client = ClientCow(<ACCESS_KEY>, <SECRET_KEY>)
```
### 云存储桶操作

```python
b = cow.get_bucket(<BUCKET>)
```

后面都用这个桶对象来操作。 它代表了`<BUCKET>`

#### 列出所有的bucket
```python
res = await b.buckets()
```

#### 列出一个bucket中的所有文件
```python
res = await b.list()
```
这个方法还有 marker, limit, prefix这三个可选参数,详情参考官方文档

bucket相关方法和用法和官方SDK同步

#### 上传

```python
file_path = '/Users/admin/Desktop/123.jpg'

with open(file_path, 'rb') as f:
c = f.read()

# 上传二进制流
res = await b.put_data(
key='AK47.jpg', # 上传后的文件名
data=c
)

# 上传文件
res = await b.put_file(
key='AK472.jpg', # 上传后的文件名
file_path=file_path
)
for i in res:
print(i)

```

#### 删除,查看文件信息
```python
await b.stat('a') # 查看单个文件信息
await b.delete('a') # 删除单个文件
```

#### 拷贝,移动(改名)经测试,只能在桶内copy和move

这两个操作需要提供源文件名和目标文件名

```python
await b.copy('a', 'b') # 将'a' 拷贝至'b'
await b.move('a', 'b') # 将'a' 改名为'b'
```

有没有觉得比官方SDK容易使用多呢?

--------

#### 异常

在封装aiohttp操作时已经处理了大部分异常和重试过程,但仍会存在一些意外

所以安全的做法是这样:

```python
try:
await b.delete('a')
except Exception as e:
# 自行处理
pass
```

###短信客户端操作

```python
# 获取一个短信客户端对象
sms = cow.get_sms()
```

#### 创建,查看,编辑,删除签名

```python
await sms.createSignature(<signature>, <source>)
await sms.querySignature()
await sms.updateSignature(<id>, <signature>)
await sms.deleteSignature(<id>)
```

#### 创建,查看,编辑,删除模版

```python
await sms.createTemplate(<name>, <template>, <type>, <description>, <signature_id>)
await sms.queryTemplate(<audit_status>)
await sms.updateTemplate(<id>, <name>, <template>, <description>, <signature_id>)
await sms.deleteTemplate(<id>)
```

####发送短信,查看发送记录,查询发送计费条数

```python
await sms.sendMessage(<template_id>, <mobiles>, <parameters>)
await sms.get_messages_info()
await sms.get_charge_message_count(<start>, <end>, <g>, <status>)
```

### 持久化

```python
# 获取持久化类对象
p = cow.get_persistent_fop(<bucket>)
```

#### 文件持久化

```python
await p.execute(<key>, <fops>)
```

###直播连麦管理

```python
# 获取一个管理类对象
r = cow.get_rtc_server()
```

#### 创建,获取,修改,删除app

```python
await r.create_app(<data>)
await r.get_app()
await r.update_app(<app_id>, <data>)
await r.delete_app(<app_id>)
```

#### 用户列表,踢出用户

```python
await r.list_user(<app_id>, <data>)
await r.kick_user(<app_id>, <data>, <user_id>)
```

#### 查看活跃房间

```python
await r.list_active_rooms(<app_id>)
```

### CDN管理

```python
# 获取cdn管理类对象
cdn = cow.get_cdn_manager()
```

#### 刷新文件、目录

```python
await cdn.refresh_urls(<urls>)
await cdn.refresh_dirs(<dirs>)
# 同时刷新urls和dirs
await cdn.refresh_urls_and_dirs(<urls>, <dirs>)
```

#### 预取文件列表

```python
await cdn.prefetch_urls(<urls>)
```

#### 查询宽带、流量数据

```python
# 宽带
await cdn.get_bandwidth_data(<domains>, <start_date>, <end_date>, <granularity>)
# 流量
await cdn.get_flux_data(<domains>, <start_date>, <end_date>, <granularity>)
```

#### 获取日志下载链接

```python
await cdn.get_log_list_data(<domains>, <log_date>)
```

#### 修改证书

```python
await cdn.put_httpsconf(<name>, <certid>)
```

### 域名管理

```python
# 获取域名管理类对象
d = cow.get_domain_manager()
```

#### 创建,查看,删除域名

```python
await d.create_domain(<name>, <body>)
await d.get_domain(<name>)
await d.delete_domain(<name>)
```

#### 上线、下线域名

```python
await d.domain_online(<name>)
await d.domain_offline(<name>)
```

#### 创建、修改证书

```python
await d.create_sslcert(<name>, <certid>, <forceHttps>)
await d.put_httpsconf(<name>, <common_name>, <pri>, <ca>)
```

### 账号客户端

```python
# 获取帐号客户端对象
app = client.get_app()
```

#### 创建、获取管理客户端

```python
await app.create_qcos_client(<app_uri>)
await app.get_qcos_client(<app_uri>)
```

#### 账号密钥

```python
# 获取帐号下应用的密钥
await app.get_app_keys(<app_uri>)
# 获取帐号下可用的应用的密钥
await app.get_valid_app_auth(<app_uri>)
```

#### 当前账号的信息

```python
await app.get_account_info()
```

####获得指定应用所在区域的产品信息

```python
await app.get_app_region_products(<app_uri>)
```

#### 获取指定区域产品信息

```python
await app.get_region_products(<region>)
```

#### 获得账号可见的区域的信息

```python
await app.list_regions()
```

#### 创建、获得、删除当前账号的应用

```python
await app.create_app(<args>)
await app.list_apps()
await app.delete_app(<app_uri>)
```

### 资源管理客户端

```python
# 获取资源管理客户端对象
q = client.get_qcos_client()
```

#### 创建、获取、删除服务组

```python
await q.create_stack(<args>)
await q.get_stack(<stack>)
await q.delete_stack(<stack>)
```

#### 启动、停止服务组

```python
await q.start_stack(<stack>)
await q.stop_stack(<stack>)
```

#### 创建、获取、更新删除服务

```python
await q.create_service(<stack>, <args>)
# 查看服务
await q.get_service_inspect(<stack>, <service>)
# 获得服务列表
await q.list_services(<stack>)
await q.update_service(<stack>, <service>, <args>)
await q.delete_service(<stack>, <service>)
```

#### 启动、停止服务

```python
await q.start_service(<stack>, <service>)
await q.stop_service(<stack>, <service>)
```

#### 扩容、缩容服务

```python
await q.scale_service(<stack>, <service>, <args>)
```

#### 创建、删除、扩容存储卷

```python
await q.create_service_volume(<stack>, <service>, <args>)
await q.delete_service_volume(<stack>, <service>, <volume>)
await q.extend_service_volume(<stack>, <service>, <volume>, <args>)
```

#### 查看、列出容器

```python
await q.get_container_inspect(<ip>)
await q.list_containers()
```

#### 启动、停止、重启容器

```python
await q.start_container(<ip>)
await q.stop_container(<ip>)
await q.restart_container(<ip>)
```

#### 接入点

```python
# 列出接入点
await q.list_aps()
# 搜索接入点
await q.search_ap(<mode>, <query>)
# 查看接入点
await q.get_ap(<apid>)
# 申请接入点
await q.create_ap(<args>)
# 更新接入点
await q.update_ap(<apid>, <args>)
# 更新接入点端口配置
await q.set_ap_port(<apid>, <port>, <args>)
# 释放接入点
await q.delete_ap(<apid>)
```

#### 自定义域名

```python
# 绑定自定义域名
await q.publish_ap(<apid>, <args>)
# 解绑自定义域名
await q.unpublish_ap(<apid>, <args>)
```

#### 查看健康检查结果

```python
await q.get_ap_port_healthcheck(<apid>, <port>)
```

#### 调整后端实例配置

```python
await q.set_ap_port_container(<apid>, <port>, <args>)
```

#### 接入点端口

```python
# 临时关闭接入点端口
await q.disable_ap_port(<apid>, <port>)
# 开启接入点端口
await q.enable_ap_port(<apid>, <port>)
```

#### 列出入口提供商

```python
await q.get_ap_providers()
```

#### 获取一次性代理地址

```python
await q.get_web_proxy(<backend>)
```

## 测试

###桶测试

1. 首先从github clone项目到本地
2. 在项目中有example供测试,配置好main.py中的access_key、secret_key、bucket以及file_path参数后即可开始测试

特别鸣谢:[Hagworm]以及七牛官方

欢迎大佬指正!感谢您的星星

Async Cow Python 七牛异步SDK的更多相关文章

  1. 七牛php sdk 生成上传凭证时出现 undefined function Qiniu_SetKeys()

    将qiniu/http.php文件改名即可,原因是xampp等集成环境会安装pear存在了http.php

  2. 基于七牛Python SDK写的一个同步脚本

    需求背景 最近刚搭了个markdown静态博客,想把博客的图片放到云存储中. 经过调研觉得七牛可以满足我个人的需求,就选它了. 博客要引用图片就要先将图片上传到云上. 虽然七牛网站后台可以上传文件,但 ...

  3. 七牛用户搭建c# sdk的图文讲解

    Qiniu 七牛问题解答 问题描写叙述:非常多客户属于小白类型. 可是请不要随便喷七牛的文档站.由于须要一点http的专业知识才干了解七牛的api文档.如今我给大家弄个c# sdk的搭建步骤 问题解决 ...

  4. UEditor上传图片到七牛C#(后端实现)

    由于个人网站空间存储有所以选择将图片统一存储到七牛上,理由很简单 1  免费10G 的容量  ,对个人网站足够用 2  规范的开发者文档 和完善的sdk(几乎所有热门语言sdk) 整体思路 图片上传七 ...

  5. 基于七牛Python SDK写的一个批量下载脚本

    前言 上一篇基于七牛Python SDK写的一个同步脚本所写的脚本只支持上传,不支持文件下载. 虽然这个需求不太强烈,但有可能有人(在备份.迁移时)需要,而官方有没提供对应的工具,所以我就把这个功能也 ...

  6. ***七牛跨域上传图片JS SDK

    SDK: http://developer.qiniu.com/code/v6/sdk/javascript.html#upload 上传 在页面中引入 plupload,plupload.full. ...

  7. yii2.0 集合七牛SDK 上传图片到第三方

    首先,请用composer下载七牛phpSDK (具体参考官方文档) composer require qiniu/php-sdk 注册七牛账号 获取 AK SK(密匙) ,创建资源对象 获取doma ...

  8. PLDroidPlayer 是七牛推出的一款免费的适用于 Android 平台的播放器 SDK,采用全自研的跨平台播放内核,拥有丰富的功能和优异的性能,可高度定制化和二次开发。 https://developer.qiniu.com/pili/sdk/…

    PLDroidPlayer PLDroidPlayer 是一个适用于 Android 平台的音视频播放器 SDK,可高度定制化和二次开发,为 Android 开发者提供了简单.快捷的接口,帮助开发者在 ...

  9. discuz接入七牛sdk

    自己摸索了几天,找群里面的人各种问,都没有一个人回答我,哎,国内的开源精神呢...... 需要修改有以下几个: 1.替换 /source/class/class_core.php 文件   解释:就 ...

随机推荐

  1. bash shell cli tools

    bash shell cli tools before # create files $ mkdir app-component $ cd app-component $ touch index.ht ...

  2. c++中运行lua

    video 下载lua源码将src下面除了 lua.c和luac.c 的文件全部添加到项目中 #include <iostream> #include "lua.hpp" ...

  3. android adb命令,向开发手机添加文件

    adb文档 把本地文件发送到调试手机 C:\Users\ajanuw>adb push C:\Users\ajanuw\Music\j.mp3 /storage/emulated/0/Downl ...

  4. Java Reference核心原理分析

    本文转载自Java Reference核心原理分析 导语 带着问题,看源码针对性会更强一点.印象会更深刻.并且效果也会更好.所以我先卖个关子,提两个问题(没准下次跳槽时就被问到). 我们可以用Byte ...

  5. 手把手教你Spring Boot整合Mybatis Plus和Swagger2

    前言:如果你是初学者,请完全按照我的教程以及代码来搭建(文末会附上完整的项目代码包,你可以直接下载我提供的完整项目代码包然后自行体验!),为了照顾初学者所以贴图比较多,请耐心跟着教程来,希望这个项目D ...

  6. 还原Oracle数据库dmp文件(Win系统)

    准备工作: 1.核对数据字符集:   一般Oracle在安装的时候默认是选择ZHS16GBK,如有改动,使用 select userenv('language') from dual;语句查看使用的字 ...

  7. 如何把数据放到C#的心里之 DB2实例

    平时偶尔因为工作需要得自己写一些小工具去操作数据库,因为只是需要实现一些小的功能,也不涉及多类型的数据库,也许就是一次性的使用.所以此时那些大而全的数据库操作框架,也就不再那么适合我了.而本篇博文主要 ...

  8. 在 c++ 程序中出现CtrIsValidHeapPointer问题

    在c++程序中出现CtrIsValidHeapPointer问题, 我发现的原因是申请了大量动态数组但是并没有把他们初始化 为数组赋初始值便可以很好解决这一问题.

  9. apiAutoTest:支持自定义函数,用例中可调用

    0. 前言 apiAutoTest从去年8月以来开源至今,也更新了不少内容,一起来看看吧 第一个版本 - 2020/08/08 增加实际响应存储数据的方法,并在字典可以处理依赖见tools/svae_ ...

  10. std和stl的关系

    [前言]在写程序时,虽然一直这么用,有点疑惑为甚么引入了头文件.h还要在加上using namespace std?例如: 1 #include<iostream> 2 using nam ...