长时间动态调用WebService出错,郁闷

gtrabcd 2013-03-06 10:55:13
最近在搞WebService开发,发现了一个问题,通过下面这个WebServiceHelper类长时间调用WebService,会出现“未将实例引用到对象”的错误。(程序开始运行正常,但是时间长了就出现问题了,大概5小时左右),高手们给小弟指点下。
WebServiceHelper的代码如下:
using System.Net;
using System.CodeDom;
using System;
using System.IO;
using System.Web.Services.Description;
using Microsoft.CSharp;
using System.Reflection;
using System.CodeDom.Compiler;

namespace messageCenter
{
public class WebServiceHelper
{
#region InvokeWebService
/// < summary>
/// 动态调用web服务
/// < /summary>
/// < param name="url">WSDL服务地址< /param>
/// < param name="methodname">方法名< /param>
/// < param name="args">参数< /param>
/// < returns>< /returns>
public static object InvokeWebService(string url, string methodname, object[] args)
{
return WebServiceHelper.InvokeWebService(url, null, methodname, args);
}

/// < summary>
/// 动态调用web服务
/// < /summary>
/// < param name="url">WSDL服务地址< /param>
/// < param name="classname">类名< /param>
/// < param name="methodname">方法名< /param>
/// < param name="args">参数< /param>
/// < returns>< /returns>
public static object InvokeWebService(string url, string classname, string methodname, object[] args)
{
string @namespace = "EnterpriseServerBase.WebService.DynamicWebCalling";
if ((classname == null) || (classname == ""))
{
classname = WebServiceHelper.GetWsClassName(url);
}

try
{
//获取WSDL
WebClient wc = new WebClient();
Stream stream = wc.OpenRead(url + "?WSDL");
ServiceDescription sd = ServiceDescription.Read(stream);
ServiceDescriptionImporter sdi = new ServiceDescriptionImporter();
sdi.AddServiceDescription(sd, "", "");
CodeNamespace cn = new CodeNamespace(@namespace);

//生成客户端代理类代码
CodeCompileUnit ccu = new CodeCompileUnit();
ccu.Namespaces.Add(cn);
sdi.Import(cn, ccu);
CSharpCodeProvider icc = new CSharpCodeProvider();

//设定编译参数
CompilerParameters cplist = new CompilerParameters();
cplist.GenerateExecutable = false;
cplist.GenerateInMemory = true;
cplist.ReferencedAssemblies.Add("System.dll");
cplist.ReferencedAssemblies.Add("System.XML.dll");
cplist.ReferencedAssemblies.Add("System.Web.Services.dll");
cplist.ReferencedAssemblies.Add("System.Data.dll");

//编译代理类
CompilerResults cr = icc.CompileAssemblyFromDom(cplist, ccu);
if (true == cr.Errors.HasErrors)
{
System.Text.StringBuilder sb = new System.Text.StringBuilder();
foreach (System.CodeDom.Compiler.CompilerError ce in cr.Errors)
{
sb.Append(ce.ToString());
sb.Append(System.Environment.NewLine);
}
throw new Exception(sb.ToString());
}

//生成代理实例,并调用方法
System.Reflection.Assembly assembly = cr.CompiledAssembly;
Type t = assembly.GetType(@namespace + "." + classname, true, true);
object obj = Activator.CreateInstance(t);
System.Reflection.MethodInfo mi = t.GetMethod(methodname);

//return mi.Invoke(obj, args);
if (args[0] != "")
return mi.Invoke(obj, args);
else
//Invoke(obj, BindingFlags.Default, new MyBinder(), new Object[] { (int)32, (int)32 }, CultureInfo.CurrentCulture);//这个是msdn上的,比较复杂有时间再琢磨。
return mi.Invoke(obj, BindingFlags.Default, null, null, null);

/*
PropertyInfo propertyInfo = type.GetProperty(propertyname);
return propertyInfo.GetValue(obj, null);
*/
}
catch (Exception ex)
{
throw new Exception(ex.InnerException.Message, new Exception(ex.InnerException.StackTrace));
}
}

private static string GetWsClassName(string wsUrl)
{
string[] parts = wsUrl.Split('/');
string[] pps = parts[parts.Length - 1].Split('.');

return pps[0];
}
#endregion
}
}
...全文
159 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
gtrabcd 2013-03-08
  • 打赏
  • 举报
回复
算了,还是用添加引用的方式算了。稳定些。
weizhuangwen 2013-03-06
  • 打赏
  • 举报
回复
访问web service接口超时了,try过本次访问,写日志。暂停10秒,执行下一次访问
herryking 2013-03-06
  • 打赏
  • 举报
回复
时间长就报错的话应该是访问超时了原因,首先排查数据访问层,优化数据库语句,然后再设置超时时间。如果都不行的话看看是不是程序逻辑的问题。我之前遇到的是程序逻辑问题,造成数据库死锁,致使程序执行数据语句时经常出现数据库访问超时的情况。希望对你能有所帮助
gtrabcd 2013-03-06
  • 打赏
  • 举报
回复
引用 1 楼 cnfixit 的回复:
把异常信息写入日志,然后再分析
日志里有,报的是“未将实例引用到对象”
gtrabcd 2013-03-06
  • 打赏
  • 举报
回复
引用 2 楼 gxingmin 的回复:
webservice有timeout,估计是超时了
是服务端吗?
billlyh 2013-03-06
  • 打赏
  • 举报
回复
长了就失效了吧
billlyh 2013-03-06
  • 打赏
  • 举报
回复
时间缩短一下吧
gxingmin 2013-03-06
  • 打赏
  • 举报
回复
webservice有timeout,估计是超时了
cnfixit 2013-03-06
  • 打赏
  • 举报
回复
把异常信息写入日志,然后再分析

110,567

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

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