qiniu 6.0.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: fb4e5dae35c9c6f8b0dea9a10c6580f15ec2c42e
4
+ data.tar.gz: b14c83f41a8fd3b88db57699648d1e8f1dd7a035
5
+ SHA512:
6
+ metadata.gz: e7bdb3f0459b3acf7fa17af1be97d84a784f7817a444356558a8b8c43eed40b9918e9406c1c2e9ef4b280113495b3f0183734478a0bec029bed32b9721f9fda1
7
+ data.tar.gz: a33a5c831cc472d86a13864e521da41f4844ebc64ae6cf215f492899ca4ae8846700f076d283cb9a55e3efce16a2bddee9a83fbeed963a2d0df69fde7a5c668a
@@ -0,0 +1,18 @@
1
+ *.gem
2
+ *.rbc
3
+ *.swp
4
+ .DS_Store
5
+ .bundle
6
+ .config
7
+ .yardoc
8
+ InstalledFiles
9
+ _yardoc
10
+ coverage
11
+ doc/
12
+ lib/bundler/man
13
+ pkg
14
+ rdoc
15
+ spec/reports
16
+ test/tmp
17
+ test/version_tmp
18
+ tmp
data/.rspec ADDED
@@ -0,0 +1 @@
1
+ --colour -f nested
@@ -0,0 +1,14 @@
1
+ language: ruby
2
+ rvm:
3
+ - 1.8.7
4
+ - 1.9.2
5
+ - 1.9.3
6
+ - 2.0.0
7
+ - 2.1.1
8
+ - jruby-18mode
9
+ - jruby-19mode
10
+ - jruby-head
11
+ - ree
12
+ before_script:
13
+ - export QINIU_ACCESS_KEY=LGRqJsjX7LAvtdtX6hhyxs861lS57HwnOQmJsOuX
14
+ - export QINIU_SECRET_KEY=g_OxhuN5iJ1O7BoA6YdXyF6zSszk34UZFKDfdIIW
@@ -0,0 +1,83 @@
1
+ ## CHANGE LOG
2
+
3
+ ### v6.0.1
4
+
5
+ - 重新划分命名空间,存储相关归入Qiniu::Storage,数据处理相关归入Qiniu::Fop,杂项相关归入Qiniu::Misc。
6
+
7
+ ### v3.4.6
8
+
9
+ - `Qiniu::RS.generate_download_token()` 方法的 `:pattern` 调整为必选项。
10
+
11
+ ### v3.4.5
12
+
13
+ - `Qiniu::RS.generate_upload_token()` 方法新增 `:callback_body` 和 `return_url` 选项。
14
+ - 选项含义参考: <http://developer.qiniu.com/docs/v6/api/reference/security/put-policy.html#put-policy-callback-body>
15
+
16
+ ### v3.4.2
17
+
18
+ - `Qiniu::RS.generate_upload_token()` 方法新增 `:return_body` 选项。
19
+
20
+ 该选项(`:return_body`)可设置文件上传成功后,执行七牛云存储规定的回调API,并以 JSON 响应格式返回其执行结果。参考 [uploadToken 之 returnBody 说明](http://developer.qiniu.com/docs/v6/api/reference/security/put-policy.html#put-policy-return-body)。
21
+
22
+ ### v3.4.1
23
+
24
+ 增加为上传文件进行预转的选项,参见 [uploadToken 之 asyncOps 说明](http://docs.qiniu.com/api/v6/put.html#uploadToken-asyncOps)
25
+
26
+ - `Qiniu::RS.generate_upload_token()` 方法新增 `:async_options` 选项用于进行预转操作。
27
+
28
+ ### v3.4.0
29
+
30
+ 增加文件复制/移动方法,包括批量复制/移动文件
31
+
32
+ - `Qiniu::RS.copy(source_bucket, source_key, target_bucket, target_key)`
33
+ - `Qiniu::RS.move(source_bucket, source_key, target_bucket, target_key)`
34
+ - `Qiniu::RS.batch_copy [source_bucket, source_key, target_bucket, target_key], ...`
35
+ - `Qiniu::RS.batch_move [source_bucket, source_key, target_bucket, target_key], ...`
36
+
37
+ ### v3.3.1
38
+
39
+ 确保单元测试里边用到的测试 Bucket 全局唯一
40
+
41
+ 使得10多种不通的 Ruby 宿主环境能隔离互不影响地执行单元/集成测试
42
+
43
+ Ruby 宿主环境如下
44
+
45
+ 1.8.7, 1.9.2, 1.9.3, jruby-18mode, jruby-19mode, rbx-18mode, rbx-19mode, ruby-head, jruby-head, ree
46
+
47
+ 详见 <https://travis-ci.org/qiniu/ruby-sdk>
48
+
49
+ ### v3.3.0
50
+
51
+ 私有资源下载新版实现,添加 Qiniu::RS.generate_download_token() 方法。参考 [downloadToken](http://developer.qiniu.com/docs/v6/api/reference/security/download-token.html)
52
+
53
+ 详见 [Ruby SDK 使用文档之私有资源下载](http://developer.qiniu.com/docs/v6/api/overview/dn/security.html)
54
+
55
+ ### v3.2.2
56
+
57
+ fixed E701 error
58
+
59
+ 断点续上传根据 mkblk 返回的 host 字段进行 bput 和 mkfile ,规避由于DNS智能解析造成的分布式并行块上传会出现上下文不连贯导致的 E701 问题。
60
+
61
+ ### v3.2.1
62
+
63
+ allow images uploaded auto-orient.
64
+
65
+ 允许图片上传成功后自动旋转。
66
+
67
+ 参考:
68
+
69
+ 1. [[API] multipart/form-data 上传文件之 action 字段详解](http://docs.qiniutek.com/v3/api/io/#upload-action)
70
+ 2. [[SDK] Qiniu::RS.upload_file() 方法中的参数增加了 :rotate 选项](http://docs.qiniutek.com/v3/sdk/ruby/#upload-server-side)
71
+
72
+ ### v3.2.0
73
+
74
+ 2012-11-06
75
+
76
+ allow files uploaded auto callback some APIs (like imageInfo, exif, etc…), and add those APIs callback results as part of the custom data for POST biz-server.
77
+
78
+ 允许上传文件(图片)成功后执行回调指定的 API (比如 imageInfo, exif 接口等),并将指定API的回调结果一并 POST 发送给客户方的业务服务器。
79
+
80
+ 参考:
81
+
82
+ 1. [[API] 生成上传授权凭证 uploadToken 之 escape 参数详解](http://docs.qiniutek.com/v3/api/io/#escape-expression)
83
+ 2. [[SDK] Qiniu::RS.generate_upload_token() 方法中的参数增加了 :escape 选项](http://docs.qiniutek.com/v3/sdk/ruby/#generate-upload-token)
data/Gemfile ADDED
@@ -0,0 +1,8 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in qiniu-s3.gemspec
4
+ gemspec
5
+
6
+ # platforms :jruby do
7
+ # gem "jruby-openssl"
8
+ # end
@@ -0,0 +1,37 @@
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ qiniu (6.0.1)
5
+ json (~> 1.7)
6
+ mime-types (~> 1.19)
7
+ rest-client (~> 1.6)
8
+ ruby-hmac (~> 0.4)
9
+
10
+ GEM
11
+ remote: https://rubygems.org/
12
+ specs:
13
+ diff-lcs (1.1.3)
14
+ fakeweb (1.3.0)
15
+ json (1.7.7)
16
+ mime-types (1.23)
17
+ rake (10.0.3)
18
+ rest-client (1.6.7)
19
+ mime-types (>= 1.16)
20
+ rspec (2.12.0)
21
+ rspec-core (~> 2.12.0)
22
+ rspec-expectations (~> 2.12.0)
23
+ rspec-mocks (~> 2.12.0)
24
+ rspec-core (2.12.2)
25
+ rspec-expectations (2.12.1)
26
+ diff-lcs (~> 1.1.3)
27
+ rspec-mocks (2.12.2)
28
+ ruby-hmac (0.4.0)
29
+
30
+ PLATFORMS
31
+ ruby
32
+
33
+ DEPENDENCIES
34
+ fakeweb (~> 1.3)
35
+ qiniu!
36
+ rake (>= 0.9)
37
+ rspec (>= 2.11)
data/LICENSE ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2012-2013 qiniutek.com
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,45 @@
1
+ # Qiniu Resource (Cloud) Storage SDK for Ruby
2
+
3
+ ## 关于
4
+
5
+ 此 Ruby SDK 适用于 Ruby 1.8.x, 1.9.x, 2.0.x, jruby, rbx, ree 版本,基于 [七牛云存储官方API](http://developer.qiniu.com/docs/v6/index.html) 构建。使用此 SDK 构建您的网络应用程序,能让您以非常便捷地方式将数据安全地存储到七牛云存储上。无论您的网络应用是一个网站程序,还是包括从云端(服务端程序)到终端(手持设备应用)的架构的服务或应用,通过七牛云存储及其 SDK,都能让您应用程序的终端用户高速上传和下载,同时也让您的服务端更加轻盈。
6
+
7
+ ## 状态
8
+
9
+ 集成测试:[![Build Status](https://api.travis-ci.org/qiniu/ruby-sdk.png?branch=master)](https://travis-ci.org/qiniu/ruby-sdk)
10
+ 版本:[![Gem Version](https://badge.fury.io/rb/qiniu-rs.png)](http://badge.fury.io/rb/qiniu-rs)
11
+
12
+ ## 安装
13
+
14
+ 在您 Ruby 应用程序的 `Gemfile` 文件中,添加如下一行代码:
15
+
16
+ gem 'qiniu'
17
+
18
+ 然后,在应用程序所在的目录下,可以运行 `bundle` 安装依赖包:
19
+
20
+ $ bundle
21
+
22
+ 或者,可以使用 Ruby 的包管理器 `gem` 进行安装:
23
+
24
+ $ gem install qiniu
25
+
26
+ ## 使用
27
+
28
+ 参考文档:[七牛云存储 Ruby SDK 使用指南](http://developer.qiniu.com/docs/v6/sdk/ruby-sdk.html)
29
+
30
+ ## 贡献代码
31
+
32
+ 1. Fork
33
+ 2. 创建您的特性分支 (`git checkout -b my-new-feature`)
34
+ 3. 提交您的改动 (`git commit -am 'Added some feature'`)
35
+ 4. 将您的修改记录提交到远程 `git` 仓库 (`git push origin my-new-feature`)
36
+ 5. 然后到 github 网站的该 `git` 远程仓库的 `my-new-feature` 分支下发起 Pull Request
37
+
38
+ ## 许可证
39
+
40
+ Copyright (c) 2012-2014 qiniu.com
41
+
42
+ 基于 MIT 协议发布:
43
+
44
+ * [www.opensource.org/licenses/MIT](http://www.opensource.org/licenses/MIT)
45
+
@@ -0,0 +1,21 @@
1
+ #!/usr/bin/env rake
2
+
3
+ require 'rubygems'
4
+ require 'bundler'
5
+ require "bundler/gem_tasks"
6
+
7
+ begin
8
+ Bundler.setup(:default, :development)
9
+ rescue Bundler::BundlerError => e
10
+ $stderr.puts e.message
11
+ $stderr.puts "Run `bundle install` to install missing gems"
12
+ exit e.status_code
13
+ end
14
+
15
+ require 'rspec/core'
16
+ require 'rspec/core/rake_task'
17
+ RSpec::Core::RakeTask.new(:spec) do |spec|
18
+ spec.pattern = FileList['spec/**/*_spec.rb']
19
+ end
20
+
21
+ task :default => :spec
@@ -0,0 +1,790 @@
1
+ ---
2
+ title: Ruby SDK
3
+ ---
4
+
5
+ 此 Ruby SDK 适用于 Ruby 1.8.x, 1.9.x, jruby, rbx, ree 版本,基于 [七牛云存储官方API](http://docs.qiniu.com/) 构建。使用此 SDK 构建您的网络应用程序,能让您以非常便捷地方式将数据安全地存储到七牛云存储上。无论您的网络应用是一个网站程序,还是包括从云端(服务端程序)到终端(手持设备应用)的架构的服务或应用,通过七牛云存储及其 SDK,都能让您应用程序的终端用户高速上传和下载,同时也让您的服务端更加轻盈。
6
+
7
+ 七牛云存储 Ruby SDK 源码地址:<https://github.com/qiniu/ruby-sdk>
8
+
9
+ **目录**
10
+
11
+ - [安装](#Installation)
12
+ - [接入](#turn-on)
13
+ - [配置密钥(AccessKey / SecretKey)](#establish_connection!)
14
+ - [针对 Ruby On Rails 网站应用初始化设置](#ror-init)
15
+ - [使用](#Usage)
16
+ - [文件上传](#upload)
17
+ - [生成上传授权凭证(uploadToken)](#generate-upload-token)
18
+ - [Ruby 服务端上传文件](#upload-server-side)
19
+ - [开启断点续上传](#resumable-upload)
20
+ - [iOS / Android / Web 端直传文件说明](#upload-client-side)
21
+ - [文件下载](#download)
22
+ - [公有资源下载](#download-public-files)
23
+ - [私有资源下载](#download-private-files)
24
+ - [生成下载授权凭证(downloadToken)](#download-token)
25
+ - [高级特性](#other-download-features)
26
+ - [断点续下载](#resumable-download)
27
+ - [自定义 404 NotFound](#upload-file-for-not-found)
28
+ - [文件管理](#file-management)
29
+ - [查看单个文件属性信息](#stat)
30
+ - [复制单个文件](#copy)
31
+ - [移动单个文件](#move)
32
+ - [删除单个文件](#delete)
33
+ - [批量操作](#batch)
34
+ - [批量获取文件属性信息](#batch-get)
35
+ - [批量复制文件](#batch-copy)
36
+ - [批量移动文件](#batch-move)
37
+ - [批量删除文件](#batch-delete)
38
+ - [云处理](#cloud-processing)
39
+ - [图像](#image-processing)
40
+ - [查看图片属性信息](#image-info)
41
+ - [查看图片EXIF信息](#image-exif)
42
+ - [图像在线处理(缩略、裁剪、旋转、转化)](#image-mogrify-for-preview)
43
+ - [图像在线处理(缩略、裁剪、旋转、转化)后并持久化存储](#image-mogrify-for-save-as)
44
+ - 音频(TODO)
45
+ - 视频(TODO)
46
+ - [贡献代码](#Contributing)
47
+ - [许可证](#License)
48
+
49
+
50
+ <a name="Installation"></a>
51
+
52
+ ## 安装
53
+
54
+ 在您 Ruby 应用程序的 `Gemfile` 文件中,添加如下一行代码:
55
+
56
+ gem 'qiniu-rs'
57
+
58
+ 然后,在应用程序所在的目录下,可以运行 `bundle` 安装依赖包:
59
+
60
+ $ bundle
61
+
62
+ 或者,可以使用 Ruby 的包管理器 `gem` 进行安装:
63
+
64
+ $ gem install qiniu-rs
65
+
66
+
67
+ <a name="turn-on"></a>
68
+
69
+ ## 接入
70
+
71
+ <a name="establish_connection!"></a>
72
+
73
+ ### 配置密钥(AccessKey / SecretKey)
74
+
75
+ 要接入七牛云存储,您需要拥有一对有效的 Access Key 和 Secret Key 用来进行签名认证。可以通过如下步骤获得:
76
+
77
+ 1. [开通七牛开发者帐号](https://portal.qiniu.com/signup)
78
+ 2. [登录七牛开发者自助平台,查看 Access Key 和 Secret Key](https://portal.qiniu.com/setting/key)
79
+
80
+ 在获取到 Access Key 和 Secret Key 之后,您可以在您的程序中调用如下两行代码进行初始化对接:
81
+
82
+ Qiniu::RS.establish_connection! :access_key => YOUR_APP_ACCESS_KEY,
83
+ :secret_key => YOUR_APP_SECRET_KEY
84
+
85
+ <a name="ror-init"></a>
86
+
87
+ ### 针对 Ruby On Rails 网站应用初始化设置
88
+
89
+ 如果您使用的是 [Ruby on Rails](http://rubyonrails.org/) 框架,我们建议您在应用初始化启动的过程中,依次调用上述两个函数即可,操作如下:
90
+
91
+ 首先,在应用初始化脚本加载的目录中新建一个文件:`YOUR_RAILS_APP/config/initializers/qiniu-rs.rb`
92
+
93
+ 然后,编辑 `YOUR_RAILS_APP/config/initializers/qiniu-rs.rb` 文件内容如下:
94
+
95
+ Qiniu::RS.establish_connection! :access_key => YOUR_APP_ACCESS_KEY,
96
+ :secret_key => YOUR_APP_SECRET_KEY
97
+
98
+ 这样,您就可以在您的 `RAILS_APP` 中使用七牛云存储 Ruby SDK 提供的其他任意方法了。
99
+
100
+ 接下来,我们会逐一介绍此 SDK 提供的其他方法。
101
+
102
+
103
+ <a name="Usage"></a>
104
+
105
+ ## 使用
106
+
107
+ <a name="upload"></a>
108
+
109
+ ### 文件上传
110
+
111
+ **注意**:如果您只是想要上传已存在您电脑本地或者是服务器上的文件到七牛云存储,可以直接使用七牛提供的 [qrsync](http://docs.qiniu.com/tools/qrsync.html) 上传工具。如果是需要通过您的网站或是移动应用(App)上传文件,则可以接入使用此 SDK,详情参考如下文档说明。
112
+
113
+ <a name="generate-upload-token"></a>
114
+
115
+ #### 生成上传授权凭证(uploadToken)
116
+
117
+ 要上传一个文件,首先需要调用 SDK 提供的 `Qiniu::RS.generate_upload_token` 函数来获取一个经过授权用于临时匿名上传的 `upload_token`——经过数字签名的一组数据信息,该 `upload_token` 作为文件上传流中 `multipart/form-data` 的一部分进行传输。
118
+
119
+ `Qiniu::RS.generate_upload_token` 函数原型如下:
120
+
121
+ Qiniu::RS.generate_upload_token :scope => target_bucket,
122
+ :expires_in => expires_in_seconds,
123
+ :callback_url => callback_url,
124
+ :callback_body => callback_body,
125
+ :callback_body_type => callback_body_type,
126
+ :customer => end_user_id,
127
+ :escape => allow_upload_callback_api,
128
+ :async_options => async_callback_api_commands,
129
+ :return_body => custom_response_body
130
+
131
+ **参数**
132
+
133
+ :scope
134
+ : 必须,字符串类型(String),设定文件要上传到的目标 `bucket`
135
+
136
+ :expires_in
137
+ : 可选,数字类型,用于设置上传 URL 的有效期,单位:秒,缺省为 3600 秒,即 1 小时后该上传链接不再有效(但该上传URL在其生成之后的59分59秒都是可用的)。
138
+
139
+ :callback_url
140
+ : 可选,字符串类型(String),用于设置文件上传成功后,七牛云存储服务端要回调客户方的业务服务器地址。
141
+
142
+ :callback_body
143
+ : 可选,字符串类型(String),用于设置文件上传成功后,七牛云存储服务端向客户方的业务服务器发送回调请求的值。
144
+
145
+ :callback_body_type
146
+ : 可选,字符串类型(String),用于设置文件上传成功后,七牛云存储服务端向客户方的业务服务器发送回调请求的 `Content-Type`。
147
+
148
+ :customer
149
+ : 可选,字符串类型(String),客户方终端用户(End User)的ID,该字段可以用来标示一个文件的属主,这在一些特殊场景下(比如给终端用户上传的图片打上名字水印)非常有用。
150
+
151
+ :escape
152
+ : 可选,数字类型,可选值 0 或者 1,缺省为 0 。值为 1 表示 callback 传递的自定义数据中允许存在转义符号 `$(VarExpression)`,参考 [VarExpression](http://docs.qiniutek.com/v3/api/words/#VarExpression)。
153
+
154
+ 当 `escape` 的值为 `1` 时,常见的转义语法如下:
155
+
156
+ - 若 `callbackBodyType` 为 `application/json` 时,一个典型的自定义回调数据([CallbackParams](http://docs.qiniutek.com/v3/api/io/#CallbackParams))为:
157
+
158
+ `{foo: "bar", w: $(imageInfo.width), h: $(imageInfo.height), exif: $(exif)}`
159
+
160
+ - 若 `callbackBodyType` 为 `application/x-www-form-urlencoded` 时,一个典型的自定义回调数据([CallbackParams](http://docs.qiniutek.com/v3/api/io/#CallbackParams))为:
161
+
162
+ `foo=bar&w=$(imageInfo.width)&h=$(imageInfo.height)&exif=$(exif)`
163
+
164
+ :async_options
165
+ : 可选,字符串类型(String),用于设置文件上传成功后,执行指定的预转指令。参考 [uploadToken 之 asyncOps 说明](http://docs.qiniutek.com/v3/api/io/#uploadToken-asyncOps)
166
+
167
+ :return_body
168
+ : 可选,字符串类型(String),用于设置文件上传成功后,执行七牛云存储规定的回调API,并以 JSON 响应格式返回其执行结果。参考 [uploadToken 之 returnBody 说明](http://docs.qiniutek.com/v3/api/io/#uploadToken-returnBody)。
169
+
170
+
171
+ **返回值**
172
+
173
+ 返回一个字符串类型(String)的用于上传文件用的临时授权 `upload_token`。
174
+
175
+ <a name="upload-server-side"></a>
176
+
177
+ #### Ruby 服务端上传文件
178
+
179
+ 通过 `Qiniu::RS.upload_file()` 方法可在客户方的业务服务器上直接往七牛云存储上传文件。该函数规格如下:
180
+
181
+ Qiniu::RS.upload_file :uptoken => upload_token,
182
+ :file => file_path,
183
+ :bucket => bucket_name,
184
+ :key => record_id,
185
+ :mime_type => file_mime_type,
186
+ :note => some_notes,
187
+ :callback_params => callback_params,
188
+ :enable_crc32_check => false,
189
+ :rotate => auto_rotate
190
+
191
+ **参数**
192
+
193
+ :uptoken
194
+ : 必须,字符串类型(String),调用 `Qiniu::RS.generate_upload_token` 生成的 [用于上传文件的临时授权凭证](#generate-upload-token)
195
+
196
+ :file
197
+ : 必须,字符串类型(String),本地文件可被读取的有效路径
198
+
199
+ :bucket
200
+ : 必须,字符串类型(String),空间名称。
201
+
202
+ :key
203
+ : 必须,字符串类型(String),若把 Bucket 理解为关系性数据库的某个表,那么 key 类似数据库里边某个表的主键ID,需给每一个文件一个UUID用于进行标示。
204
+
205
+ :mime_type
206
+ : 可选,字符串类型(String),文件的 mime-type 值。如若不传入,SDK 会自行计算得出,若计算失败缺省使用 application/octet-stream 代替之。
207
+
208
+ :note
209
+ : 可选,字符串类型(String),为文件添加备注信息。
210
+
211
+ :callback_params
212
+ : 可选,String 或者 Hash 类型,文件上传成功后,七牛云存储向客户方业务服务器发送的回调参数。
213
+
214
+ :enable_crc32_check
215
+ : 可选,Boolean 类型,是否启用文件上传 crc32 校验,缺省为 false 。
216
+
217
+ :rotate
218
+ : 可选,数字类型,上传图片时专用,可针对图片上传后进行旋转。该参数值为 0 :表示根据图像EXIF信息自动旋转;值为 1 : 右转90度;值为 2 :右转180度;值为 3 : 右转270度。
219
+
220
+ **返回值**
221
+
222
+ 上传成功,返回如下一个 Hash:
223
+
224
+ {"hash"=>"FgHk-_iqpnZji6PsNr4ghsK5qEwR"}
225
+
226
+ 上传失败,会抛出 `UploadFailedError` 异常。
227
+
228
+ <a name="resumable-upload"></a>
229
+
230
+ ##### 开启断点续上传
231
+
232
+ 无需任何额外改动,SDK 提供的 `Qiniu::RS.upload_file()` 方法缺省支持断点续上传。默认情况下,SDK 会自动启用断点续上传的方式来上传超过 4MB 大小的文件。您也可以在 [应用接入](http://docs.qiniutek.com/v3/sdk/ruby/#establish_connection!) 时通过修改缺省配置来设置该阀值:
233
+
234
+ Qiniu::RS.establish_connection! :access_key => YOUR_APP_ACCESS_KEY,
235
+ :secret_key => YOUR_APP_SECRET_KEY,
236
+ :block_size => 1024*1024*4,
237
+ :chunk_size => 1024*256,
238
+ :tmpdir => Dir.tmpdir + File::SEPARATOR + 'Qiniu-RS-Ruby-SDK',
239
+ :enable_debug => true,
240
+ :auto_reconnect => true,
241
+ :max_retry_times => 3
242
+
243
+ **参数详解**
244
+
245
+ 应用接入初始化时,以下配置参数均为可选:
246
+
247
+ :block_size
248
+ : 整型,指定断点续上传针对大文件所使用的分块大小,缺省为 4MB ,小于该阀值的文件不启用断点续上传。
249
+
250
+ :chunk_size
251
+ : 整型,指定断点续上传每次http请求上传的数据块大小,缺省为 256KB。该设置尽量不要超过实际使用的上行带宽,且不能超过 `:block_size` 定义的值。
252
+
253
+ :tmpdir
254
+ : 字符串类型,指定持久化保存断点续上传进度状态临时文件的目录,缺省放置于操作系统的临时目录中。
255
+
256
+ :enable_debug
257
+ : 布尔值,是否启用调试模式,缺省启用(true),启用后会打印相关日志。该参数 SDK 全局有效。
258
+
259
+ :auto_reconnect
260
+ : 布尔值,指定每次 http 若请求失败是否启用重试,缺省启用(true)。该参数 SDK 全局有效。
261
+
262
+ :max_retry_times
263
+ : 整型,指定每次 http 若请求失败最多可以重试的次数,缺省为3次。该参数 SDK 全局有效。
264
+
265
+
266
+ <a name="upload-client-side"></a>
267
+
268
+ #### iOS / Android / Web 端直传文件说明
269
+
270
+ 客户端 iOS / Android / Web 上传流程和服务端上传类似,差别在于:客户端直传文件所需的 `uploadToken` 选择在客户方的业务服务器端生成,然后将其生成的 `uploadToken` 颁发给客户端。
271
+
272
+ 简单来讲,客户端上传流程分为两步:
273
+
274
+ 1. [服务端生成上传授权凭证(uploadToken)](#generate-upload-token)
275
+ 2. 客户端程序调用 [iOS](http://docs.qiniu.com/ios-sdk/index.html) / [Android](http://docs.qiniu.com/android-sdk/index.html) SDK 的文件上传方法进行上传
276
+
277
+ 如果是网页直传文件到七牛云存储,网页可以使用 JavaScript 动态实现 [七牛云存储上传API](http://docs.qiniutek.com/v3/api/io/#upload-file-by-html-form)。
278
+
279
+ 通过客户端直传文件,您的终端用户即可把数据(比如图片或视频)直接上传到七牛云存储服务器上,而无须经由您的服务端中转,终端用户上传数据始终是离他物理距离最近的七牛存储节点。当终端用户上传成功后,七牛云存储服务端会向您指定的 `callback_url` (一般在 [uploadToken](#generate-upload-token) 里边指定)发送回调数据(回调数据在客户端程序里边指定)。如果 `callback_url` 所指向的服务端处理完毕后输出 `JSON` 格式的数据,七牛云存储服务端会将该回调请求所得的 JSON 响应信息原封不动地返回给客户端应用程序。
280
+
281
+
282
+ <a name="download"></a>
283
+
284
+ ### 文件下载
285
+
286
+ 七牛云存储上的资源下载分为 [公有资源下载](#download-public-files) 和 [私有资源下载](#download-private-files) 。
287
+
288
+ 私有(private)是 Bucket(空间)的一个属性,一个私有 Bucket 中的资源为私有资源,私有资源不可匿名下载。
289
+
290
+ 新创建的空间(Bucket)缺省为私有,也可以将某个 Bucket 设为公有,公有 Bucket 中的资源为公有资源,公有资源可以匿名下载。
291
+
292
+ <a name="download-public-files"></a>
293
+
294
+ #### 公有资源下载
295
+
296
+ [GET] http://<bucket>.qiniudn.com/<key>
297
+
298
+ 或者,
299
+
300
+ [GET] http://<绑定域名>/<key>
301
+
302
+ 绑定域名可以是自定义域名,可以在 [七牛云存储开发者自助网站](https://portal.qiniu.com/) 进行域名绑定操作。
303
+
304
+ **注意**,尖括号不是必需,代表替换项。
305
+
306
+ <a name="download-private-files"></a>
307
+
308
+ #### 私有资源下载
309
+
310
+ 私有资源只能通过临时下载授权凭证(downloadToken)下载,下载链接格式如下:
311
+
312
+ [GET] http://<bucket>.qiniudn.com/<key>?token=<downloadToken>
313
+
314
+ 或者,
315
+
316
+ [GET] http://<绑定域名>/<key>?token=<downloadToken>
317
+
318
+ <a name="download-token"></a>
319
+
320
+ ##### 生成下载授权凭证(downloadToken)
321
+
322
+ `<downloadToken>` 可以使用 SDK 提供的如下方法生成:
323
+
324
+ Qiniu::RS.generate_download_token :expires_in => expires_in_seconds,
325
+ :pattern => download_url_patterns
326
+
327
+ **参数**
328
+
329
+ expires_in
330
+ : 可选,数字类型,用于设置上传 URL 的有效期,单位:秒,缺省为 3600 秒,即 1 小时后该下载授权凭证(downloadToken)不再有效。
331
+
332
+ pattern
333
+ : 必选,字符串类型,用于设置可匹配的下载链接。参考:[downloadToken pattern 详解](http://docs.qiniutek.com/v3/api/io/#download-token-pattern)
334
+
335
+
336
+ <a name="other-download-features"></a>
337
+
338
+ #### 高级特性
339
+
340
+ <a name="resumable-download"></a>
341
+
342
+ ##### 断点续下载
343
+
344
+ 七牛云存储支持标准的断点续下载,参考:[云存储API之断点续下载](http://docs.qiniu.com/api/get.html#download-by-range-bytes)
345
+
346
+ <a name="upload-file-for-not-found"></a>
347
+
348
+ ##### 自定义 404 NotFound
349
+
350
+ 您可以上传一个应对 HTTP 404 出错处理的文件,当用户访问一个不存在的文件时,即可使用您上传的“自定义404文件”代替之。要这么做,您只须使用 `Qiniu::RS.upload_file` 函数上传一个 `key` 为固定字符串类型的值 `errno-404` 即可。
351
+
352
+ 除了使用 SDK 提供的方法,同样也可以借助七牛云存储提供的命令行辅助工具 [qboxrsctl](http://docs.qiniu.com/tools/qboxrsctl.html) 达到同样的目的:
353
+
354
+ qboxrsctl put <Bucket> <Key> <LocalFile>
355
+
356
+ 将其中的 `<Key>` 换作 `errno-404` 即可。
357
+
358
+ 注意,每个 `<Bucket>` 里边有且只有一个 `errno-404` 文件,上传多个,最后的那一个会覆盖前面所有的。
359
+
360
+
361
+ <a name="file-management"></a>
362
+
363
+ ### 文件管理
364
+
365
+ 文件管理包括对存储在七牛云存储上的文件进行查看、复制、移动和删除处理。
366
+
367
+ <a name="stat"></a>
368
+
369
+ #### 查看单个文件属性信息
370
+
371
+ Qiniu::RS.stat(bucket, key)
372
+
373
+ 可以通过 SDK 提供的 `Qiniu::RS.stat` 函数,来查看某个已上传文件的属性信息。
374
+
375
+ **参数**
376
+
377
+ bucket
378
+ : 必须,字符串类型(String),空间名称。
379
+
380
+ key
381
+ : 必须,字符串类型(String),若把 Bucket 理解为关系性数据库的某个表,那么 key 类似数据库里边某个表的主键ID,需给每一个文件一个UUID用于进行标示。
382
+
383
+ **返回值**
384
+
385
+ 如果请求失败,返回 `false`;否则返回如下一个 `Hash` 类型的结构:
386
+
387
+ {
388
+ "fsize" => 3053,
389
+ "hash" => "Fu9lBSwQKbWNlBLActdx8-toAajv",
390
+ "mimeType" => "application/x-ruby",
391
+ "putTime" => 13372775859344500
392
+ }
393
+
394
+ fsize
395
+ : 表示文件总大小,单位是 Byte
396
+
397
+ hash
398
+ : 文件的特征值,可以看做是基版本号
399
+
400
+ mimeType
401
+ : 文件的 mime-type
402
+
403
+ putTime
404
+ : 上传时间,单位是 百纳秒
405
+
406
+
407
+ <a name="copy"></a>
408
+
409
+ #### 复制单个文件
410
+
411
+ Qiniu::RS.copy(source_bucket, source_key, target_bucket, target_key)
412
+
413
+ 可以通过 SDK 提供的 `Qiniu::RS.copy` 函数进行文件复制操作。
414
+
415
+ **参数**
416
+
417
+ source_bucket
418
+ : 必须,字符串类型(String),指定源空间。
419
+
420
+ source_key
421
+ : 必须,字符串类型(String),指定源文件。
422
+
423
+ target_bucket
424
+ : 必须,字符串类型(String),指定要复制到的目标空间。
425
+
426
+ target_key
427
+ : 必须,字符串类型(String),指定要复制到目标空间的目标文件名。
428
+
429
+ **返回值**
430
+
431
+ 如果请求失败,返回 `false`;否则返回 `true` 。
432
+
433
+
434
+ <a name="move"></a>
435
+
436
+ #### 移动单个文件
437
+
438
+ Qiniu::RS.move(source_bucket, source_key, target_bucket, target_key)
439
+
440
+ 可以通过 SDK 提供的 `Qiniu::RS.move` 函数进行文件移动操作。
441
+
442
+ **参数**
443
+
444
+ source_bucket
445
+ : 必须,字符串类型(String),指定源空间。
446
+
447
+ source_key
448
+ : 必须,字符串类型(String),指定源文件。
449
+
450
+ target_bucket
451
+ : 必须,字符串类型(String),指定要移动到的目标空间。
452
+
453
+ target_key
454
+ : 必须,字符串类型(String),指定要移动到目标空间的目标文件名。
455
+
456
+ **返回值**
457
+
458
+ 如果请求失败,返回 `false`;否则返回 `true` 。
459
+
460
+
461
+ <a name="delete"></a>
462
+
463
+ ### 删除单个文件
464
+
465
+ Qiniu::RS.delete(bucket, key)
466
+
467
+ `Qiniu::RS.delete` 函数提供了从指定的 `bucket` 中删除指定的 `key`,即删除 `key` 索引关联的具体文件。
468
+
469
+ **参数**
470
+
471
+ bucket
472
+ : 必须,字符串类型(String),空间名称。
473
+
474
+ key
475
+ : 必须,字符串类型(String),若把 Bucket 理解为关系性数据库的某个表,那么 key 类似数据库里边某个表的主键ID,需给每一个文件一个UUID用于进行标示。
476
+
477
+ **返回值**
478
+
479
+ 如果删除成功,返回 `true`,否则返回 `false` 。
480
+
481
+
482
+ <a name="batch"></a>
483
+
484
+ ### 批量操作
485
+
486
+ Qiniu::RS.batch(command, bucket, keys)
487
+
488
+ SDK 还提供了 `Qiniu::RS.batch` 函数来提供批量处理 `Qiniu::RS.stat` 或是 `Qiniu::RS.get` 或 `Qiniu::RS.delete` 的相应功能。
489
+
490
+ **参数**
491
+
492
+ command
493
+ : 必须,字符串类型(String),其值可以是 `stat`, `get`, `delete` 中的一种
494
+
495
+ bucket
496
+ : 必须,字符串类型(String),空间名称。
497
+
498
+ keys
499
+ : 必须,数组类型(Array),所要操作 `key` 的集合。
500
+
501
+ **返回值**
502
+
503
+ 如果请求失败,返回 `false`,否则返回一个 `Array` 类型的结构,其中每个元素是一个 `Hash` 类型的结构。例如批量`get`:
504
+
505
+ [
506
+ {
507
+ "code" => 200,
508
+ "data" => {
509
+ "expires" => 3600,
510
+ "fsize" => 3053,
511
+ "hash" => "Fu9lBSwQKbWNlBLActdx8-toAajv",
512
+ "mimeType" => "application/x-ruby",
513
+ "url" => "http://iovip.qbox.me/file/<an-authorized-token>"
514
+ }
515
+ },
516
+ ...
517
+ ]
518
+
519
+ <a name="batch-get"></a>
520
+
521
+ #### 批量获取文件属性信息
522
+
523
+ Qiniu::RS.batch_get(bucket, keys)
524
+
525
+ `Qiniu::RS.batch_get` 函数是在 `Qiniu::RS.batch` 之上的封装,提供批量获取文件属性信息(含下载链接)的功能。
526
+
527
+ **参数**
528
+
529
+ bucket
530
+ : 必须,字符串类型(String),空间名称。
531
+
532
+ keys
533
+ : 必须,数组类型(Array),所要操作 `key` 的集合。
534
+
535
+ **返回值**
536
+
537
+ 如果请求失败,返回 `false`,否则返回一个 `Array` 类型的结构,其中每个元素是一个 `Hash` 类型的结构。`Hash` 类型的值同 `Qiniu::RS.get` 函数的返回值类似,只多出一个 `code` 字段,`code` 为 200 表示所有 keys 全部获取成功,`code` 若为 298 表示部分获取成功。
538
+
539
+ [
540
+ {
541
+ "code" => 200,
542
+ "data" => {
543
+ "expires" => 3600,
544
+ "fsize" => 3053,
545
+ "hash" => "Fu9lBSwQKbWNlBLActdx8-toAajv",
546
+ "mimeType" => "application/x-ruby",
547
+ "url" => "http://iovip.qbox.me/file/<an-authorized-token>"
548
+ }
549
+ },
550
+ ...
551
+ ]
552
+
553
+
554
+ <a name="batch-copy"></a>
555
+
556
+ #### 批量复制文件
557
+
558
+ Qiniu::RS.batch_copy(*args)
559
+
560
+ 等价于,
561
+
562
+ Qiniu::RS.batch_copy [source_bucket, source_key, target_bucket, target_key], ...
563
+
564
+ `Qiniu::RS.batch_copy()` 的参数是一个可变长数组,其中每个数组其元素含义同 `Qiniu::RS.copy` 的参数一样。
565
+
566
+ **返回值**
567
+
568
+ 如果批量删除成功,返回 `true` ,否则为 `false` 。
569
+
570
+
571
+ <a name="batch-move"></a>
572
+
573
+ #### 批量移动文件
574
+
575
+ Qiniu::RS.batch_move(*args)
576
+
577
+ 等价于,
578
+
579
+ Qiniu::RS.batch_move [source_bucket, source_key, target_bucket, target_key], ...
580
+
581
+ `Qiniu::RS.batch_move()` 的参数是一个可变长数组,其中每个数组其元素含义同 `Qiniu::RS.move` 的参数一样。
582
+
583
+ **返回值**
584
+
585
+ 如果批量删除成功,返回 `true` ,否则为 `false` 。
586
+
587
+
588
+ <a name="batch-delete"></a>
589
+
590
+ #### 批量删除文件
591
+
592
+ Qiniu::RS.batch_delete(bucket, keys)
593
+
594
+ `Qiniu::RS.batch_download` 函数也是在 `Qiniu::RS.batch` 之上的封装,提供批量删除文件的功能。
595
+
596
+ 参数同 `Qiniu::RS.batch_get` 的参数一样。
597
+
598
+ **返回值**
599
+
600
+ 如果批量删除成功,返回 `true` ,否则为 `false` 。
601
+
602
+
603
+ <a name="cloud-processing"></a>
604
+
605
+ ### 云处理
606
+
607
+ <a name="image-processing"></a>
608
+
609
+ #### 图像
610
+
611
+ <a name="image-info"></a>
612
+
613
+ ##### 查看图片属性信息
614
+
615
+ Qiniu::RS.image_info(url)
616
+
617
+ 使用 SDK 提供的 `Qiniu::RS.image_info` 方法,可以基于一张存储于七牛云存储服务器上的图片,针对其下载链接来获取该张图片的属性信息。
618
+
619
+ **参数**
620
+
621
+ url
622
+ : 必须,字符串类型(String),图片的下载链接,需是 `Qiniu::RS.get`(或`Qiniu::RS.batch_get`)函数返回值中 `url` 字段的值,或者是 `Qiniu::RS.download`(或`Qiniu::RS.batch_download`)函数返回的下载链接。且文件本身必须是图片。
623
+
624
+ **返回值**
625
+
626
+ 如果请求失败,返回 `false`;否则,返回如下一个 `Hash` 类型的结构:
627
+
628
+ {
629
+ "format" => "jpeg",
630
+ "width" => 640,
631
+ "height" => 425,
632
+ "colorModel" => "ycbcr"
633
+ }
634
+
635
+ format
636
+ : 原始图片类型
637
+
638
+ width
639
+ : 原始图片宽度,单位像素
640
+
641
+ height
642
+ : 原始图片高度,单位像素
643
+
644
+ colorModel
645
+ : 原始图片着色模式
646
+
647
+ <a name="image-exif"></a>
648
+
649
+ ##### 查看图片EXIF信息
650
+
651
+ Qiniu::RS.image_exif(url)
652
+
653
+ 使用 SDK 提供的 `Qiniu::RS.image_exif` 方法,可以基于一张存储于七牛云存储服务器上的原始图片图片,取到该图片的 EXIF 信息。
654
+
655
+ **参数**
656
+
657
+ url
658
+ : 必须,字符串类型(String),原图的下载链接,需是 `Qiniu::RS.get`(或`Qiniu::RS.batch_get`)函数返回值中 `url` 字段的值,或者是 `Qiniu::RS.download`(或`Qiniu::RS.batch_download`)函数返回的下载链接。且文件本身必须是图片。
659
+
660
+ **返回值**
661
+
662
+ 如果参数 `url` 所代表的图片没有 EXIF 信息,返回 `false`。否则,返回一个包含 EXIF 信息的 Hash 结构。
663
+
664
+ <a name="image-mogrify-for-preview"></a>
665
+
666
+ ##### 图像在线处理(缩略、裁剪、旋转、转化)
667
+
668
+ `Qiniu::RS.image_mogrify_preview_url()` 方法支持将一个存储在七牛云存储的图片进行缩略、裁剪、旋转和格式转化处理,该方法返回一个可以直接预览缩略图的URL。
669
+
670
+ image_mogrify_preview_url = Qiniu::RS.image_mogrify_preview_url(source_image_url, mogrify_options)
671
+
672
+ **参数**
673
+
674
+ source_image_url
675
+ : 必须,字符串类型(string),指定原始图片的下载链接,可以根据 rs.get() 获取到。
676
+
677
+ mogrify_options
678
+ : 必须,Hash Map 格式的图像处理参数。
679
+
680
+ `mogrify_options` 对象具体的规格如下:
681
+
682
+ mogrify_options = {
683
+ :thumbnail => <ImageSizeGeometry>,
684
+ :gravity => <GravityType>, =NorthWest, North, NorthEast, West, Center, East, SouthWest, South, SouthEast
685
+ :crop => <ImageSizeAndOffsetGeometry>,
686
+ :quality => <ImageQuality>,
687
+ :rotate => <RotateDegree>,
688
+ :format => <DestinationImageFormat>, =jpg, gif, png, tif, etc.
689
+ :auto_orient => <TrueOrFalse>
690
+ }
691
+
692
+ `Qiniu::RS.image_mogrify_preview_url()` 方法是对七牛云存储图像处理高级接口的完整包装,关于 `mogrify_options` 参数里边的具体含义和使用方式,可以参考文档:[图像处理高级接口](http://docs.qiniu.com/api/image-process.html#imageMogr)。
693
+
694
+ **返回值**
695
+
696
+ 返回一个可以预览最终缩略图的URL,String 类型。
697
+
698
+ <a name="image-mogrify-for-save-as"></a>
699
+
700
+ #### 图像在线处理(缩略、裁剪、旋转、转化)后并持久化存储
701
+
702
+ `Qiniu::RS.image_mogrify_save_as()` 方法支持将一个存储在七牛云存储的图片进行缩略、裁剪、旋转和格式转化处理,并且将处理后的缩略图作为一个新文件持久化存储到七牛云存储服务器上,这样就可以供后续直接使用而不用每次都传入参数进行图像处理。
703
+
704
+ result = Qiniu::RS.image_mogrify_save_as(target_bucket, target_key, src_img_url, mogrify_options)
705
+
706
+ **参数**
707
+
708
+ target_bucket
709
+ : 必须,字符串类型(string),指定最终缩略图要存放的 bucket 。
710
+
711
+ target_key
712
+ : 必须,字符串类型(string),指定最终缩略图存放在云存储服务端的唯一文件ID。
713
+
714
+ src_img_url
715
+ : 必须,字符串类型(string),指定原始图片的下载链接,可以根据 rs.get() 获取到。
716
+
717
+ mogrify_options
718
+ : 必须,Hash Map 格式的图像处理参数。
719
+
720
+ `mogrify_options` 对象具体的规格如下:
721
+
722
+ mogrify_options = {
723
+ :thumbnail => <ImageSizeGeometry>,
724
+ :gravity => <GravityType>, =NorthWest, North, NorthEast, West, Center, East, SouthWest, South, SouthEast
725
+ :crop => <ImageSizeAndOffsetGeometry>,
726
+ :quality => <ImageQuality>,
727
+ :rotate => <RotateDegree>,
728
+ :format => <DestinationImageFormat>, =jpg, gif, png, tif, etc.
729
+ :auto_orient => <TrueOrFalse>
730
+ }
731
+
732
+ `Qiniu::RS::Image.mogrify_preview_url()` 方法是对七牛云存储图像处理高级接口的完整包装,关于 `mogrify_options` 参数里边的具体含义和使用方式,可以参考文档:[图像处理高级接口](http://docs.qiniu.com/api/image-process.html#imageMogr)
733
+
734
+ **返回值**
735
+
736
+ 如果请求失败,返回 `false`;否则,返回如下一个 `Hash` 类型的结构:
737
+
738
+ {"hash" => "FrOXNat8VhBVmcMF3uGrILpTu8Cs"}
739
+
740
+ 示例代码:
741
+
742
+ data = Qiniu::RS.get("<test_image_bucket>", "<test_image_key>")
743
+ src_img_url = data["url"]
744
+
745
+ target_bucket = "test_thumbnails_bucket"
746
+ target_key = "cropped-" + @test_image_key
747
+
748
+ mogrify_options = {
749
+ :thumbnail => "!120x120r",
750
+ :gravity => "center",
751
+ :crop => "!120x120a0a0",
752
+ :quality => 85,
753
+ :rotate => 45,
754
+ :format => "jpg",
755
+ :auto_orient => true
756
+ }
757
+
758
+ result = Qiniu::RS.image_mogrify_save_as(target_bucket, target_key, src_img_url, mogrify_options)
759
+ if result
760
+ thumbnail = Qiniu::RS.get(target_bucket, target_key)
761
+ puts thumbnail["url"]
762
+
763
+ # 您可以选择将存放缩略图的 bucket 公开,这样就可以直接以外链的形式访问到缩略图,而不用走API获取下载URL,就可以直接以如下方式访问缩略图:
764
+
765
+ # [GET] http://<bucket>.qiniudn.com/<target_key>
766
+ end
767
+
768
+
769
+ <a name="Contributing"></a>
770
+
771
+ ## 贡献代码
772
+
773
+ 七牛云存储 Ruby SDK 源码地址:<https://github.com/qiniu/ruby-sdk>
774
+
775
+ 1. 登录 <https://github.com>
776
+ 2. Fork <https://github.com/qiniu/ruby-sdk>
777
+ 3. 创建您的特性分支 (`git checkout -b my-new-feature`)
778
+ 4. 提交您的改动 (`git commit -am 'Added some feature'`)
779
+ 5. 将您的改动记录提交到远程 `git` 仓库 (`git push origin my-new-feature`)
780
+ 6. 然后到 github 网站的该 `git` 远程仓库的 `my-new-feature` 分支下发起 Pull Request
781
+
782
+ <a name="License"></a>
783
+
784
+ ## 许可证
785
+
786
+ Copyright (c) 2012 qiniutek.com
787
+
788
+ 基于 MIT 协议发布:
789
+
790
+ * [www.opensource.org/licenses/MIT](http://www.opensource.org/licenses/MIT)