需求很简单,在SQL Server数据库中存放用户上传的Visio文件,然后使用Visio Viewer在IE中直接显示用户上传的Visio文件的内容。
对于这个需求,我们需要分成两部分:
1.实现Visio文件的数据库存放和读取,并在Asp.Net中能够下载下来。
2.使用微软官方提供的Visio Viewer,在HTML中使用该Object来调用Visio图。
对于第一个功能。首先需要实现的是文件的上传。在文件上传时我们一般需要记录3个内容:文件的Content Type,文件名和文件的二进制内容。用户上传文件保存到数据库的功能代码很简单,我这里就不累述了。
然后说一下下载功能,我们新建一个ViewFile.aspx文件,然后在后台代码中编写如下:
protected void Page_Load(object sender, EventArgs e) { var p = Mgr.GetProcessByID(Request.QueryString["id"]); Page.Response.Clear(); Page.Response.ContentType = p.FileContentType; //内容类型 Page.Response.AddHeader("Content-Disposition", "attachment;FileName=" + p.FileName);//文件名 Page.Response.BinaryWrite(p.ProcessFile.ToArray());//文件内容 Page.Response.End(); }
OK ,就这么简单,现在我们只需要运行程序,然后Url中输入ViewFile.aspx?id=6就可以读取到ID=6的Visio文件并下载下来。
接下来再说Visio Viewer的调用,编写一个新的页面VisioView.aspx,
protected void Page_Load(object sender, EventArgs e) { StringBuilder sb = new StringBuilder(); sb.Append("<object classid=clsid:279D6C9A-652E-4833-BEFC-312CA8887857 id=vviewer "); sb.Append("codebase=http://download.microsoft.com/download/4/5/2/452f8090-413f-408f-83c0-edd66db786ee/vviewer.exe Width =100% Height = 600 > "); sb.Append("<param name=SRC value=" + "http://localhost:2303/VisioFile.aspx?id=6" + "> "); sb.Append("<param name=HighQualityRender value=1> "); sb.Append("<param name=BackColor value=#000000> "); sb.Append("<param name=PageColor value=#000000> "); sb.Append("<param name=PageVisible value=1> "); sb.Append("<param name=AlertsEnabled value=1> "); sb.Append("<param name=ContextMenuEnabled value=1> "); sb.Append("<param name=GridVisible value=1> "); sb.Append("<param name=PropertyDialogEnabled value=1> "); sb.Append("<param name=ScrollbarsVisible value=1> "); sb.Append("<param name=ToolbarVisible value=1> "); sb.Append("<param name=CurrentPageIndex value=1> "); sb.Append("<param name=Zoom value=-1> "); sb.Append("</object>"); lvisio.Text = sb.ToString();//这里是一个Literal控件 }
Visio文件正常下载,那么说明我们的src参数是正确的啊!这是什么原因造成的呢,经过简单的研究,发现原来是Visio Viewer的一个Bug吧,这个控件他只认识Visio格式后缀的url,而我们这里的文件URL是VisioFile.aspx?id=6,这个地方Visio Viewer认为不是一个Visio文件,所以根本不加载其中的内容了。
那么怎么解决呢?办法有好几个:
1.做一个.vsd的httphandler,然后指定解释.vsd格式的类,这样URL就变成了XXX.vsd格式了。
2.加一个无聊的参数:xx=.vsd。这样Visio Viewer就以为这个路径是Visio文件并进行加载了。
我采用第二个方案,修改代码第6行:
sb.Append("<param name=SRC value=" + "http://localhost:2303/VisioFile.aspx?id=6" + "&xx=.vsd> ");
OK,我们存放在数据库中的Visio就可以正常显示在Visio Viewer中了。