asp.net操作office

zhantianyou 2009-05-24 03:54:04
大侠们好:
请问谁用过dsoframe.ocx这个组件,我在asp.net通过按钮打开word文档,可以正常工作,现在我想在asp.net页面加载时,就把某个word文件加载进来,需要怎么做??我在page_load事件中去写
clientRegistScript().....这个方法调用javascript打开word文档,结果没用,请问我需要如何作??急,时间不等人,任务时间要到了.
谢谢!!5。5节日快乐!!
...全文
307 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
f274126259 2010-09-09
  • 打赏
  • 举报
回复
IwebOffice active 第3方插件在哪有下载啊
zhantianyou 2009-05-25
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 glboy12 的回复:]
去baidu一下IwebOffice active 第3方插件.
[/Quote]

感謝這個仁兄,通過你這個提義,我去下載了,看了他頁面的方法後,我修改了我的頁面,成功.!!
wugang_1982 2009-05-25
  • 打赏
  • 举报
回复
学习
zzxap 2009-05-25
  • 打赏
  • 举报
回复
http://www.cnblogs.com/jinglelin/archive/2005/09/02/228486.html

[code=C#]
涉及到asp.net操作word的问题
今年陆续又碰到操作excel、word等office文档
使用的都是Interop相关dll,打开office相关进程进行操作
为免忘记,将相关tip整理如下:
1. 引用文件,几个dll打包了
2. 操作word代码示例:
using ImportExportToOffice;
using Microsoft.ApplicationBlocks.Data;

protected void btnJianJie_Click(object sender, EventArgs e)
{
string sYear = DropDownList2.SelectedValue;
string sMonth = DropDownList1.SelectedValue;
string sDate1 = String.Format("{0}-{1}-{2}", sYear, sMonth, "1");
string sDate2 = String.Format("{0}-{1}-{2}", sYear, sMonth, System.DateTime.DaysInMonth(int.Parse(sYear), int.Parse(sMonth)).ToString());
word = new ImportExportToWord();

string sTmpUrl = "../Report/" + Guid.NewGuid().ToString() + ".Doc";
string sTmpFile = Server.MapPath(sTmpUrl);
string sModelDoc = Server.MapPath("../Report/国际漫游简报模板.doc");
System.IO.File.Copy(sModelDoc, sTmpFile, true);
try
{
word.Open(sTmpFile);

object sBookMark = "";

//GSM 来访前十 分公司
sBookMark = "GSM_1";
if (word.Document.Bookmarks.Exists(sBookMark.ToString()))
{
word.Document.Bookmarks.get_Item(ref sBookMark).Select();

string sSql = "SELECT TOP 10 t1.ToCarrier, COUNT(t1.ToCarrier) AS Num, t2.ShortName AS Name" +
" FROM BiteGSM t1 INNER JOIN" +
" BranchInfo t2 ON t1.ToCarrier = t2.ID" +
" INNER JOIN DispatchInfo t3 ON t1.DispatchID = t3.ID" +
" Where t3.SendTime >='" + sDate1 + "'" +
" And t3.SendTime <='" + sDate2 + "'" +
" And t1.SimType=1" +
" GROUP BY t1.ToCarrier, t2.ShortName" +
" ORDER BY COUNT(t1.ToCarrier) DESC";
SqlDataReader dr = SqlHelper.ExecuteReader(Connection.ConnectionString, CommandType.Text, sSql);
while (dr.Read())
{
word.Application.Selection.TypeText(dr["Name"].ToString());
word.GoToRightCell();
word.Application.Selection.TypeText(dr["Num"].ToString());
word.GoToLeftCell();
word.GoToDownCell();
}
dr.Close();
}

//CDMA 来访前十 分公司
sBookMark = "CDMA_1";
if (word.Document.Bookmarks.Exists(sBookMark.ToString()))
{
word.Document.Bookmarks.get_Item(ref sBookMark).Select();

string sSql = "SELECT TOP 10 t1.ToCarrier, COUNT(t1.ToCarrier) AS Num, t2.ShortName AS Name" +
" FROM BiteGSM t1 INNER JOIN" +
" BranchInfo t2 ON t1.ToCarrier = t2.ID" +
" INNER JOIN DispatchInfo t3 ON t1.DispatchID = t3.ID" +
" Where t3.SendTime >='" + sDate1 + "'" +
" And t3.SendTime <='" + sDate2 + "'" +
" And t1.SimType=2" +
" GROUP BY t1.ToCarrier, t2.ShortName" +
" ORDER BY COUNT(t1.ToCarrier) DESC";
SqlDataReader dr = SqlHelper.ExecuteReader(Connection.ConnectionString, CommandType.Text, sSql);
while (dr.Read())
{
word.Application.Selection.TypeText(dr["Name"].ToString());
word.GoToRightCell();
word.Application.Selection.TypeText(dr["Num"].ToString());
word.GoToLeftCell();
word.GoToDownCell();
}
dr.Close();
}

//GSM 去访前十 分公司
sBookMark = "GSM1";
if (word.Document.Bookmarks.Exists(sBookMark.ToString()))
{
word.Document.Bookmarks.get_Item(ref sBookMark).Select();

string sSql = "SELECT TOP 10 t1.ToCarrier, COUNT(t1.ToCarrier) AS Num, t2.CarrierName AS Name" +
" FROM Unicom2TSTT t1 INNER JOIN" +
" CarrierInfo t2 ON t1.ToCarrier = t2.ID" +
" INNER JOIN DispatchInfo t3 ON t1.DispatchID = t3.ID" +
" Where t3.SendTime >='" + sDate1 + "'" +
" And t3.SendTime <='" + sDate2 + "'" +
" And t1.SimType=1" +
" GROUP BY t1.ToCarrier, t2.CarrierName" +
" ORDER BY COUNT(t1.ToCarrier) DESC";
SqlDataReader dr = SqlHelper.ExecuteReader(Connection.ConnectionString, CommandType.Text, sSql);
while (dr.Read())
{
word.Application.Selection.TypeText(dr["Name"].ToString());
word.GoToRightCell();
word.Application.Selection.TypeText(dr["Num"].ToString());
word.GoToLeftCell();
word.GoToDownCell();
}
dr.Close();
}

//CDMA 去访前十 分公司
sBookMark = "CDMA1";
if (word.Document.Bookmarks.Exists(sBookMark.ToString()))
{
word.Document.Bookmarks.get_Item(ref sBookMark).Select();

string sSql = "SELECT TOP 10 t1.ToCarrier, COUNT(t1.ToCarrier) AS Num, t2.CarrierName AS Name" +
" FROM Unicom2TSTT t1 INNER JOIN" +
" CarrierInfo t2 ON t1.ToCarrier = t2.ID" +
" INNER JOIN DispatchInfo t3 ON t1.DispatchID = t3.ID" +
" Where t3.SendTime >='" + sDate1 + "'" +
" And t3.SendTime <='" + sDate2 + "'" +
" And t1.SimType=2" +
" GROUP BY t1.ToCarrier, t2.CarrierName" +
" ORDER BY COUNT(t1.ToCarrier) DESC";
SqlDataReader dr = SqlHelper.ExecuteReader(Connection.ConnectionString, CommandType.Text, sSql);
while (dr.Read())
{
word.Application.Selection.TypeText(dr["Name"].ToString());
word.GoToRightCell();
word.Application.Selection.TypeText(dr["Num"].ToString());
word.GoToLeftCell();
word.GoToDownCell();
}
dr.Close();
}

word.SaveAs(sTmpFile);
word.Quit();
SysUtil.Log(UserContext.GetUserContext(), FunctionContext.GetFunctionContext(),OperType.其它, LogLevel.信息, "生成国际漫游简报成功");
Response.Write("<script>window.open(\"" + sTmpUrl + "\")</script>");
}
catch (Exception err)
{
try
{
word.Quit();
}
catch
{
}
SysUtil.Log(UserContext.GetUserContext(), FunctionContext.GetFunctionContext(),OperType.其它, LogLevel.信息, "生成国际漫游简报失败,错误信息:" + err.Message);
}
}

3.部署相关: 确保服务器正确安装office 2k3
运行后若office进程起不来,如下检查:
1.运行Dcomcnfg.exe
2.组件服务――计算机――我的电脑――DCOM配置――找到microsoft word 文档
3.点击属性
4.选择“安全性”
5.选定“使用自定义访问权限”和“使用自定义启动权限”
6.分别编辑权限,添加Everyone(ASPNET,VS Developers,Debugger User)
7.选择“身份标识”,在选定“交互式用户” 即可
8.在Web.config里加 <identity impersonate="true"/>
[/CODE]
glboy12 2009-05-25
  • 打赏
  • 举报
回复
去baidu一下IwebOffice active 第3方插件.
zhantianyou 2009-05-25
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 fei997yang 的回复:]
直接写javascript,当页面加载完成之后,调用脚本打开word文档
[/Quote]

