Skip to content

lizhanpeng/python-sdk

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

62 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Qiniu Resource (Cloud) Storage SDK for Python

Python 2.x SDK 使用指南

此 Python SDK 适用于2.x版本,基于 七牛云存储官方API 构建。使用此 SDK 构建您的网络应用程序,能让您以非常便捷地方式将数据安全地存储到七牛云存储上。无论您的网络应用是一个网站程序,还是包括从云端(服务端程序)到终端(手持设备应用)的架构的服务或应用,通过七牛云存储及其 SDK,都能让您应用程序的终端用户高速上传和下载,同时也让您的服务端更加轻盈。

目录


1. 安装

在命令行下执行

git clone http://github.com/qiniu/python-sdk
# 将系统路径添加到python 的搜索路径

2.1 配置密钥

要接入七牛云存储,您需要拥有一对有效的 Access Key 和 Secret Key 用来进行签名认证。可以通过如下步骤获得:

  1. 开通七牛开发者帐号
  2. 登录七牛开发者自助平台,查看 Access Key 和 Secret Key

在获取到 Access Key 和 Secret Key 之后,您可以在您的程序中调用如下两行代码进行初始化对接, 要确保ACCESS_KEYSECRET_KEY 在调用所有七牛API服务之前均已赋值:

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

3. 资源管理接口

3.1 查看单个文件属性信息

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.rs

ret, err = rs_client.stat(bucket_name, key)
if err is not None:
	error(err)
	return
print ret,

3.2 复制单个文件

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.rs

ret, err = rs_client.copy(bucket_name, key, bucket_name, key2)
if err is not None:
	error(err)
	return

3.3 移动单个文件

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.rs

ret, err = rs_client.move(bucket_name, key2, bucket_name, key3)
if err is not None:
	error(err)
	return

3.4 删除单个文件

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.rs

ret, err = rs_client.move(bucket_name, key2, bucket_name, key3)
if err is not None:
	error(err)
	return

3.5 批量操作

当您需要一次性进行多个操作时, 可以使用批量操作.

3.5.1 批量获取文件属性信息

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.rs

path_1 = qiniu.rs.EntryPath(bucket_name, key)
path_2 = qiniu.rs.EntryPath(bucket_name, key2)
path_3 = qiniu.rs.EntryPath(bucket_name, key3)

rets, err = rs_client.batch_stat([path_1, path_2, path_3])
if err is not None:
	error(err)
	return

3.5.2 批量复制文件

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.rs

path_1 = qiniu.rs.EntryPath(bucket_name, key)
path_2 = qiniu.rs.EntryPath(bucket_name, key2)
path_3 = qiniu.rs.EntryPath(bucket_name, key3)

pair_1 = qiniu.rs.EntryPathPair(path_1, path_3)
rets, err = rs_client.batch_copy([pair_1])
if not rets[0]['code'] == 200:
	error("复制失败")
	return

3.5.3 批量移动文件

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.rs

path_1 = qiniu.rs.EntryPath(bucket_name, key)
path_2 = qiniu.rs.EntryPath(bucket_name, key2)
path_3 = qiniu.rs.EntryPath(bucket_name, key3)

pair_2 = qiniu.rs.EntryPathPair(path_3, path_2)
rets, err = rs_client.batch_move([pair_2])
if not rets[0]['code'] == 200:
	error("移动失败")
	return

3.5.4 批量删除文件

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.rs

path_1 = qiniu.rs.EntryPath(bucket_name, key)
path_2 = qiniu.rs.EntryPath(bucket_name, key2)
path_3 = qiniu.rs.EntryPath(bucket_name, key3)

rets, err = rs_client.batch_delete([path_1, path_2])
if not [ret['code'] for ret in rets] == [200, 200]:
	error("删除失败")
	return

4. 上传下载接口

4.1 上传下载授权

4.1.1 上传授权uptoken

uptoken是一个字符串,作为http协议Header的一部分(Authorization字段)发送到我们七牛的服务端,表示这个http请求是经过认证的。

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.auth_token

policy = qiniu.auth_token.PutPolicy(bucket_name)
uptoken = policy.token()

4.1.2 下载授权downtoken

downtoken的原理同上,用来生成downtoken的GetPolicy

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.auth_token

policy = qiniu.auth_token.GetPolicy(bucket_name)
token = policy.token()

