没有太多细节,我有一个C#WCF应用程序,它是我调用的基于XML的API的包装器。该API返回一个字符串,它实际上只是一个XML文档。然后我解析该XML,然后返回它。返回的信息在浏览器中显示为JSON。
有点令人困惑,但这里有一些采样代码:
[OperationContract]
[WebInvoke(Method = "GET", BodyStyle = WebMessageBodyStyle.Bare,
ResponseFormat = WebMessageFormat.Json, UriTemplate = "/TestGetUser")]
TestGetUserResponse TestGetUser();
/* ... */
[DataContract(Namespace = "http://schema.mytestdomain/", Name = "TestGetUser")]
public class TestGetUserResponse
{
[DataMember]
public User User { get; set; }
[DataMember]
public Error Error { get; set; }
}
而TestGetUser
正在:
public TestGetUserResponse TestGetUser() {
WebClient client = getCredentials(); // getCredentials() method is defined elsewhere
string apiUrl = "http://my.api.url.com/API";
string apiRequest = "<?xml version='1.0' encoding='utf-8' ?><test>My XML Request Lives Here</test>";
string result = client.UploadString(apiUrl, apiRequest);
XmlDocument user = new XmlDocument();
user.LoadXml(result);
userNode = user.SelectSingleNode("/my[1]/xpath[1]/user[1]");
return new TestGetUserResponse {
Error = new Error(),
User = new User {
Name = userNode.SelectSingleNode("name[1]").InnerText,
Email = userNode.SelectSingleNode("email[1]").InnerText,
ID = System.Convert.ToInt32(userNode.SelectSingleNode("id[1]").InnerText)
}
};
}
因此,当我从浏览器点击我的URL时,它会返回一个JSON字符串,如下所示:
{
"Error": {
"ErrorCode": 0,
"ErrorDetail": null,
"ErrorMessage":"Success"
},
"User": {
"Name": "John Smith",
"Email": "john.smith@example.com",
"ID": 12345
}
}
现在,我的问题是,有时返回的字符串(直接来自API)是一个编码严重的UTF-8字符串(我想?我可能会有点错误)。例如,我可能会回来:
{
"Error": {
"ErrorCode": 0,
"ErrorDetail": null,
"ErrorMessage":"Success"
},
"User": {
"Name": "Jose Nuñez",
"Email": "jose.nunez@example.com",
"ID": 54321
}
}
注意User对象下的Name属性中的ñ
。
我的问题是,如何将这个编码不正确的字符串转换为ñ
,这应该是什么?
我找到了很多帖子
但似乎没有一个正是我需要的,或者试图借用这些帖子都失败了。
所以,尽可能提出我的问题,
如果我在C#(.NET 3.5)应用程序中有一个变量,那么当我把它写到屏幕上时会把它写成'ñ',我怎么能“重新编码”(可能是错误的单词) )它输出为'ñ'?
提前致谢。
答案 0 :(得分:13)
理想情况下,这将在您调用的api中修复,因此它将返回预期的编码。但你应该能够以这种方式修复它:
byte[] bytes = Encoding.GetEncoding(1252).GetBytes(Name);
var nameFixed = Encoding.UTF8.GetString(bytes);