Response.Write("<script language='javascript'>document.all.FramerControl1.Open('Http://192.168.8.105/AspNet/WebOffice/Office/Word.doc', true); </script>");//這個行不通


ClientScript.RegisterStartupScript(this.GetType(),"js","<script language=javascript>OpenWebDoc(Word.doc);</script>",false);這個也行不通

<scritp language="javascript">
function OpenWebDoc(fileName)
{
document.all.FramerControl1.Open("Http://192.168.8.105/AspNet/WebOffice/Office/"+fileName, true);
}
</script>
zywhao 2009-05-24
  • 打赏
  • 举报
回复
我用过一次,感觉不是很好,,浏览器经常死掉,还出现灾难性故障.

与客户端装的office也有关系,象现在使用的office2007肯定就不能使用



关注一下你的解决方案...
fei997yang 2009-05-24
  • 打赏
  • 举报
回复
直接写javascript,当页面加载完成之后,调用脚本打开word文档
tian_ya4 2009-05-24
  • 打赏
  • 举报
回复
学习
zouzedong 2009-05-24
  • 打赏
  • 举报
回复
没用过·
freemeditator 2009-05-24
  • 打赏
  • 举报
回复
ocx???
dd__dd 2009-05-24
  • 打赏
  • 举报
回复
帮顶
mengxj85 2009-05-24
  • 打赏
  • 举报