4.2 文件上传

注意:如果您只是想要上传已存在您电脑本地或者是服务器上的文件到七牛云存储,可以直接使用七牛提供的 qrsync 上传工具。 文件上传有两种方式,一种是以普通方式直传文件,简称普通上传,另一种方式是断点续上传,断点续上传在网络条件很一般的情况下也能有出色的上传速度,而且对大文件的传输非常友好。

4.2.1 普通上传

普通上传的接口在 qiniu.io 里,如下:

直接上传二进制流

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.io

extra = qiniu.io.PutExtra(bucket_name)
extra.mime_type = "text/plain"

ret, err = qiniu.io.put(uptoken, key, "hello!", extra)
if err is not None:
	error(err)
	return

上传本地文件

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.io

localfile = "./%s" % __file__
extra = qiniu.io.PutExtra(bucket_name)

ret, err = qiniu.io.put_file(uptoken, key, localfile, extra)
if err is not None:
	error(err)
	return

4.2.2 断点续上传

上传二进制流

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.resumable_io as rio

class ResumableUpload(object):
	position = 0
	def __init__(self, string_data):
		self.data = string_data
	
	def read(self, length):
		data = self.data[self.position: self.position+length]
		self.position += length
		return data

a = "resumable upload string"
extra = rio.PutExtra(bucket_name)
extra.mime_type = "text/plain"
ret, err = rio.put(uptoken, key, ResumableUpload(a), len(a), extra)
if err is not None:
	error(err)
	return
print ret,

上传本地文件

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.resumable_io as rio

localfile = "./%s" % __file__
extra = rio.PutExtra(bucket_name)

ret, err = rio.put_file(uptoken, key, localfile, extra)
if err is not None:
	error(err)
	return
print ret,

4.3 文件下载

七牛云存储上的资源下载分为 公有资源下载 和 私有资源下载 。

私有(private)是 Bucket(空间)的一个属性,一个私有 Bucket 中的资源为私有资源,私有资源不可匿名下载。

新创建的空间(Bucket)缺省为私有,也可以将某个 Bucket 设为公有,公有 Bucket 中的资源为公有资源,公有资源可以匿名下载。

4.3.1 公有资源下载

如果在给bucket绑定了域名的话,可以通过以下地址访问。

[GET] http://<domain>/<key>

其中可以到七牛云存储开发者自助网站绑定, 域名可以使用自己一级域名的或者是由七牛提供的二级域名(<bucket>.qiniutek.com)。注意,尖括号不是必需,代表替换项。

4.3.2 私有资源下载

私有资源必须通过临时下载授权凭证(downloadToken)下载,如下:

[GET] http://<domain>/<key>?token=<downloadToken>

注意,尖括号不是必需,代表替换项。
downloadToken 可以使用 SDK 提供的如下方法生成:

5. 数据处理接口

七牛支持在云端对图像, 视频, 音频等富媒体进行个性化处理

5.1 图像

5.1.1 查看图像属性

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.fop

info, err = qiniu.fop.ImageInfo().call(domain + key2)
if err is not None:
	error(err)
	return 
print info,

5.1.2 查看图片EXIF信息

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.fop

exif, err = qiniu.fop.Exif().call(domain + key2)
if err is not None:
	error(err)
	return
print exif

5.1.3 生成图片预览

import qiniu.config

qiniu.config.ACCESS_KEY = "<YOUR_APP_ACCESS_KEY>"
qiniu.config.SECRET_KEY = "<YOUR_APP_SECRET_KEY>"

import qiniu.fop

iv = qiniu.fop.ImageView()
iv.width = 100
print '可以在浏览器浏览: %s' % iv.make_request(domain + key2)

6. 贡献代码

  1. Fork
  2. 创建您的特性分支 (git checkout -b my-new-feature)
  3. 提交您的改动 (git commit -am 'Added some feature')
  4. 将您的修改记录提交到远程 git 仓库 (git push origin my-new-feature)
  5. 然后到 github 网站的该 git 远程仓库的 my-new-feature 分支下发起 Pull Request

7. 许可证

Copyright (c) 2013 qiniu.com

基于 MIT 协议发布:

About

Qiniu Resource (Cloud) Storage SDK for Python

Resources

Stars

Watchers

Forks

Packages

No packages published