《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

时间:2022-08-26 14:45:17

两个月前的发布的博客《介绍一款开源的类Excel电子表格软件》引起了热议:在博客园有近2000个View、超过20个评论。 同时有热心读者电话咨询如何能够在SpreadDesing中实现存储Excel云文件,既通过云方式读取、加载Excel文件。在本文,我们就大家关心的云存储进行实战操练---基于SpreadDesign源码基础。

系统必备:

  • 本文选用的国内比较流行的七牛云存储。
  • SpreadDesign.exe已经升级为最新的Spread Studio 8.35.20143.0内核
  • .Netframework 4.0
  • Windows 8.1 64系统
  • Visual Studio 2013 社区版

要实现的功能列表如下:

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

注册七牛云存储账号(有账号的请跳过本节)

七牛云存储 - 主页 http://www.qiniu.com/ (友情给七牛做个宣传,多谢七牛给葡萄城控件提供的七牛云存储优惠券)

七牛云存储的核心团队成员来自于盛大、金山、网龙、惠普等知名互联网公司。核心成员之间已合作多年。公司创始人许式伟先生曾在金山、百度和盛大等公司担任重要领导岗位,具有多年存储行业实战经验,被誉为国内最适合做云存储的几人之一。

话说7牛云存储大有来头!区别于国内外其他云存储,七牛自行研发的全分布式架构解决了其他云存储单一数据中心架构可能存在的风险,同时首创双向加速特性对数据上传下载均加速,使得数据访问速度较传统方案平均提升 50%以上。此外,镜像存储客户端直传断点续上传云端富媒体处理等七牛云存储独有的功能也大大提升了开发效率,最大程度减少了服务器资源浪费。

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

七牛官方新手上路链接

体验用户:

      • 储存空间1GB
      • 每月Put请求1万次
      • 每月下载流量1GB
      • 每月Get请求10万次
      • 创建1个空间
      • 仅支持富媒体上传

升级为标准用户:

      • 储存空间10GB
      • 每月Put请求10万次
      • 每月下载流量10GB
      • 每月Get请求100万次
      • 创建20个空间
      • 使用七牛的全部功能

7牛云存储需要3个信息就可以使用了。

1,AK(AccessKey)

2,SK(SecretKey)

3,  Bucket

进入账号设置-密钥可以找到如下信息:

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

关于公钥、秘钥的安全问题,请参见官方的《公钥密钥应该放在哪里?

配置一个空间(Bucket),如在本文中我使用的是“grapecity”的空间---空间注意大小写要和代码中一致:

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

配置七牛云C#开发环境

七牛开发者中心中,我们可以看到七牛提供了很多SDK:

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

点击《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)跳转到C# SDK 使用指南的页面。

通过七牛官网提供的URL,下载七牛的C# SDK,以及第三方的开源项目 Json.NET。

同时在GCDN社区,也提供了下载镜像:http://gcdn.gcpowertools.com.cn/showtopic.aspx?topicid=13778&postid=73156#73156

配置很容易,添加这2个dll引用即可:

Qiniu.DLL

Newtonsoft.Json.dll

代码实现

初始化七牛SDK代码

Qiniu.Conf.Config.ACCESS_KEY = "5iujaJ62Q9eQc94uF0sgFzxwVTP-9c_hKq_2jC-j";
Qiniu.Conf.Config.SECRET_KEY = "RMRV45M6J-GpLvz2pAgndn3i-MmTxnDcJMqwsWKG"; private const string Bucket = "grapecity";
private const string Domain = Bucket + ".qiniudn.com";

注:ACCESS_KEY、SECRET_KEY请自行通过七牛后台管理界面申请,每人可申请2对。

