Asp.NET操作Word

为什么要杀掉死进程?因为Word、Excel天生就不是给服务器端服务程序调用的,如果非要用asp.net(包括Jsp、asp、php等)调用,当然Word、Excel会有些水土不服啦,呵呵,形象地比喻一下。
在服务器端自动化word/excel是有风险的,连微软都不建议在服务器端自动化word/excel,出了问题也不提供任何支持,至于有什么风险,看微软自己是怎么说的
服务器端 Office 自动化注意事项
http://support.microsoft.com/default.aspx?scid=kb;

你看完上面的资料,就会知道为什么会有死进程了。所以就有人出主意:有死进程就干脆杀掉,好一个头痛医头,脚痛医脚!至于系统稳不稳定就顾不了那么多了。

为完美解决Web服务器端读写存取微软Office文档的技术难题,微软Office中间件——SOAOffice应运而生。
由于SOAOffice提供纯.Net组件,所以服务器端不需安装office。 SOAOffice的word组件和excel组件类似word/excel的简化接口,调用简单。SOAOffice能够在客户端浏览器的网页里通过SOAOffice直接显示生成的Excel,用户不必先下载再打开观看内容。

What, why and how 说齐了

附上杀死死进程的代码
需要注意的是:这个文件要放在具有administrator访问权限的虚拟目录下(注意:这又产生了一个不安全的因素,敢用吗?)。 (摘自作者:peter a. bromberg, ph.d. 出自:孟宪会之精彩世界)
以下是c#代码:

<%@ page language="c#" %>
<html>
<head>
<% @ import namespace= "system.diagnostics" %>
<script language="c#" runat="server" debug="true">
void page_load(object sender, eventargs e){
btnkill.attributes.add("onclick", "javascript: return confirm('你真的要杀死这个进程吗?');");
}

private void killprocess(string processname){
system.diagnostics.process myproc= new system.diagnostics.process();
//得到所有打开的进程
try{
foreach (process thisproc in process.getprocessesbyname(processname)) {
if(!thisproc.closemainwindow()){
thisproc.kill();
}
}
}
catch(exception exc)
{
msg.text+= "杀死" +procname.selecteditem.text + "失败!";
}
}
public void btnkill_click(object sender, system.eventargs e)
{
killprocess(procname.selecteditem.text);
msg.text= procname.selecteditem.text +" 已经被杀死。";
}


public void btnshow_click(object sender, system.eventargs e){
arraylist proclist =new arraylist();
string tempname="";
int begpos;
int endpos;
foreach (process thisproc in system.diagnostics.process.getprocesses()) {
tempname=thisproc.tostring();
begpos = tempname.indexof("(")+1;
endpos= tempname.indexof(")");
tempname=tempname.substring(begpos,endpos-begpos);
proclist.add(tempname);
}
procname.datasource=proclist;
procname.databind();
}
</script>
</head>
<body>
<basefont face="tahoma" />
<center><h2>asp.net 进程杀死器!</h2><br>
<table cellspacing=2 cellpadding=2 border=0 bgcolor="#ffcc66">
<form id="frmproc" runat="server" method="post">
<tr><td><asp:dropdownlist id="procname" runat="server" /></td><td>
进程名字</td></tr>
<tr><td>
<asp:button id="btnkill" text="杀死进程" runat="server" causesvalidation="false" οnclick="btnkill_click" />
</td>
<td><asp:button id="btnshow" text="列出所有进程" runat="server" causesvalidation="false" οnclick="btnshow_click" />
</td></tr>
</table>
<center><asp:label id="msg" runat="server"/></center>
</form>
</center>
</body>
</html>

转载于:https://www.cnblogs.com/Silverlight_Team/archive/2009/03/22/1418905.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ASP.NET生成WORD文档服务器部署注意事项 配置详情请下载附件图解 1、Asp.net 2.0在配置Microsoft Excel、Microsoft Word应用程序权限时 error: 80070005 和8000401a 的解决总 2007-11-01 11:30 检索 COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 80070005。 控制面板-》管理工具-》组件服务-》计算机-》我的电脑-》DCom配置-》找到Microsoft Word文档 之后 单击属性打开此应用程序的属性对话框。 单击"安全"选项卡,分别在"启动和激活权限"和"访问权限"组中选中"自定义",然后 自定义->编辑->添加ASP.NET账户和IUSER_计算机名 * 这些帐户仅在计算机上安装有 IIS 的情况下才存在。 在标识选项卡选择下列用户,输入用户名密码 13. 确保允许每个用户访问,然后单击确定。 14. 单击确定关闭 DCOMCNFG。 检索 COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 8000401a 。 运行dcomcnfg打开组件服务, 依次展开"组件服务"->"计算机"->"我的电脑"->"DCOM配置" 找到"Microsoft Excel应用程序"或"Microsoft Word应用程序", 右键打开属性对话框,点击"标识"选项卡, 点"下列用户",把管理员的用户密码正确填写进去... 点击"安全"选项卡, 依次把"启动和激活权限","访问权限","配置权限",都选择为自定义, 然后依次点击它们的编辑,把everyone添加进去,并加入所有的权限... OK,解决此问题! 2、请设置web.config中的帐号和密码,否则会提示检索 COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 80070005。 例如
SOAOFFICE - 微软 OFFICE 中间件 SOAOffice 中间件是北京科翰软件为微软OFFICE量身打造的Web中间件,是Web调用Office、存取Office数据的必备中间件。SOAOffice中间件由服务器端数据组件和客户端显示控件构成。 SOAOffice 完全抛弃了传统利用Office服务器端自动化技术存取文档数据的种种弊端和缺陷,采用独创的专利技术构建了一个功能强大、简单易用的微软Office中间件平台,平台提供标准的.net和java组件接口,不但能够在线(浏览器页面)打开、编辑、保存Office文档,而且开发人员还能够以简洁的代码快速的将数据库数据动态填充到Office文档指定位置,并且也能够从Office文档中提取指定位置的数据保存到数据库。 SOAOffice提供这些强大功能的同时,服务器端并不需要安装运行Office软件。通过SOAOffice,在Web世界里,难以驯服的Word/Excel就变成了普通的、熟悉的、服务器端可调用的.Net组件、Java组件、ASP组件、PHP组件,开发人员再也不用研究复杂的Word/Excel COM自动化细节、学习复杂的VBA语法调用,也不用去应对Word/Excel死进程、系统稳定运行的问题。开发人员能够节省宝贵的精力和时间,把它投放到更重要的业务逻辑和系统架构上,而控制Office的具体技术细节交给SOAOffice去做。 SOAOffice除了提供Word/Excel动态数据填充,Word/Excel数据导入导出,Word/Excel/PowerPoint等Office文档的在线打开、编辑、保存,权限控制,只读控制等功能外,还给在线办公内置了强大的支持功能:强制痕迹保留,手写批注,圈阅签字,手写签名,电子印章、数字签名、模板套红、一键套红等。 科翰软件是国内唯一的微软Office中间件开发商,拥有卓越的自主研发实力和独创的专利技术,其产品SOAOffice不仅畅销国内,而且还远销欧美国际市场,其中世界500强美国Dover集团、可口可乐 Coca-Cola、中石油、中石化等都是SOAOffice产品的忠实客户。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值