如何處理JSON中的特殊字元,處理JSON特殊字元
JSON 是適用於 Ajax 應用程式的一種有效格式,原因是它使 JavaScript 對象和字串值之間得以快速轉換。由於 Ajax 應用程式非常適合將純文字發送給伺服器端程式並對應地接收純文字,相比不能產生文本的 API,能產生文本的 API 自然更可取;而且,JSON 讓您能夠處理本地 JavaScript 對象,而無需為如何表示這些對象多費心思。
XML 也可以提供文本方面的類似益處,但用於將 JavaScript 對象轉換成 XML 的幾個現有 API 沒有 JSON API 成熟;有時,您必須在建立和處理 JavaScript 對象時格外謹慎以確保所進行的處理能與所選用的 XML 會話 API 協作。但對於 JSON,情況就大不相同:它能處理幾乎所有可能的物件類型,並會返回給您一個非常好的 JSON 資料表示。 因此,JSON 的最大價值在於可以將 JavaScript 真的作為 JavaScript 而非資料格式語言進行處理。
您所學到的所有有關使用 JavaScript 對象的技巧都可以應用到代碼中,而無需為如何將這些對象轉變成文本而多費心思。
1. 斷行符號問題
JSON傳值的時候,如果有斷行符號符就會掛的。我們可以使用正則來去掉斷行符號符:
$str = preg_replace("'([\r\n])[\s]+'", "", $str); // 不用正則 $str = str_replace("\n","",$str);
轉出來的字串就沒有斷行符號符的困擾了。
順便記錄一個PHP過濾指令碼:
<?php // $document 應包含一個 HTML 文檔。 // 本例將去掉 HTML 標籤,javascript 代碼 // 和空白字元。還會將一些通用的 // HTML 實體轉換成相應的文本。 $search = array ("'<script[^>]*?>.*?</script>'si", // 去掉 javascript "'<[\/\!]*?[^<>]*?>'si", // 去掉 HTML 標籤 "'([\r\n])[\s]+'", // 去掉空白字元 "'&(quot|#34);'i", // 替換 HTML 實體 "'&(amp|#38);'i", "'&(lt|#60);'i", "'&(gt|#62);'i", "'&(nbsp|#160);'i", "'&(iexcl|#161);'i", "'&(cent|#162);'i", "'&(pound|#163);'i", "'&(copy|#169);'i", "'&#(\d+);'e"); // 作為 PHP 代碼運行 $replace = array ("", "", "\\1", "\"", "&", "<", ">", " ", chr(161), chr(162), chr(163), chr(169), "chr(\\1)"); $text = preg_replace ($search, $replace, $document); ?>
2. HTML特殊字元
從伺服器端以JSON格式將資料傳遞到用戶端後,通過JS顯示在HTML頁面時,有一些特殊字元不能直接顯示,如後台傳遞過來的是 '<b>msg</b> #' 通過JS顯示在HTML頁面中時,顯示成了 msg # ,並不是msg #,這是由於<與>之間的內容看作是HTML標籤了,而以&開頭的 與#為HTML實體,所以顯示不正常。
解決辦法很簡單,在JS將其渲染到HTML頁面前轉換一下即可:
<script type="text/javascript"> var str = '<b>msg</b> #'; document.all.div1.innerHTML='<pre>'+str+'</pre>'; //js中的字串正常顯示在HTML頁面中 String.prototype.displayHtml= function(){ //將字串轉換成數組 var strArr = this.split(''); //HTML頁面特殊字元顯示,空格本質不是,但多個空格時瀏覽器預設只顯示一個,所以替換 var htmlChar="&<>"; for(var i = 0; i< str.length;i++){ //尋找是否含有特殊的HTML字元 if(htmlChar.indexOf(str.charAt(i)) !=-1){ //如果存在,則將它們轉換成對應的HTML實體 switch (str.charAt(i)) { case '<': strArr.splice(i,1,'<'); break; case '>': strArr.splice(i,1,'>'); break; case '&': strArr.splice(i,1,'&'); } } } return strArr.join(''); } alert(str.displayHtml()); document.all.div2.innerHTML=str.displayHtml(); </script>
3. escape()函數
該函數可以處理空格、斜線和其他任何可能影響瀏覽器的內容,並將它們轉換成 Web 可用字元(比如,空格會被轉換成 %20,瀏覽器並不會將其視為空白格處理,而是不做更改,將其直接傳遞到伺服器)。之後,伺服器會(通常自動)再把它們轉換回它們傳輸後的本來 “面目”。
var url = "nowamagic.php?people=" + escape(people.toJSONString()); request.open("GET", url, true); request.onreadystatechange = updatePage; request.send(null);
這種做法的缺點有兩個: 在使用 GET 請求發送大塊資料時,對 URL 字串有長度限制。雖然這個限制很寬泛,但對象的 JSON 字串表示的長度可能超出您的想象,尤其是在使用極其複雜的對象時更是如此。在跨網路以純文字發送所有資料的時候,發送資料面臨的不安全性超出了您的處理能力。
簡言之,以上是 GET 請求的兩個限制,而不是簡單的兩個與 JSON 資料相關的事情。在想要發送使用者名稱和姓之外的更多內容,比如表單中的選擇時,二者可能會需要多加註意。若要處理任何機密或極長的內容,可以使用 POST 請求。
4. 引號問題
JSON中如果包含引號或雙引號,會破壞JSON的格式。有兩種方法可以解決。
在入庫的時候可以使用addslashes()函數處理一下字串,給引號前加上斜杠。被改的字元包括單引號 (')、雙引號 (")、反斜線 backslash (\) 以及Null 字元NULL。
$text = addslashes($text); JavaScript的話,可以這樣: function valueReplace(v){ v=v.toString().replace(new RegExp('(["\"])', 'g'),"\\\""); return v; } var eValue = encodeURI($.trim(valueReplace(e.value)))
就總結到這裡。
以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。