当前位置: 代码迷 >> ASP.NET >> 小弟我要的是在客户端打开excel文件而不是在服务器上
  详细解决方案

小弟我要的是在客户端打开excel文件而不是在服务器上

热度:1377   发布时间:2013-02-25 00:00:00.0
我要的是在客户端打开excel文件而不是在服务器上
我在Windows 2003Server上装了office2003
想打开服务器网站的excel文件:
fi.OpenExistsExcelFile("~/report/test.xls");
但发现客户端只一闪而过,服务器上却打开了此文件,这不是我想要的,我要的是在客户端打开此文件而不是在服务器上,请问如何做啊??

注:我在服务器上设置了DCOM为交互用户,本地启动,本地激活,权限也设了。

------解决方案--------------------------------------------------------
先上传到服务器
------解决方案--------------------------------------------------------
Response.Write
输出Excel文件内容到客户端
------解决方案--------------------------------------------------------
貌似不行吧,浏览器调用其他程序是很危险的,虽然要做到是完全可能的。。。



等待答案。。。
------解决方案--------------------------------------------------------
探讨
我在Windows 2003Server上装了office2003
想打开服务器网站的excel文件:
fi.OpenExistsExcelFile("~/report/test.xls");
但发现客户端只一闪而过,服务器上却打开了此文件,这不是我想要的,我要的是在客户端打开此文件而不是在服务器上,请问如何做啊??

注:我在服务器上设置了DCOM为交互用户,本地启动,本地激活,权限也……

------解决方案--------------------------------------------------------
下载到本地在打开不行么
------解决方案--------------------------------------------------------
这个要在客户端打开需要用ActiveX插件的,因为你要打开客户端的EXCEL,IE用户权限似乎不够, 你可以看一下DSOFramer,微软提供的插件,开源的
------解决方案--------------------------------------------------------
....

如果你实现了这个功能,但是别人浏览页面的时候机器上没有装Office呢。。。
------解决方案--------------------------------------------------------
<a href="report/test.xls">open</a>
------解决方案--------------------------------------------------------
hrperlink连接EXCEL文件
或string fileName = "";//客户端保存的文件名
string filePath = Server.MapPath("");//路径

FileInfo fileInfo = new FileInfo(filePath);
Response.Clear();
Response.ClearContent();
Response.ClearHeaders();
Response.AddHeader("Content-Disposition", "attachment;filename=" + fileName);
Response.AddHeader("Content-Length", fileInfo.Length.ToString());
Response.AddHeader("Content-Transfer-Encoding", "binary");
Response.ContentType = "application/octet-stream";
Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");
Response.WriteFile(fileInfo.FullName);
Response.Flush();
Response.End();

------解决方案--------------------------------------------------------
流的方式读出来,行得通。以前做项目用过。
------解决方案--------------------------------------------------------
你获得了这个Excel文件后,修改Excel内容 不就得了。然后再用流的方式(10楼正解)读出来啊!!
------解决方案--------------------------------------------------------
这个我有代码,但不在这,明天发上来,记得给分我
------解决方案--------------------------------------------------------
有JS吧
可能需要ACTIVEX
------解决方案--------------------------------------------------------
工具函数

C# code
public static bool ResponseFile(HttpRequest _Request,HttpResponse _Response,string _fileName,string _fullPath, long _speed)    {        try        {            FileStream myFile = new FileStream(_fullPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);            BinaryReader br = new BinaryReader(myFile);            try            {                _Response.AddHeader("Accept-Ranges", "bytes");                _Response.Buffer = false;                long fileLength = myFile.Length;                long startBytes = 0;                     double pack = 10240; //10K bytes                //int sleep = 200;   //每秒5次   即5*10K bytes每秒                int sleep = (int)Math.Floor(1000 * pack / _speed) + 1;                if (_Request.Headers["Range"] != null)                {                    _Response.StatusCode = 206;                    string[] range = _Request.Headers["Range"].Split(new char[] {'=', '-'});                    startBytes = Convert.ToInt64(range[1]);                }                _Response.AddHeader("Content-Length", (fileLength - startBytes).ToString());                if (startBytes != 0)                {                    //Response.AddHeader("Content-Range", string.Format(" bytes {0}-{1}/{2}", startBytes, fileLength-1, fileLength));                }                _Response.AddHeader("Connection", "Keep-Alive");                _Response.ContentType = "application/octet-stream";                _Response.AddHeader("Content-Disposition","attachment;filename=" + HttpUtility.UrlEncode(_fileName,System.Text.Encoding.UTF8) );                             br.BaseStream.Seek(startBytes, SeekOrigin.Begin);                int maxCount = (int) Math.Floor((fileLength - startBytes) / pack) + 1;                for (int i = 0; i < maxCount; i++)                {                    if (_Response.IsClientConnected)                    {                        _Response.BinaryWrite(br.ReadBytes(int.Parse(pack.ToString())));                      System.Threading.Thread.Sleep(sleep);                    }                    else                    {                        i=maxCount;                     }                }            }            catch            {             return false;            }            finally            {                br.Close();                myFile.Close();            }        }        catch        {            return false;        }        return true;    }
  相关解决方案