如何从ASPX页面读取XML响应

时间:2015-11-06 21:42:28

标签: c# asp.net xml

我正在使用C#将数据传递到.aspx页面,一切正常。现在,返回消息已转换为.xml响应,我不知道如何处理读取/写入.xml响应我的页面以显示失败/成功。

这是我实际发送数据的语法

    private void SendData()
    {
        this.lblResult.Text = string.Empty;           
        Dictionary<string, string> dictFormValues = new Dictionary<string, string>();
        string connectionString = null;
        SqlConnection cnn;
        SqlCommand cmd;
        StringBuilder sql = new StringBuilder();
        SqlDataReader reader;
        string email = string.Empty;
        connectionString = "Data Source=titanium;Initial Catalog=DB;User ID=uid;Password=pswd";
        sql.Append("select fullname, address, city, state, zip from testtable");
        cnn = new SqlConnection(connectionString);
        try
        {
            cnn.Open();
            cmd = new SqlCommand(sql.ToString(), cnn);
            reader = cmd.ExecuteReader();
            while (reader.Read())
            {
                dictFormValues.Add("name", reader.GetValue(0).ToString());
                dictFormValues.Add("address", reader.GetValue(1).ToString());
                dictFormValues.Add("city", reader.GetValue(2).ToString());
                dictFormValues.Add("state", reader.GetValue(3).ToString());
                dictFormValues.Add("zip", reader.GetValue(4).ToString());                    
                fullname = reader.GetValue(0).ToString();
            }
            reader.Close();
            cmd.Dispose();
            cnn.Close();
        }
        catch (Exception ex)
        {
            Response.Write(ex.Message.ToString());
        }
        string abcdefg = "";
        string strIpAddress = System.Web.HttpContext.Current.Request.UserHostAddress;
        string strPageTitle = this.Title;
        string strPageURL = System.Web.HttpContext.Current.Request.Url.AbsoluteUri;
        string strError = "";
        bool blnRet = false;
        blnRet = PostDataToPage(dictFormValues, abcdefg, strIpAddress, strPageTitle, strPageURL, ref strError);          
        if (blnRet == true)
        {
            this.lblResult.Text = "Success!";
        }
        else
        {
            this.lblResult.Text = strError + ": Fail";
        }
    }
    public bool PostDataToPage(Dictionary<string, string> dictFormValues, string abcdefg, string strIpAddress, string strPageTitle, string strPageURL, ref string strMessage)
    {
        string strEndpointURL = string.Format("http://invalidsite.com/test/");
        System.Web.Script.Serialization.JavaScriptSerializer json = new System.Web.Script.Serialization.JavaScriptSerializer();
        string strPostData = "";
        foreach (var d in dictFormValues)
        {
            strPostData += d.Key + "=" + Server.UrlEncode(d.Value) + "&";
        }
        strPostData += "hs_context=";
        System.Net.HttpWebRequest r = (System.Net.HttpWebRequest)System.Net.WebRequest.Create(strEndpointURL);
        r.Method = "POST";
        r.Accept = "application/json";
        r.ContentType = "application/x-www-form-urlencoded";
        r.ContentLength = strPostData.Length;
        r.KeepAlive = false;
        using (System.IO.StreamWriter sw = new System.IO.StreamWriter(r.GetRequestStream()))
        {
            try
            {
                sw.Write(strPostData);
            }
            catch (Exception ex)
            {
                strMessage = ex.Message;
                return false;
            }
        }
        return true;
    }


现在这是显示成功的语法:

<?xml version="1.0" encoding="utf-8" ?>
<result>
 <success>1</success>
 <successid>12345</successid>
 <errors/>
</result>

这是显示失败的回应

<?xml version="1.0" encoding="utf-8" ?>
<result>
 <success>0</success>
 <successid/>
 <errors>
    <error>Error 1: Too Many Characters</error>
    <error>Error 2: Invalid Entry</error>
 </errors>
</result>


现在如何在屏幕上成功写入成功时使用C#语法,如果失败读取失败的原因并写入屏幕?

1 个答案:

答案 0 :(得分:0)

试试xml linq

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Linq;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            string xml =
                "<?xml version=\"1.0\" encoding=\"utf-8\" ?>" +
                    "<result>" +
                     "<success>0</success>" +
                     "<successid/>" +
                     "<errors>" +
                        "<error>Error 1: Too Many Characters</error>" +
                        "<error>Error 2: Invalid Entry</error>" +
                     "</errors>" +
                    "</result>";

            XDocument result = XDocument.Parse(xml);
            var parsed = result.Elements().Select(x => new {
                success = (int)x.Element("success"),
                errors = x.Descendants("error") == null ? null : x.Descendants("error").Select(y => y.Value).ToList()
            }).FirstOrDefault();
        }
    }
}
​