Исключение сокета - PullRequest
       33

Исключение сокета

1 голос
/ 24 ноября 2011

Я работаю над веб-клиентом.Вот код:

using System.Net;
using System.Net.Sockets;
using System.Text;
using Microsoft.SPOT;
using System.Threading;
using System;

namespace EPI.Net
{
    public class EfficientPutRequest
    {
        #region MysSettings        
        static string _server;
        static int httpPort;
        static string _name;
        static string _namespace = "http://tempuri.org/";
        static string _event = "CreateEvent";
        #endregion

        public static Socket connection;


        public EfficientPutRequest(string uri)
        {
            Uri siteUri = new Uri(uri);
            _server = siteUri.Host;
            _name = siteUri.AbsolutePath;
            httpPort = siteUri.Port;
            connection = Connect(_server, 5000);
        }

        static Socket Connect(string host, int timeout)
        {
            IPHostEntry hostEntry = Dns.GetHostEntry(host);

            IPAddress hostAddress = hostEntry.AddressList[0];
            IPEndPoint remoteEndPoint = new IPEndPoint(hostAddress, httpPort);

            var connection = new Socket(AddressFamily.InterNetwork,  SocketType.Stream, ProtocolType.Tcp);
            connection.Connect(remoteEndPoint);
            connection.SetSocketOption(SocketOptionLevel.Tcp, SocketOptionName.NoDelay, true);
            connection.SendTimeout = timeout;
            return connection;
        }

        public void SendRequest(System.DateTime timestamp, string args)
        {
            Socket s = connection;
            const string CRLF = "\r\n";

            string content =
                "<s:Envelope xmlns:s=\"http://schemas.xmlsoap.org/soap/envelope/\">" +
                "<s:Body>" +
                "<" + _event + " xmlns=\"" + _namespace + "\" xmlns:i=\"http://www.w3.org/2001/XMLSchema-instance\">" +
                "<timestamp>" + timestamp.ToString("yyyy-MM-ddTHH:mm:ss") + "</timestamp>" +
                "<Args>" + args + "</Args>" +
                "</" + _event + ">" +
                "</s:Body>" +
                "</s:Envelope>";
            byte[] contentBuffer = Encoding.UTF8.GetBytes(content);

            var requestLine =
                "POST " + _name + " HTTP/1.1" + CRLF;
            byte[] requestLineBuffer = Encoding.UTF8.GetBytes(requestLine);

            var headers =
                "Content-Type: text/xml; charset=utf-8" + CRLF +
                "SOAPAction: \"" + _namespace + _event + "\"" + CRLF +
                "Host: " + _server + CRLF +
                "Content-Length: " + contentBuffer.Length + CRLF +
                "Expect: 100-continue" + CRLF +
                "Accept-Encoding: gzip, deflate" + CRLF + CRLF;
            byte[] headersBuffer = Encoding.UTF8.GetBytes(headers);
            try
            {
                s.Send(requestLineBuffer);
                Thread.Sleep(100);
                s.Send(headersBuffer);
                Thread.Sleep(100);
                s.Send(contentBuffer);
                Thread.Sleep(100);
                s.Close();
                connection.Close();
            }
        }
    }
}

Я использую этот код для тестирования клиента:

using System;
using System.Threading;
using Microsoft.SPOT;
using Microsoft.SPOT.Hardware;
using GHIElectronics.NETMF.FEZ;
using EPI.Net;

namespace FEZ_Cobra_Console_Application1
{
    public class Program
    {
        public static string endPoint = "http://192.*********/webservice.asmx";
        public static int i = 1;
        public static void Main()
        {
            while (true)
            {
                EfficientPutRequest Servicio = new EfficientPutRequest(endPoint);
                Servicio.SendRequest(System.DateTime.Now, 17, 17, 0, "");
                Debug.Print(i.ToString() + " sent");
                i++;
                Thread.Sleep(1000);
            }
        }

    }
}

