asp.net调用Console程序,异常未结束的处理。

    因一年前用asp.net开发了一套B/S结构的备品管理系统,   因财务作帐的需求,备品的数据要与生产用的OpenVms的数据进行交互。故用写了两支Console程序,一支从OpenVms系统写入SQL,一支从SQL写入OpenVms系统。两支程序由asp.net的页调用,当用户点击页面上的按钮时,再运行console程序。

    最近发现用户调用程序时,写入OPENVMS的CONSOLE会出现问题,进程一执行后,就无反应,停留在内存中,通过进程查看器可以看得到。但换一台机器再执行这个进程则正常。

  从网上找到相关代码,找一个时间在测试环境调试一下。

   关于在asp.net中调用Excel组件不能结束进程的问题,常见的解决方法用的是下面这段代码

wb.Close( null , null , null );
app.Workbooks.Close();
app.Quit();

if (rng  !=   null )
{
    System.Runtime.InteropServices.Marshal.ReleaseComObject(rng);
    rng 
= null;
}

if (ws  !=   null )
{
System.Runtime.InteropServices.Marshal.ReleaseComObject(ws);
    ws 
= null;
}

if (wb  !=   null )
{  System.Runtime.InteropServices.Marshal.ReleaseComObject(wb);
    wb 
= null;
}

if (app  !=   null )
{ System.Runtime.InteropServices.Marshal.ReleaseComObject(app);
app 
= null;
}

GC.Collect();

        虽然这段代码在配置正确的情况下能自动结束Excel进程,但是前提是在操作Excel时没有引发异常的情况下,如果有异常发生,那么Excel进程将不能结束(比如:引用了一个在Excel文件中不存在的文本框时就会出现“HRESULT 中的异常:0x800A03EC。”),这时就要借助Process类的Kill()方法来结束,下面是我写的测试代码:

using  System;
using  System.Diagnostics;
using  excel  =  Microsoft.Office.Interop.Excel;

namespace  ExcelTest
{
    
/// <summary>
    
/// Excel的摘要说明。
    
/// </summary>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值