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


#事故现场

调用webservice接口,报错:(十六进制值0x01)是无效的字符。
如图:
调用webservice接口,报错:(十六进制值0x01)是无效的字符_第1张图片
意思是webservice返回的信息中包含无效的字符,无法解析成xml;

#分析

使用postman向webservice发送请求,请求成功,返回了数据,但在数据中发现了一些莫名其妙的字符,如图:
调用webservice接口,报错:(十六进制值0x01)是无效的字符_第2张图片
因数据来源数据库,故去数据库中查询,果然又发现,如图:
在这里插入图片描述
将异常文本复制到notepad++中,显示的是:SOH
在这里插入图片描述
SOH是ASCII中的控制字符,start of heading的缩写,报文头的意思;

在ASCII码中,第0~31号及第127号(共33个)是控制字符或通讯专用字符,如控制符:LF(换行)、CR(回车)、FF(换页)、DEL(删除)、BS(退格)、BEL(振铃)等;通讯专用字符:SOH(文头)、EOT(文尾)、ACK(确认)等。
调用webservice接口,报错:(十六进制值0x01)是无效的字符_第3张图片

#解决方法

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

/// 
/// 过滤不可见字符
/// 
/// 原始字符
/// 删除后结果

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();
}

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