Skip to content

tencentyun/cos-cpp-sdk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

cos-cpp-sdk

已弃用 - 请升级到 cos-cpp-sdk-v5

SDK 已弃用,请直接使用基于 XML API 的 cos-cpp-sdk-v5

##linux等类UINX系统使用手册 ##需要安装的库和工具 openssl: ubuntu下运行 sudo apt-get install libssl-dev 安装
其他类uinx系统按照各自的方法安装好该库

curl: 在 Ubuntu 12.04.2 LTS,linux 版本 3.13.0-32-generic,编译了.a放在lib目录下。
如果有问题,在http://curl.haxx.se/download/curl-7.43.0.tar.gz 下载源码,
编译生成 .a 或者 .so 放到 lib目录下,替换掉原来的libcurl.a

jsoncpp: 在 Ubuntu 12.04.2 LTS,linux 版本 3.13.0-32-generic,编译了.a放在lib目录下。
如果有问题,在 https://github.com/open-source-parsers/jsoncpp 下载源码,
编译生成 .a 或者 .so 放到 lib目录下,替换掉原来的libjsoncpp.a

cmake: 去http://www.cmake.org/download/ 下载cmake安装好即可

##编译生成静态库.a 执行下面的命令
cd ${cos-cpp-sdk}
mkdir -p build
cd build
cmake ..
make

需要将cos_demo.cpp里的appid、secretId、secretKey、bucket等信息换成你自己的。
生成的cos_demo就可以直接运行,试用,

生成的静态库,名称为:libcosdk.a

##将生成的库链接进自己的项目 生成的libcosdk.a放到你自己的工程里lib路径下,
include目录下的 auth_utility.h cosapi.h curl json openssl都放到你自己的工程的include路径下。

例如我的项目里只有一个cos_demo.cpp,项目目录和sdk在同级目录,copy libcosdk.a 到项目所在目录
那么编译命令为:
g++ -o cos_demo cos_demo.cpp -I ./include/ -L. -L../cos-cpp-sdk/lib/ -lcosdk -lcurl -lcrypto -lssl -lrt -ljsoncpp

#windows系统暂时不支持

#sample例子 使用接口前,必须调用:
qcloud_cos::COS_Init();
CosApiClientOption client_option("your appid", "your secretId", "your secretKey", "interface timeout"); Cosapi api(client_option);

注意cos上的path以 / 开头

##计算多次签名,静态函数任何地方可以直接调用 string sign = AuthUtility::AppSignMuti( "your appid", "your secretId", "your secretKey", "expired unix timestamp", "bucketName");

##创建目录 api.CreateFolder( "bucketName", "/test/");

##listFolder目录下文件列表 api.ListFolder("bucketName", "/", 10);

##prefixSearch前缀搜索 api.PrefixSearch("bucketName", "/test", 10);

##更新目录属性 api.UpdateFolder( bucketName, "/test/", "attr");

##更新文件属性 api.Update( bucketName, "/test.log", "attr");

##statFolder查询目录 api.StatFolder( bucketName, "/test/");

##stat查询文件 //可以用来判断文件是否存在 api.Stat( bucketName, "/test.log");

##删除目录 api.DeleteFolder( "bucketName", "/test/");

##删除文件 api.DelFile( "bucketName", "/test.log");

##上传文件 api.Upload( "srcPath", "bucketName",- "/dstPath");

##大文件分片上传 //sliceSize参数可以指定分片大小,默认是 512KB //后台允许的最大分片大小是3MB //如果中途失败,以相同的参数再次调用upload_slice可以自动断点续传 api.UploadSlice( "srcPath", "bucketName",- "/dstPath", "", 310241024);