HttpWebRequest.EndGetRequestStream проблема в Silverlight - PullRequest
3 голосов
/ 17 ноября 2009

Я использую HTTPWebRequest для публикации данных на веб-сервере в Silver light 3.0, вот мой код

    public void MakePostRequest()
    {


            // Create a new HttpWebRequest object.

        HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://www.mywebsite.com/somepage.php");    

            // Set the ContentType property. 
            request.ContentType="application/x-www-form-urlencoded";
            // Set the Method property to 'POST' to post data to the URI.
            request.Method = "POST";

            // Start the asynchronous operation.    
            request.BeginGetRequestStream(new AsyncCallback(ReadCallback), request);    

           // Keep the main thread from continuing while the asynchronous
            // operation completes. A real world application
            // could do something useful such as updating its user interface. 
            allDone.WaitOne();

            // Get the response.

            request.BeginGetResponse(new AsyncCallback(ResponseCallback), request);    
    }


    private static void ResponseCallback(IAsyncResult asynchronousResult)
    {
        HttpWebRequest request = (HttpWebRequest)asynchronousResult.AsyncState;
        HttpWebResponse resp = (HttpWebResponse)request.EndGetResponse(asynchronousResult);
        Stream streamResponse = resp.GetResponseStream();
        StreamReader streamRead = new StreamReader(streamResponse);
        string responseString = streamRead.ReadToEnd();
        Console.WriteLine(responseString);
        // Close the stream object.
        streamResponse.Close();
        streamRead.Close();

        // Release the HttpWebResponse.
        resp.Close();
    }

    private static void ReadCallback(IAsyncResult asynchronousResult)
    {    
            IDictionary<string, string> objDictionary = new Dictionary<string, string>();  
            objDictionary.Add("action", "login");
            objDictionary.Add("login", "myid@yahoo.com");
            objDictionary.Add("password", "pass123");


            HttpWebRequest request = (HttpWebRequest)asynchronousResult.AsyncState;
            // End the operation.
            // This line of code making the blocking call???
            Stream postStream = request.EndGetRequestStream(asynchronousResult);

        string boundary = "----------------------------" + DateTime.Now.Ticks.ToString("x");

            Stream memStream = new System.IO.MemoryStream();

            byte[] boundarybytes = System.Text.Encoding.UTF8.GetBytes("\r\n--" + boundary + "\r\n");

            string formdataTemplate = "\r\n--" + boundary + "\r\nContent-Disposition: form-data; name=\"{0}\";\r\n\r\n{1}";

            foreach (KeyValuePair<string, string> entry in objDictionary)
            {
                string key = entry.Key;
               string value = entry.Value;
                string formitem = string.Format(formdataTemplate, key, value);
                byte[] formitembytes = System.Text.Encoding.UTF8.GetBytes(formitem);
                memStream.Write(formitembytes, 0, formitembytes.Length);
            }

        memStream.Write(boundarybytes, 0, boundarybytes.Length);



        memStream.Position = 0;
        byte[] tempBuffer = new byte[memStream.Length];
        memStream.Read(tempBuffer, 0, tempBuffer.Length);

        //Writing the name value pair
        postStream.Write(tempBuffer, 0, tempBuffer.Length);

        memStream.Close();
        postStream.Close();

}

Проблема, с которой я сталкиваюсь, заключается в том, что линия Stream postStream = request.EndGetRequestStream(asynchronousResult); выполняет некоторый блокирующий вызов, и все мое приложение кажется зависшим ... однако я могу открыть ту же самую веб-страницу из браузера ... Почему это так?

Ответы [ 4 ]

3 голосов
/ 17 ноября 2009

Снимите использование ручки ожидания allDone. Вместо этого переместите ваш вызов на BeginGetResponse до конца ReadCallback метода. Фактически вы объединяете вызовы: -

BeginGetRequest->ReadCallback->BeginGetResponse->ResponseCallback

Кстати, вы используете тип контента "application / x-www-form-urlencoded". Однако вы, похоже, пытаетесь закодировать тело объекта Multipart, и в этом случае тип вашего контента должен быть «multipart / form-data».

0 голосов
/ 20 декабря 2009

кажется или может быть, вы собираетесь получить доступ к URL, который требует «разрешения». В веб-браузере хранятся файлы cookie или любые другие файлы, на которые вы имеете право доступа, но ваше приложение - нет. После того как вы войдете в этот URL-адрес с помощью браузера, вы получите это разрешение на доступ только для вашего браузера и не сможете перейти в другое приложение.

0 голосов
/ 17 ноября 2009

Если все, что вы хотите сделать, это POST и сбор пары имя / значение на сервере, просто используйте WebClient. В двух строках кода вы можете достичь того, что вы хотите.

Конечно, он не даст вам точного контроля, как, например, возможность реализовать асинхронную работу, но в конце концов он выполнит свою работу.

0 голосов
/ 17 ноября 2009

Кажется, что это не весь ваш код, так как есть:

 allDone.WaitOne();

Скорее всего, это будет источником вашего блокирующего вызова.

...