我正在使用使用dot net framework 4.5在C#中编写的restful API。当前它的工作正常......我在JSON转换后返回结果..我期待一个纯粹的JSON结果......我目前没有得到...我期待简单的解决方案在根元素处省略字符串XMLNS,我返回JSON ... 结果 我得到了:
我的代码:
public String GetAllSalesInvoices(string customer_id, string Startdate, string Enddate)
{
System.Web.Script.Serialization.JavaScriptSerializer serializer = new System.Web.Script.Serialization.JavaScriptSerializer();
string query = "SELECT * FROM sales_invoice WHERE customer_id =" + customer_id + " AND invoice_date BETWEEN '" + Startdate + "' AND '" + Enddate + "'";
DataSet ds = conObj.execQuery(query);
DataTable dt = new DataTable();
dt = ds.Tables[0];
List<sales_invoice> result = new List<sales_invoice>();
foreach (DataRow dr in dt.Rows)
{
sales_invoice inv = new sales_invoice()
{
Invoice_id = Convert.ToInt32(dr["invoice_id"]),
Invoice_date = Convert.ToString(dr["invoice_date"].ToString()),
Customer_id = Convert.ToInt32(dr["customer_id"]),
Product_id = Convert.ToInt32((dr["product_id"])),
Time = Convert.ToString((dr["time"]).ToString()),
Quantity = Convert.ToInt32((dr["quantity"])),
Unit_of_measure = Convert.ToString(dr["unit_of_measure"]),
Product_price = Convert.ToInt32((dr["product_price"])),
Sub_total = Convert.ToInt32((dr["sub_total"])),
};
result.Add(inv);
}
string json=serializer.Serialize(result);
return json;
}
由于
答案 0 :(得分:0)
大家好我终于想出了一个回答来删除xml名称空间或字符串名称空间的答案。 解决方案是使用上下文方法并直接将内容写入浏览器。为此,您可以使用此代码。
String result =js.Serialize(data);
this.Context.Response.ContentType = "application/json; charset=utf-8";
this.Context.Response.Write(result);
这会将json序列化的原始数据写入浏览器而不带任何名称空间。请注意,它不能在restful api的上下文中使用,因为这可能会有所不同。