接收出错:基础连接已经关闭: 接收时发生错误。
接收出错:基础连接已经关闭: 接收时发生错误。
在 System.Web.Services.Protocols.WebClientProtocol.GetWebResponse(WebRequest request)
在 System.Web.Services.Protocols.HttpWebClientProtocol.GetWebResponse(WebRequest request)
在 System.Web.Services.Protocols.SoapHttpClientProtocol.Invoke(String methodName, Object[] parameters)
在 WindowsApplication发短信3.FetionObj.fWebSer.ReMsg(String xno, Int32 mtx) 位置 G:\ASP.net\WindowsApplication\Web References\FetionObj\Reference.cs:行号 328
在 WindowsApplication.Form1.TreCom(String myMNo) 位置 G:\ASP.net\WindowsApplication\Form1.cs:行号 53
Form1的代码如下:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using WindowsApplication发短信3.FetionObj;
using System.Threading;
using System.Web.Services.Protocols;
namespace WindowsApplication发短信3
{
public partial class Form1 : Form
{
private string _myMNo = ""; //保存登录号
private fWebSer fws = null; //声名接口类
private bool reAsync = false; //连续接收信息开关
public Form1()
{
InitializeComponent();
fws = new fWebSer(); //创建WebService接口类
fws.CookieContainer = new System.Net.CookieContainer(); //这句很重要,否则将不能登录
}
public void Login_Click(object sender, EventArgs e)
{
_myMNo = loginNo.Text;
fws.Login(_myMNo, loginPass.Text); //要先发送登录命令
if (!reAsync) //接收已经停止才能重新开始异步接收
{
reAsync = true;
DelegateTreCom dn = new DelegateTreCom(TreCom); //实例化委托并初赋值
IAsyncResult iar = dn.BeginInvoke(_myMNo, new AsyncCallback(CallBackTreCom), dn); //异步开始执行
}
}
//多线程安全委托输出
private delegate void MyControl(Control myc, string txt);
private void Setout(Control myc, string txt)
{
if (myc.InvokeRequired)
myc.Invoke(new MyControl(Setout), myc, txt);
else
myc.Text = txt + "\r\n" + myc.Text;
}
private delegate void DelegateTreCom(string recom); //定义委托
private void TreCom(string myMNo)
{//用异步处理收到的信息的函数
try
{
string remsg = fws.ReMsg(myMNo, 40); //长连接方式接收数据,没数据时最多可以等待40秒再返回
string[] rearr = remsg.Split('\n'); //拆分事件记录
for (int i = 0; i < rearr.Length; i++) //处理收到的所有事件
{
//分析每一事件
string com = "", rfno = "", rmno = "", msg = "", errtxt = "", rgno = "", fname = "";
string[] comarr = rearr[i].Split('&');
for (int j = 0; j < comarr.Length; j++)
{
string[] varr = comarr[j].Split('=');
if (varr.Length < 2) continue;
if (varr[0] == "com") com = varr[1];
if (varr[0] == "rfno") rfno = varr[1];
if (varr[0] == "rmno") rmno = varr[1];
if (varr[0] == "msg") msg = varr[1];
if (varr[0] == "errtxt") errtxt = varr[1];
if (varr[0] == "rgno") rgno = varr[1];
if (varr[0] == "fname") fname = varr[1];
}
if (com == "rmsg")
{//收到新信息
Setout(showtxt, "收到" + fname + "(" + rfno + "|" + rmno + ")新信息:" + msg);
}
if (com == "sendok")
{//发送成功
Setout(showtxt, "发送到" + rfno + "成功,内容:" + msg);
}
if (com == "senderr")
{//发送失败
Setout(showtxt, "发送到" + rfno + "失败,错误信息:" + errtxt);
}
if (com == "loginok")
{//登录成功
Setout(showtxt, "登录成功,自己的飞信号:" + rfno + ",手机号:" + rmno + ",昵称:" + fname);
}
if (com == "loginerr")
{//登录失败
reAsync = false; //停止接收事件
Setout(showtxt, "登录失败");
}
if (com == "fadd")
{//被添加为好友
Setout(showtxt, "被添加为好友,对方信息:" + msg.Trim());
}
if (com == "list")
{//好友列表完成
Setout(showtxt, "好友列表完成");
}
if (com == "logout")
{//被注销
reAsync = false; //停止接收事件
Setout(showtxt, "已经注销");
}
if (com == "changed")
{//好友状态改变
string[] farr = msg.Trim().Split('|');
if (farr.Length >= 7)
{
if (farr[5] == "聊天")
{
Setout(showtxt, "好友打开聊天窗口:" + msg.Trim());
}
else
{
Setout(showtxt, "好友状态改变:" + msg.Trim());
}
}
}
}
}
catch (Exception er)
{
Setout(showtxt, "接收出错:" + er.Message + er.StackTrace);
}
if (reAsync)
{//重复调用接收数据
Thread.Sleep(2000); //控制调用速度
DelegateTreCom dn = new DelegateTreCom(TreCom); //实例化委托并初赋值
IAsyncResult iar = dn.BeginInvoke(myMNo, new AsyncCallback(CallBackTreCom), dn); //异步开始执行
}
}
//send_Click函数代码内容如下:
public void send_Click(object sender, EventArgs e)
{
if (!reAsync) //如果接收事件停止就要重新开始异步接收
{
reAsync = true;
DelegateTreCom dn = new DelegateTreCom(TreCom); //实例化委托并初赋值
IAsyncResult iar = dn.BeginInvoke(_myMNo, new AsyncCallback(CallBackTreCom), dn); //异步开始执行
}
fws.Send(_myMNo, tofno.Text,msgtxt.Text); //发送
}
//异步完成时,执行的方法(回调方法)
private void CallBackTreCom(IAsyncResult ar)
{
//从异步状态ar.AsyncState中,获取委托对象
DelegateTreCom dn = (DelegateTreCom)ar.AsyncState;
//一定要EndInvoke
dn.EndInvoke(ar);
}
}
}
请大家帮忙看下,咋弄呀,谢谢了!
[解决办法]
server 端关闭,client端依然在读取数据 所以引发异常
[解决办法]
同问啊。我也出现了这个问题。