调用webservice接口,报错:(十六进制值0x01)是无效的字符

时间:2023-03-08 22:58:56
调用webservice接口,报错:(十六进制值0x01)是无效的字符

#事故现场

调用webservice接口,报错:(十六进制值0x01)是无效的字符。

如图:

调用webservice接口,报错:(十六进制值0x01)是无效的字符

意思是webservice返回的信息中包含无效的字符,无法解析成xml;

#分析

使用postman向webservice发送请求,请求成功,返回了数据,但在数据中发现了一些莫名其妙的字符,如图:

调用webservice接口,报错:(十六进制值0x01)是无效的字符

因数据来源数据库,故去数据库中查询,果然又发现,如图:

调用webservice接口,报错:(十六进制值0x01)是无效的字符

将异常文本复制到notepad++中,显示的是:SOH

调用webservice接口,报错:(十六进制值0x01)是无效的字符

SOH是ASCII中的控制字符,start of heading的缩写,报文头的意思;

在ASCII码中,第0~31号及第127号(共33个)是控制字符或通讯专用字符,如控制符:LF(换行)、CR(回车)、FF(换页)、DEL(删除)、BS(退格)、BEL(振铃)等;通讯专用字符:SOH(文头)、EOT(文尾)、ACK(确认)等。

调用webservice接口,报错:(十六进制值0x01)是无效的字符

#解决方法

故取数据的时候要过滤掉这些字符,以C#代码为例:

/// <summary>
/// 过滤不可见字符
/// </summary>
/// <param name="sourceString">原始字符</param>
/// <returns>删除后结果</returns> public string DeleteControlChar(string sourceString)
{
System.Text.StringBuilder sBuilder = new System.Text.StringBuilder();
for (int i = 0; i < sourceString.Length; i++)
{
int Unicode = sourceString[i];
if (Unicode > 31 && Unicode != 127)
{
sBuilder.Append(sourceString[i].ToString());
}
}
return sBuilder.ToString();
}