List文件列表代码

       public void List(ListView listView1, string bucket = Bucket)
{
Qiniu.RSF.RSFClient rsf = new Qiniu.RSF.RSFClient(bucket);
rsf.Prefix = "";
rsf.Limit = ;
List<DumpItem> items;
while ((items = rsf.Next()) != null)
{
foreach (DumpItem item in items)
{
Stat(listView1, item.Key, bucket);
}
}
} public void Stat(ListView listView1, string key, string bucket = Bucket)
{ RSClient client = new RSClient();
Entry entry = client.Stat(new EntryPath(bucket, key));
if (entry.OK)
{
ListViewItem item = new ListViewItem(new string[]{key, entry.MimeType,
DateTime.FromFileTime(entry.PutTime).ToLongDateString(), entry.Fsize.ToString()});
listView1.Items.Add(item);
}
else
{
Console.WriteLine("Failed to Stat");
}
}

注:key可使用文件名,中文的文件名也可以。

删除文件代码:

      public bool Delete(string key, string bucket = Bucket)
{
RSClient client = new RSClient();
CallRet ret = client.Delete(new EntryPath(bucket, key));
return ret.OK;
}

下载文件代码

        public string DownLoad(string key1, string domain = Domain)
{
string baseUrl = GetPolicy.MakeBaseUrl(domain, key1);
string private_url = GetPolicy.MakeRequest(baseUrl);
private_url = HttpUtility.UrlPathEncode(private_url); try
{
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(private_url);
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
Stream stream = response.GetResponseStream();
string newFile = AppDomain.CurrentDomain.BaseDirectory + key1;
FileStream write = new FileStream(newFile, FileMode.OpenOrCreate); stream.CopyTo(write); stream.Close();
write.Close(); return newFile;
}
catch (Exception ex)
{
System.Diagnostics.Debug.Assert(false, ex.Message);
return "";
}
}

设计Excel管理UI

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

弹出的“远端管理视图”提供了3个云存储相关的功能:

  • List:获得云端,对应ACCESS_KEY、SECRET_KEY、Bucket下的文件列表
  • Delete::删除云端的文件
  • DownLoad:从云端下载选择的文件,

下载云端的文件后,直接传给Spread.OpenExcel,即可在SpreadDesign上进行编辑、打印,非常方便。

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

编辑完成后,点击“存储到云端”,在弹出的对话框中存储为“本地修改后存储的文件.xlsx”,然后程序自动实现存储到云端。

在云内容管理界面,刷新可看到文件被自动上传了:

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)

完整源码:

http://git.oschina.net/GrapeCity/SpreadDesigner

小道消息:目前还有少量七牛云存储的试用优惠券(一个七牛账户只能只用一次),有需要请留言沟通。