Выдает ошибку сокета после отправки 15 сообщений.Здесь ошибка: enter image description here

Я также пытался закрыть сокет после отправки, и ни один не работает.Есть идеи?

РЕДАКТИРОВАТЬ: Я обновил код, закрывая сокеты после отправки сообщения.Работает нормально в эмуляторе, но не на моем устройстве.

Ответы [ 2 ]

0 голосов
/ 25 ноября 2011

Решено так:

connection.SetSocketOption(SocketOptionLevel.Tcp, SocketOptionName.Linger, new byte[] { 0, 0, 0, 0 });

И добавив это после отправки сообщения:

connection.Close();

Здесь вы можете увидеть фиксированный код:

using System.Net;
using System.Net.Sockets;
using System.Text;
using Microsoft.SPOT;
using System.Threading;
using System;

namespace EPI.Net
{
    public class EfficientPutRequest
    {
        #region MysSettings        
        static string _server;
        static int httpPort;
        static string _name;
        static string _namespace = "http://tempuri.org/";
        static string _event = "CreateEvent";
        #endregion

        public static Socket connection;


        public EfficientPutRequest(string uri)
        {
            Uri siteUri = new Uri(uri);
            _server = siteUri.Host;
            _name = siteUri.AbsolutePath;
            httpPort = siteUri.Port;
            connection = Connect(_server, 5000);
        }

        static Socket Connect(string host, int timeout)
        {
            IPHostEntry hostEntry = Dns.GetHostEntry(host);

            IPAddress hostAddress = hostEntry.AddressList[0];
            IPEndPoint remoteEndPoint = new IPEndPoint(hostAddress, httpPort);

            var connection = new Socket(AddressFamily.InterNetwork,  SocketType.Stream, ProtocolType.Tcp);
            connection.Connect(remoteEndPoint);
            connection.SetSocketOption(SocketOptionLevel.Tcp, SocketOptionName.Linger, new byte[] { 0, 0, 0, 0 });
            connection.SendTimeout = timeout;
            return connection;
        }

        public void SendRequest(System.DateTime timestamp, string args)
        {
            const string CRLF = "\r\n";

            string content =
                "<s:Envelope xmlns:s=\"http://schemas.xmlsoap.org/soap/envelope/\">" +
                "<s:Body>" +
                "<" + _event + " xmlns=\"" + _namespace + "\" xmlns:i=\"http://www.w3.org/2001/XMLSchema-instance\">" +
                "<timestamp>" + timestamp.ToString("yyyy-MM-ddTHH:mm:ss") + "</timestamp>" +
                "<Args>" + args + "</Args>" +
                "</" + _event + ">" +
                "</s:Body>" +
                "</s:Envelope>";
            byte[] contentBuffer = Encoding.UTF8.GetBytes(content);

            var requestLine =
                "POST " + _name + " HTTP/1.1" + CRLF;
            byte[] requestLineBuffer = Encoding.UTF8.GetBytes(requestLine);

            var headers =
                "Content-Type: text/xml; charset=utf-8" + CRLF +
                "SOAPAction: \"" + _namespace + _event + "\"" + CRLF +
                "Host: " + _server + CRLF +
                "Content-Length: " + contentBuffer.Length + CRLF +
                "Expect: 100-continue" + CRLF +
                "Accept-Encoding: gzip, deflate" + CRLF + CRLF;
            byte[] headersBuffer = Encoding.UTF8.GetBytes(headers);
            try
            {
                connection.Send(requestLineBuffer);
                Thread.Sleep(100);
                connection.Send(headersBuffer);
                Thread.Sleep(100);
                connection.Send(contentBuffer);
                Thread.Sleep(100);
                connection.Close();
            }
        }
    }
}
0 голосов
/ 24 ноября 2011

Вы неправильно написали свое имя события: static string _event = "CrearteEvent";Что приведет к тому, что сообщение не будет работать, также вы должны добавить close (), который закрывает соединение, прежде чем открывать другое соединение в конструкторе.

...