У меня есть хранимая процедура, возвращающая данные с помощью хранимой процедуры в веб-методе веб-службы. Я пытаюсь затем преобразовать данные в XML, однако, когда я просматриваю источник возвращенного XML (который выглядит хорошо в окне браузера), вместо <> он возвращает <
и >
вокруг узлов XML.
Я посмотрел на подобные вопросы, и я попытался , используя HTMLEncode или HTMLDecode , но безрезультатно.
Вот мой код веб-службы.
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Text;
using System.Web;
using System.Web.Services;
using System.Xml;
namespace DAL
{
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
public class iPhoneWebServices : System.Web.Services.WebService
{
[WebMethod(Description="Return All Current Makes")]
public string ReturnMakes()
{
// Get All Records with NAME Parameter
DataTable dataTable = DataAccessLayer.ExecuteDataTable("ipa_ReturnMakes");
StringBuilder sbrXML = new StringBuilder();
if (dataTable.Rows.Count > 0)
{
sbrXML.AppendLine("<MakeList>");
foreach (DataRow objRow in dataTable.Rows)
{
sbrXML.AppendLine("<Make><MakeID>[makeID]</MakeID><MakeName>[makeName]</MakeName></Make>");
sbrXML.Replace("[makeID]", objRow["MakeID"].ToString());
sbrXML.Replace("[makeName]", objRow["MakeName"].ToString());
}
sbrXML.AppendLine("</MakeList>");
}
else
{
// no data
sbrXML.AppendLine("<makeList>");
sbrXML.AppendLine("no data");
sbrXML.AppendLine("</makeList>");
}
return sbrXML.ToString();
}
//Return Models From Make ID
[WebMethod(Description="Returns Models From Make ID")]
public string ReturnModels(int MakeID)
{
SqlParameter[] param = new SqlParameter[1];
param[0] = new SqlParameter("MakeID", SqlDbType.Int);
param[0].Value = MakeID;
// Get All Records with NAME Parameter
DataTable dataTable = DataAccessLayer.ExecuteDataTable("ipa_ReturnModelsForMake", param);
StringBuilder sbrXML = new StringBuilder();
if (dataTable.Rows.Count > 0)
{
sbrXML.AppendLine("<ModelList>");
foreach (DataRow objRow in dataTable.Rows)
{
sbrXML.AppendLine("<Model><ModelID>[modelID]</ModelID><ModelName>[modelName]</ModelName></Model>");
sbrXML.Replace("[modelID]", objRow["ModelID"].ToString());
sbrXML.Replace("[modelName]", objRow["ModelName"].ToString());
}
sbrXML.AppendLine("</ModelList>");
}
else
{
// no data
sbrXML.AppendLine("<ModelList>");
sbrXML.AppendLine("no data");
sbrXML.AppendLine("</ModelList>");
}
return sbrXML.ToString();
}
}
}
Что он возвращает в исходном представлении для веб-метода «ReturnModels»
<?xml version="1.0" encoding="utf-8"?>
<string xmlns="http://tempuri.org/"><ModelList>
<Model><ModelID>20945</ModelID><ModelName>Anglia</ModelName></Model>
<Model><ModelID>11006</ModelID><ModelName>Transit</ModelName></Model>
<Model><ModelID>21952</ModelID><ModelName>Zodiac Mark III</ModelName></Model>
</ModelList>
</string>
Он правильно отображается в окне браузера:
<string>
<ModelList>
<Model><ModelID>20945</ModelID><ModelName>Anglia</ModelName></Model>
<Model><ModelID>15881</ModelID><ModelName>C-Max</ModelName></Model>
<Model><ModelID>20303</ModelID><ModelName>Capri</ModelName></Model>
<Model><ModelID>11006</ModelID><ModelName>Transit</ModelName></Model>
<Model><ModelID>21952</ModelID><ModelName>Zodiac Mark III</ModelName></Model>
</ModelList>
</string>
Просто нужно перенести то, что отображается в окне браузера, в источник просмотра.
Спасибо за вашу помощь и время заранее!