《介绍一款开源的类Excel电子表格软件》续:七牛云存储实战(C#)的更多相关文章

  1. 介绍一款开源的类Excel电子表格软件

     Excel一直以霸主的地位,占领了Windows桌面表格软件市场No 1,与此同一时候,Office套装产品差点儿成为了IT行业的标配办公技能.有无相似Excel的桌面程序,绿色版,实现主要的数 ...

  2. 一款开源且超好用的网站克隆机 HTTrack

    0x00 前言 我们在学习前端的时候,总是会想着去学习其他人网站是如何制作的,或者我们遇到一些比较有用的知识点的时候,我们可能会选择通过 Ctrl + C / Ctrl + V 去扒下内容,然而我并非 ...

  3. metasploit 一款开源的渗透测试框架

    渗透神器漏洞利用框架metasploit from: https://zhuanlan.zhihu.com/p/30743401 metasploit是一款开源的渗透测试框架软件也是一个逐步发展与成熟 ...

  4. 分享一下怎么开发一款图片视频类App,秒拍和prisma

    第一步,分解短视频App的功能 我们在秒拍官网看到如此描述: [视频拍摄及导入]支持直接拍摄及导入手机本地的视频 [照片电影]照片专属特效,轻松创作照片电影 [MV特效]10余款全新MV特效,让普通视 ...

  5. 一款开源免费的&period;NET文档操作组件DocX(&period;NET组件介绍之一)

    在目前的软件项目中,都会较多的使用到对文档的操作,用于记录和统计相关业务信息.由于系统自身提供了对文档的相关操作,所以在一定程度上极大的简化了软件使用者的工作量. 在.NET项目中如果用户提出了相关文 ...

  6. 几款开源的hybird移动app框架分析

    几款开源的Hybrid移动app框架分析 Ionic Onsen UI 与 ionic 相比 jQuery Mobile Mobile Angular UI 结论 很多移动开发者喜欢使用原生代码开发, ...

  7. 7 款*开源 BI(商务智能)软件和报表工具

    在这个信息化时代,每分每秒都产生海量数据.在海量数据中,挖掘出有用的数据,并且能以较人性化.直观的方式展示这些数据,变得尤为重要.本文将介绍 7款*开源 BI(商务智能)软件和报表工具,用于商业数据 ...

  8. Metasploit是一款开源的安全漏洞检测工具,

    Metasploit是一款开源的安全漏洞检测工具,可以帮助安全和IT专业人士识别安全性问题,验证漏洞的缓解措施,并管理专家驱动的安全性进行评估,适合于需要核实漏洞的安全专家,同时也适合于强大进攻能力的 ...

  9. 1&period; Android 系统上一款开源的图表库

    1. MPAndroidChart  MPAndroidChart 是 Android 系统上一款开源的图表库.目前提供线图和饼图,支持选择.缩放和拖放. 一个可以拖动缩放的图表库,包含曲线图.直方图 ...

随机推荐

  1. C&num; Cache 设定缓存过期时间方法 绝对过期时间 和 相对过期时间&lpar;即&colon;访问激活后不过期&rpar;

    摘自: http://www.cnblogs.com/zj1111184556/p/3493840.html 1. 设定绝对过期时间 /// <summary> /// 设定绝对的过期时间 ...

  2. linux下配置ip地址四种方法&lpar;图文方法&rpar;

    主要是用第四种方法 (1)Ifconfig命令  第一种使用ifconfig命令配置网卡的ip地址.此命令通常用来零时的测试用,计算机启动后 ip地址的配置将自动失效.具体用法如下.Ipconfig  ...

  3. 第二百五十八天 how can I 坚持

    装虚拟机了.CentOs,32位,这电脑装4台能不能带起来啊. 早上,流鼻血了,不知道咋回事.太干了... 明天得早起会,得利索着点,不能托托拉拉的. 还有,今天又忘带钥匙了.悲剧. 睡觉.hadoo ...

  4. 《Java并发编程实战》第十四章 构建自己定义的同步工具 读书笔记

    一.状态依赖性的管理 有界缓存实现的基类 @ ThreadSafe public abstract class BaseBoundedBuffer<E> { @GuardeBy( &quo ...

  5. ipc 入侵步骤

    第一步:建立IPC隧道net use \\10.56.204.186\IPC$ "密码" /user:"用户"     第二步:映射对方c盘到本地z盘net u ...

  6. Android 图片显示

    一.Android手机显示图片 若R.G.B每种颜色使用一个字节(8bit)表示,每幅图像可以有1670万种颜色:若R.G.B每种颜色使用两个字节(16bit)表示,每幅图像可以有10的12次方种颜色 ...

  7. 物理机(真实机)能ping通虚拟机,但是虚拟机无法ping通真实机(可能是防火墙问题)

    物理机IP地址:192.168.1.209 虚拟机IP地址:192.168.1.5.192.168.1.7.192.168.1.10 物理机设置:

  8. Word Press使用

    邮件发送功能插件:Easy WP SMTP LNMP一键包网站环境WordPress程序无法后台切换安装主题 https://help.aliyun.com/document_detail/44619 ...

  9. Android 3&period;0开始引入fragments(碎片、片段)类

    Fragment要点 Fragment作为Activity界面的一部分组成出现. 可以在一个Activity中同时出现多个Fragment,并且,一个Fragment亦可在多个Activity中使用. ...

  10. CentOS 7&period;X 关闭SELinux

    1.查看 [root@dev-server ~]# getenforce Disabled [root@dev-server ~]# /usr/sbin/sestatus -v SELinux sta ...