• 阿里云储存代码整理(由三卷天书整理)


    最近不是很忙,就看了下阿里云储存,整理出来方法,为以后改版微笑话网内容多的时候用云储存准备,现在贴出来,希望对大家有所帮助,本文有博客园 三卷天书原创,转载请注明出处,谢谢!

    直接贴代码了,就一个帮助类,直接调用里面的方法就OK了的,如果有什么地方出错,麻烦各位在回复区指出。

    /// <summary>
        /// 阿里云储存帮助类(欢迎访问www.weixh.net微笑话,帮我涨点人气谢谢大家了)
        /// </summary>
        public class AliyunHelper
        {
            const string accessKeyId = "<your access key id>";
            const string accessKeySecret = "<your access key secret>";
            const string endpoint = "<valid host name>";
            #region 上传部分
            /// <summary>
            /// 简单上传文件
            /// </summary>
            /// <param name="file">上传控件</param>
            /// <param name="key">文件标识</param>
            /// <param name="bucketName">空间名</param>
            public static string AliyunUploadFile(FileUpload file, string key, string bucketName)
            {
                try
                {
                    Stream sr = file.PostedFile.InputStream;
                    var client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                    var result = client.PutObject(bucketName, key, sr);
                    return "succeeded";
                }
                catch (OssException ex)
                {
                    return "上传失败:" + ex.ErrorCode;
                }
                catch (Exception ex)
                {
                    return ex.Message;
                }
            }
            /// <summary>
            /// 简单上传文件
            /// </summary>
            /// <param name="file">上传控件</param>
            /// <param name="key">文件标识</param>
            /// <param name="bucketName">空间名</param>
            public static string AliyunUploadFile(HttpPostedFile file, string key, string bucketName)
            {
                try
                {
                    Stream sr = file.InputStream;
                    var client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                    var result = client.PutObject(bucketName, key, sr);
                    return "succeeded";
                }
                catch (OssException ex)
                {
                    return "上传失败:" + ex.ErrorCode;
                }
                catch (Exception ex)
                {
                    return ex.Message;
                }
            }
            /// <summary>
            /// 分片上传
            /// </summary>
            /// <param name="bucketName">空间名</param>
            /// <param name="key">唯一标识</param>
            /// <param name="file">上传控件</param>
            /// <param name="partSize">每片大小(默认5MB)</param>
            /// <returns></returns>
            public static string AliyunUploadPart(string bucketName, string key, FileUpload file, int partSize = 5*1024*1024)
            {
                try
                {
                    Stream sr = file.PostedFile.InputStream;
                    OssClient client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                    client.PutBigObject(bucketName, key, sr, null, partSize);
                    return "succeeded";
                }
                catch (OssException ex)
                {
                    return "上传失败:" + ex.ErrorCode;
                }
                catch (Exception ex)
                {
                    return "上传失败:" + ex.Message;
                }
    
            }
            /// <summary>
            /// 分片上传
            /// </summary>
            /// <param name="bucketName">空间名</param>
            /// <param name="objectName">key</param>
            /// <param name="fileToUpload">指定分片上传文件路径</param>
            /// <param name="partSize">分片大小(单位:字节)</param>
            public static void UploadMultipart(String bucketName, String key, FileUpload file, int partSize = 5*1024*1024)
            {
                var uploadId = InitiateMultipartUpload(bucketName, key);
                var partETags = UploadParts(bucketName, key, file, uploadId, partSize);
                var completeResult = CompleteUploadPart(bucketName, key, uploadId, partETags);
                //Console.WriteLine(@"Upload multipart result : " + completeResult.Location);
            }
            private static string InitiateMultipartUpload(String bucketName, String objectName)
            {
                var request = new InitiateMultipartUploadRequest(bucketName, objectName);
                OssClient client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                var result = client.InitiateMultipartUpload(request);
                return result.UploadId;
            }
            private static List<PartETag> UploadParts(String bucketName, String objectName, FileUpload file, String uploadId, int partSize)
            {
                var fileSize = file.PostedFile.ContentLength;
                var partCount = fileSize / partSize;
                if (fileSize % partSize != 0)
                {
                    partCount++;
                }
    
                var partETags = new List<PartETag>();
                using (var sr = file.PostedFile.InputStream)
                {
                    for (var i = 0; i < partCount; i++)
                    {
                        var skipBytes = (long)partSize * i;
                        sr.Seek(skipBytes, 0);
                        var size = (partSize < fileSize - skipBytes) ? partSize : (fileSize - skipBytes);
                        var request = new UploadPartRequest(bucketName, objectName, uploadId)
                        {
                            InputStream = sr,
                            PartSize = size,
                            PartNumber = i + 1
                        };
                        OssClient client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                        var result = client.UploadPart(request);
                        partETags.Add(result.PartETag);
                    }
                }
                return partETags;
            }
            private static CompleteMultipartUploadResult CompleteUploadPart(String bucketName, String objectName, String uploadId, List<PartETag> partETags)
            {
                var completeMultipartUploadRequest =
                    new CompleteMultipartUploadRequest(bucketName, objectName, uploadId);
                foreach (var partETag in partETags)
                {
                    completeMultipartUploadRequest.PartETags.Add(partETag);
                }
                OssClient client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                return client.CompleteMultipartUpload(completeMultipartUploadRequest);
            }
            #endregion
            #region URL访问
            /// <summary>
            /// URL获取
            /// </summary>
            /// <param name="bucketName"></param>
            /// <param name="key"></param>
            /// <returns></returns>
            public static string GetUrlGet(string bucketName, string key)
            {
                var req = new GeneratePresignedUriRequest(bucketName, key, SignHttpMethod.Get)
                {
                    Expiration = new DateTime().AddHours(1)
                };
                var client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                var uri = client.GeneratePresignedUri(req);
                return uri.ToString();
            }
            /// <summary>
            /// URL获取
            /// </summary>
            /// <param name="bucketName"></param>
            /// <param name="key"></param>
            /// <param name="timeMinutes">过期时间(分)</param>
            /// <returns></returns>
            public static string GetUrlGet(string bucketName, string key, int timeMinutes)
            {
                var req = new GeneratePresignedUriRequest(bucketName, key, SignHttpMethod.Get)
                {
                    Expiration = new DateTime().AddMinutes(timeMinutes)
                };
                var client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                var uri = client.GeneratePresignedUri(req);
                return uri.ToString();
            }
            #endregion
            #region 文件下载
    
    
            /// <summary>
            /// 从指定的OSS存储空间中获取指定的文件
            /// </summary>
            /// <param name="bucketName">要获取的文件所在的存储空间的名称</param>
            /// <param name="key">要获取的文件的名称</param>
            /// <param name="fileToDownload">文件保存的本地路径</param>
            public static string GetObject(string bucketName, string key, string fileToDownload)
            {
                try
                {
                    // 初始化OssClient
                    var client = new OssClient(endpoint, accessKeyId, accessKeySecret);
                    var obj = client.GetObject(bucketName, key);
                    using (var requestStream = obj.Content)
                    {
                        byte[] buf = new byte[1024];
                        var fs = File.Open(fileToDownload, FileMode.OpenOrCreate);
                        var len = 0;
                        while ((len = requestStream.Read(buf, 0, 1024)) != 0)
                        {
                            fs.Write(buf, 0, len);
                        }
                        fs.Close();
                    }
    
                    return "succeeded";
                }
                catch (Exception ex)
                {
                    return ex.Message;
                }
            }
            #endregion
        }

    转载请注明出处。

  • 相关阅读:
    管道/重定向/环境变量
    用户和组命令
    常用命令
    系统监控及进程
    Centos硬件信息
    Centos系统信息及日志
    linux防火墙
    ipt_connlimit限制并发,ipt_recent限制单位时间内的请求数目
    apache添加mod_limitipconn限制单个ip并发连接数
    php核心技术与最佳实践知识点(下)
  • 原文地址:https://www.cnblogs.com/sanjuantianshu/p/5056936.html
Copyright © 2020-2023  润新知