微信小程序基于腾讯云对象存储的图片上传功能
更新时间:2018年03月20日 10:54:26 作者:灵动生活
这篇文章主要介绍了微信小程序基于腾讯云对象存储的图片上传功能,需要的朋友可以参考下
在使用腾讯云对象存储之前,公司一直使用的是传统的FTP的上传模式,而随着用户量的不断增加,FTP所暴露出来的问题也越来越多,1.传输效率低,上传速度慢。2.时常有上传其他文件来攻击服务器,安全上得不到保障。所以我们在经过慎重考虑觉得使用第三方的云存储服务。
在最开始的时候我们在腾讯云与阿里云中选择,最终我们选择腾讯云,腾讯云在文件上传用时方面的性能比较突出,文件越大表现越好;在下载用时方面表现略优于阿里云;文件删除用时方面总体速度略逊于,但在不同大小文件删除用时上都比较稳定。当然这与我们主要用于开发微信小程序是有着密切的关系。
在我们酷客多小程序使用腾讯云对象存储的时候除了直接使用 API 接口外,COS 提供了丰富多样的 SDK 给我们使用,可是在他提供的SDK中并没有发现我们Asp.net相关的SDK
在一番百度和一顿操作终于让我找到啦!看到没,只能说隐藏的真深,而且还是历史版本的,但是不管怎么样我们还是找到啦
找到C#的SDK,下载下来 (附上C#版本SDK的下载地址 C# SDK github项目下载地址)然后按照SDK中提供的方法,就可以成功上传!
然而并没有这么简单,当我们使用SDK中的方法的时候发现,SDK中的方法只适用于,绝对路径地址的文件上传!也就是并不满足我们ASP.Net中使用文件域上传文件。此时我们只有对方法进行改造!
附上改造过后代码:
/// <summary>
/// 文件流上传
/// 说明: 酷客多小程序
/// 其中分片上传使用SliceUploadInit SliceUploadData SliceUploadFinihs
/// </summary>
/// <param name=”bucketName”>bucket名称</param>
/// <param name=”remotePath”>远程文件路径</param>
/// <param name=”localPath”>本地文件路径</param>
/// <param name=”parameterDic”>参数Dictionary</param>
/// <returns></returns>
public string UploadFile(string bucketName, string remotePath, Stream file, string filename,Dictionary<string, string> parameterDic = null)
{
if (remotePath.EndsWith(“/”))
{
return constructResult(ERRORCode.ERROR_CODE_PARAMETER_ERROE, “file path can not end with ‘/'”);
}
string bizAttribute = “”;
if (parameterDic != null && parameterDic.ContainsKey(CosParameters.PARA_BIZ_ATTR))
bizAttribute = parameterDic[CosParameters.PARA_BIZ_ATTR];
int insertOnly = 1;
if (parameterDic != null && parameterDic.ContainsKey(CosParameters.PARA_INSERT_ONLY))
{
try
{
insertOnly = Int32.Parse(parameterDic[CosParameters.PARA_INSERT_ONLY]);
}
catch (Exception e)
{
Console.WriteLine(e.Message);
return constructResult(ERRORCode.ERROR_CODE_PARAMETER_ERROE, “parameter insertOnly value invalidate”);
}
}
return Upload(bucketName, remotePath, file, filename, bizAttribute, insertOnly);
}
/// <summary>
/// 单个文件上传
/// 说明: 酷客多小程序
/// <param name=”bucketName”>bucket名称</param>
/// <param name=”remotePath”>远程文件路径</param>
/// <param name=”localPath”>本地文件路径</param>
/// <param name=”biz_attr”>biz_attr属性</param>
/// <param name=”insertOnly”>同名文件是否覆盖</param>
/// <returns></returns>
public string Upload(string bucketName, string remotePath, Stream file,string filename,
string bizAttribute = “”, int insertOnly = 1)
{
var url = generateURL(bucketName, remotePath);
var sha1 = SHA1.GetFileSHA1(file);
var data = new Dictionary<string, object>();
data.Add(“op”, “upload”);
data.Add(“sha”, sha1);
data.Add(“biz_attr”, bizAttribute);
data.Add(“insertOnly”, insertOnly);
var expired = getExpiredTime();
var sign = Sign.Signature(appId, secretId, secretKey, expired, bucketName);
var header = new Dictionary<string, string>();
header.Add(“Authorization”, sign);
return httpRequest.SendRequest(url, ref data, HttpMethod.Post, ref header, timeOut, file, filename);
}
#region 直接上传文件流
public string SendRequest(string url, ref Dictionary<string, object> data, HttpMethod requestMethod,
ref Dictionary<string, string> header, int timeOut, Stream file,string filename, long offset = -1, int sliceSize = 0)
{
try
{
//Console.WriteLine(“url:” + url);
System.Net.ServicePointManager.Expect100Continue = false;
if (requestMethod == HttpMethod.Get)
{
var paramStr = “”;
foreach (var key in data.Keys)
{
paramStr += string.Format(“{0}={1}&”, key, HttpUtility.UrlEncode(data[key].ToString()));
}
paramStr = paramStr.TrimEnd(‘&’);
url += (url.EndsWith(“?”) ? “&” : “?”) + paramStr;
}
request = (HttpWebRequest)HttpWebRequest.Create(url);
request.Accept = CosDefaultValue.ACCEPT;
request.KeepAlive = true;
request.UserAgent = CosDefaultValue.USER_AGENT_VERSION;
request.Timeout = timeOut;
foreach (var key in header.Keys)
{
if (key == “Content-Type”)
{
request.ContentType = header[key];
}
else
{
request.Headers.Add(key, header[key]);
}
}
if (requestMethod == HttpMethod.Post)
{
request.Method = requestMethod.ToString().ToUpper();
var memStream = new MemoryStream();
if (header.ContainsKey(“Content-Type”) && header[“Content-Type”] == “application/json”)
{
var json = JsonConvert.SerializeObject(data);
var jsonByte = Encoding.GetEncoding(“utf-8”).GetBytes(json.ToString());
memStream.Write(jsonByte, 0, jsonByte.Length);
}
else
{
var boundary = “—————” + DateTime.Now.Ticks.ToString(“x”);
var beginBoundary = Encoding.ASCII.GetBytes(“\\r\\n–” + boundary + “\\r\\n”);
var endBoundary = Encoding.ASCII.GetBytes(“\\r\\n–” + boundary + “–\\r\\n”);
request.ContentType = “multipart/form-data; boundary=” + boundary;
var strBuf = new StringBuilder();
foreach (var key in data.Keys)
{
strBuf.Append(“\\r\\n–” + boundary + “\\r\\n”);
strBuf.Append(“Content-Disposition: form-data; name=\\”” + key + “\\”\\r\\n\\r\\n”);
strBuf.Append(data[key].ToString());
}
var paramsByte = Encoding.GetEncoding(“utf-8”).GetBytes(strBuf.ToString());
memStream.Write(paramsByte, 0, paramsByte.Length);
memStream.Write(beginBoundary, 0, beginBoundary.Length);
var fileStream = file;
const string filePartHeader =
“Content-Disposition: form-data; name=\\”fileContent\\”; filename=\\”{0}\\”\\r\\n” +
“Content-Type: application/octet-stream\\r\\n\\r\\n”;
var headerText = string.Format(filePartHeader, filename);
var headerbytes = Encoding.UTF8.GetBytes(headerText);
memStream.Write(headerbytes, 0, headerbytes.Length);
if (offset == -1)
{
var buffer = new byte[1024];
int bytesRead;
while ((bytesRead = fileStream.Read(buffer, 0, buffer.Length)) != 0)
{
memStream.Write(buffer, 0, bytesRead);
}
}
else
{
var buffer = new byte[sliceSize];
int bytesRead;
fileStream.Seek(offset, SeekOrigin.Begin);
bytesRead = fileStream.Read(buffer, 0, buffer.Length);
memStream.Write(buffer, 0, bytesRead);
}
fileStream.Close();
memStream.Write(endBoundary, 0, endBoundary.Length);
}
request.ContentLength = memStream.Length;
var requestStream = request.GetRequestStream();
memStream.Position = 0;
var tempBuffer = new byte[memStream.Length];
memStream.Read(tempBuffer, 0, tempBuffer.Length);
memStream.Close();
requestStream.Write(tempBuffer, 0, tempBuffer.Length);
requestStream.Close();
//Console.WriteLine(strBuf.ToString());
}
//Console.WriteLine(request.ContentType.ToString());
var response = request.GetResponse();
using (var s = response.GetResponseStream())
{
var reader = new StreamReader(s, Encoding.UTF8);
return reader.ReadToEnd();
}
}
catch (WebException we)
{
if (we.Status == WebExceptionStatus.ProtocolError)
{
using (var s = we.Response.GetResponseStream())
{
var reader = new StreamReader(s, Encoding.UTF8);
return reader.ReadToEnd();
}
}
else
{
throw we;
}
}
catch (Exception e)
{
throw e;
}
}
使用上面改造过后的方法直接传入文件流即可通过文本域的方式上传文件到腾讯云上面去!
总结
以上所述是小编给大家介绍的微信小程序基于腾讯云对象存储的图片上传功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对华域联盟网站的支持!
您可能感兴趣的文章:微信小程序实现图片上传放大预览删除代码tp5实现微信小程序多图片上传到服务器功能微信小程序实现图片上传功能微信小程序实现图片上传功能实例(前端+PHP后端)微信小程序实现图片上传、删除和预览功能的方法微信小程序多张图片上传功能微信小程序 图片上传实例详解微信小程序开发之从相册获取图片 使用相机拍照 本地图片上传微信小程序开发(二)图片上传+服务端接收详解微信小程序教程之本地图片上传(leancloud)实例详解微信小程序实现图片上传
微信小程序
图片上传
相关文章
.NET/ASP.NET Routing路由(深入解析路由系统架构原理)这篇文章主要介绍了.NET/ASP.NET Routing路由(深入解析路由系统架构原理),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2018-07-07
很实用的NLog配置分享这篇文章主要给大家分享介绍了关于NLog配置的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧 2019-07-07
ASP.NET中内嵌页面代码的一个问题如果页面继承了一个父页面,而且当前页面用new覆盖了父页面的某个属性 2010-02-02
.NET中用ICSharpCode.TextEditor自定义代码折叠与高亮这篇文章主要给大家介绍了.NET中用ICSharpCode.TextEditor自定义代码折叠与高亮的相关资料,文中通过示例代码与图片介绍的很详细,需要的朋友可以参考借鉴,下面来一起看看吧。 2017-02-02
asp.net Request获取url信息的各种方法比较Request 获取url信息的各种方法比较 2010-03-03
ASP.net实现页面跳转的方法在ASP.NET进行页面开发时候经常遇到需要进行页面跳转的操作。这个其实并不难,关键是知不知道的问题。下面给出操作方法。 2013-06-06
GridView生成的HTML代码示例对比很多初学者都奇怪GridView生成的HTML代码到底是什么,下面有个示例对比,需要的朋友可以参考下 2014-02-02
超好用轻量级MVC分页控件JPager.Net本文给大家分享的是一款超好用轻量级MVC分页控件–JPager.Net,小编自己也在使用,非常的不错,推荐给大家。 2016-06-06
使用母版页时内容页如何使用css和javascript由于网站的主要频道页和列表页的头部和底部都是一样的,如果将每个页面放在单独的页面中,当头部和底部需要更改时维护量太大。于是想把头部和底部做成母版页,频道页和列表页的具体内容放到内容页中。这样当头和底需要改动时,只要修改一下母版页就可以了。 2009-08-08
httpHandler实现.Net无后缀名Web访问的实现解析有时候我们看到很多网站是网址是没有后缀名的,其实.net中可以通过httpHandler来实现。 2011-10-10
最新评论

评论(0)