云存储,就是把本地的资源文件存放至网络上,可以公网访问。相当于网盘功能,感觉非常方便。
这里介绍的是七牛云存储。有兴趣的可以去官方网站详看
根据官网的介绍,本身是提供SDK的,下载地址,大家可以根据自己开发的应用程序,下载对应的SDK包。我下载的是C#版本,参考对应的API文档,会发现最新SDK源码和API文档不一致。是的,文档还没有及时更新
因此,我在这里重新封装一层,直接调用即可。代码如下
先定义若干属性(注册七牛用户时,由系统发放)
public static string AccessKey = null;
public static string SecretKey = null;
public static string Bucket = null;
public static string UrlPrefix { get; set; }
上传文件
public static void UploadFile(string localFile, string saveKey)
{
// 上传策略
PutPolicy putPolicy = new PutPolicy(); // 设置要上传的目标空间
putPolicy.Scope = QiniuUtil.Bucket; // 上传策略的过期时间(单位:秒)
putPolicy.SetExpires(3600); //// 文件上传完毕后,在多少天后自动被删除
//putPolicy.DeleteAfterDays = 1; // 生成上传凭证
//参考地址:https://segmentfault.com/q/1010000008205978
string jsonParam = JsonHelper.GetJsonByObject(putPolicy);
Mac mac = new Mac(QiniuUtil.AccessKey, QiniuUtil.SecretKey);
string uploadToken = Auth.CreateUploadToken(mac, jsonParam); FormUploader upLoader = new FormUploader(false);
HttpResult result = upLoader.UploadFile(localFile, saveKey, uploadToken);
if (result.Code != 200)
{
throw new Exception(result.RefText);
} return;
}
下载文件
public static void DownloadFile(string url, string localFileFullName)
{
//文件链接地址:http://oio2cxdal.bkt.clouddn.com/1/20170213231810.jpg
DownloadManager.Download(url, localFileFullName);
}
删除文件
public static void DeleteFile(string saveKey)
{
Mac mac = new Mac(QiniuUtil.AccessKey, QiniuUtil.SecretKey);
BucketManager bm = new BucketManager(mac); bm.Delete(QiniuUtil.Bucket, saveKey);
}
SDK中还有其他方法,比如:断点续传之类的,如有需要可以继续封装
调用代码更简单
QiniuUtil.AccessKey = "";
QiniuUtil.SecretKey = "";
QiniuUtil.Bucket = "";
QiniuUtil.UrlPrefix = ""; string saveKey = @"1/20170213231810.jpg"; ////(OK)上传文件
//string localFile = @"d:\TestImage2.jpg";
//QiniuUtil.UploadFile(localFile, saveKey); ////(OK)下载文件
//string localFile = @"d:\111.jpg";
//QiniuUtil.DownloadFile("http://oio2cxdal.bkt.clouddn.com/1/20170213231810.jpg", localFile); //(OK)删除文件
QiniuUtil.DeleteFile(saveKey);
要注意的是,七牛会根据地区分配它的服务器,也就是说,如果你在华南,就不能使得华东的服务器操作。这里要修改下源码,位置如下
没有源码,直接调用方法Config.SetZone即可
看,是不是so easy