回复
关注,没用过
wuyq11 2009-05-24
  • 打赏
  • 举报
回复
SharePoint.OpenDocuments.2实现word在线编辑
参考
作为ASP.NET项目的开发者,在应对用户的Word、Excel文档时,您是否迫切希望Visual Studio工具箱里能有现成的Word、Excel标准ASP.NET控件可用就太好了?现在梦想已经成真,想在网页上显示编辑Word、Excel文档并且调用微软Office的强大功能,就直接从工具箱拖动一个PageOffice控件到Web页面上就可以了,就和使用常用的TextBox控件一样简单方便。 PageOffice是什么? PageOffice for ASP.NET是一款非常优秀的专业的集成微软OFFICE功能的ASP.NET控件平台,能够帮助Web开发人员轻松实现在网页中嵌入运行微软Office的特殊功能。PageOffice把微软复杂的Office编程接口(COM API) 有效地整合于 ASP.NET 环境,通过简化的.NET类库接口为开发者提供了在Web项目里获得Office众多强大功能的机会,并且能够同时利用来自 .NET Framework 的开发效率和软件功能。 集成PageOffice不但能够实现在线编辑、保存真正的Office文档,而且还可以轻松实现Word、Excel文档的动态数据填充、格式控制和用户输入提交的高级复杂功能。只要集成PageOffice,您将能够轻松应对在Web项目开发中遇见的绝大部分和Office文档有关的功能和难题。您只需把精力集中在项目业务逻辑上,Office技术问题就交给PageOffice实现解决吧。 PageOffice除了提供Word/Excel动态数据填充,格式控制,Word/Excel用户输入提交,Word/Excel/PowerPoint/WPS等Office文档的在线打开、只读浏览、编辑、保存等功能外,还给在线协同办公提供了强大的支持功能:可编辑区域控制,强制痕迹保留,并发编辑控制,手写批注,手写签名,圈阅签字,电子印章、动态模板套红等。 专业的MSDN风格的开发帮助,上百的示例代码,确保您的开发效率事半功倍。 运行环境 服务器端:Windows2003、Windows2008、Windows2012及Windows XP、Windows7、Windows8等(包括64位版本);.Netframework2.0及以上版本。 客户端:Windows XP、Windows Vista、Windows7、Windows8及以上版本(包括64位版本);Microsoft Office2003、2007、2010、2013;IE 6.0、7.0、8.0、9.0、10.0。 名称:PageOffice for ASP.NET专业版 2.0 下载:http://www.zhuozhengsoft.com/down/PageOffice_ASP.NET.rar 大小:13.8MB 版本:专业版 2.0

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