呼叫webservice介面,報錯:(十六進位制值0x01)是無效的字元

willingtolove發表於2020-06-13

#事故現場

呼叫webservice介面,報錯:(十六進位制值0x01)是無效的字元。
如圖:
在這裡插入圖片描述
意思是webservice返回的資訊中包含無效的字元,無法解析成xml;

#分析

使用postman向webservice傳送請求,請求成功,返回了資料,但在資料中發現了一些莫名其妙的字元,如圖:
在這裡插入圖片描述
因資料來源資料庫,故去資料庫中查詢,果然又發現,如圖:
在這裡插入圖片描述
將異常文字複製到notepad++中,顯示的是:SOH
在這裡插入圖片描述
SOH是ASCII中的控制字元,start of heading的縮寫,報文頭的意思;

在ASCII碼中,第0~31號及第127號(共33個)是控制字元或通訊專用字元,如控制符:LF(換行)、CR(回車)、FF(換頁)、DEL(刪除)、BS(退格)、BEL(振鈴)等;通訊專用字元:SOH(文頭)、EOT(文尾)、ACK(確認)等。
在這裡插入圖片描述

#解決方法

故取資料的時候要過濾掉這些字元,以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();
}

相關文章