国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

AJAX POST數(shù)據(jù)中有特殊符號(轉(zhuǎn)義字符)導(dǎo)致數(shù)據(jù)丟失的解決方法

瀏覽:3日期:2022-06-14 13:34:01

使用Ajax傳送數(shù)據(jù)時,當(dāng)數(shù)據(jù)中存在加號(+)、連接符(&)或者百分號(%)時,服務(wù)器端接收數(shù)據(jù)時會丟失數(shù)據(jù)。分析Ajax傳送數(shù)據(jù)的格式與Javascript的語法:

1. "+"號:JavaScript解析為字符串連接符,所以服務(wù)器端接收數(shù)據(jù)時"+"會丟失變空格。

2. "&"號:JavaScript解析為變量連接符,所以服務(wù)器端接收數(shù)據(jù)時&符號以后的數(shù)據(jù)都會丟失變空格。

解決方法是通過正則表達式進行編碼替換(假設(shè)postStr是你想通過ajax傳送的數(shù)據(jù)字符串)

postStr = postStr.replace(/%/g, '%25'); postStr = postStr.replace(/\&/g, '%26'); postStr = postStr.replace(/\+/g, '%2B'); 下面是其它網(wǎng)友的補充

今天用ckEditor4編輯器時,把編輯器里面的內(nèi)容通過Ajax傳到后端的時候,居然發(fā)現(xiàn)后端接收的數(shù)據(jù)不完整,以下我編輯器內(nèi)容的源碼:

<p><img src='https://dss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=1483731740,4186543320&amp;fm=26&amp;gp=0.jpg'/></p>

結(jié)果“4186543320”后面的內(nèi)容就一直沒有收到。

原因:

通過網(wǎng)絡(luò)查資料,得到的原因是分號”;”導(dǎo)致的問題。

ajax傳輸以“;”分割的字符串,卻發(fā)現(xiàn)后臺只會接受到第一個字符串。

例如:我向后臺傳輸

“小明;小紅;小白”

后臺只會接收到小明。

經(jīng)過我的親自測試,發(fā)現(xiàn):

1、Ajax傳的字符串?dāng)?shù)據(jù),javascript用console.log可以完整的輸出來,只是后端接收不全,例如:

2、Ajax傳的字符串?dāng)?shù)據(jù),我直接傳分號”;”+其它正常數(shù)據(jù),后臺一樣是可以接收到的,一點問題都沒有。

根本原因是:

ajax請求內(nèi)容中包含一些HTML轉(zhuǎn)義字符,例如:

&nbsp; &gt; &lt; &amp; &quot;

最主要的是這些轉(zhuǎn)義字符中含有&。

例如:

如果我發(fā)送“ blablabla&ltgrogrogro”,則服務(wù)器僅收到“ blablabla”。

&在URL參數(shù)中是什么意思?

我相信做過web程序開發(fā)的人都知道:&代表數(shù)據(jù)查詢字符串中的另一個變量,&以此格式表示新參數(shù)的開始。

最后去看了一下“ckEditor4編輯器”,無論是為空字符串還是回車,都會自動的幫你進行HTML轉(zhuǎn)義,哪怕你配置了“不轉(zhuǎn)義HTML”參數(shù),也會自動幫你轉(zhuǎn)。

解決方法

知道了上面的原因,解決方法就容易大了,有程序經(jīng)驗的人已經(jīng)知道怎么做了?

原理就是:把HTML轉(zhuǎn)義字符解碼成標(biāo)簽或者編碼再傳送數(shù)據(jù)。

以我這里用“ckEditor4編輯器”為例子,只需要修改config.js,增加如下配置參數(shù):

config.basicEntities = false; config.htmlEncodeOutput = false;

以上這種也有一個弊端,如果你的編輯器里面有“代碼塊“功能,要插入一些代碼,例如:PHP、java、python、c++.......等等。代碼塊這里同樣也會自動進行HTML字符轉(zhuǎn)義。

最終的解決方法:

1、ajax請求傳字符串?dāng)?shù)據(jù)的時候,我們先做JavaScript URL編碼,例如:

var contents = encodeURIComponent(document.getElementById( 'editor1' ).value);

編碼函數(shù):encodeURIComponent()

解碼函數(shù):decodeURIComponent()

注意:用此編碼函數(shù),Asp與PHP處理后端的時候不需要解碼,會自動的相互通訊,自動解碼。

編碼:encodeURI()

解碼:decodeURI()

注意:用此編碼函數(shù),后端處理必須先解碼。

2、后端接收數(shù)據(jù)的時候,我們要做一個URL解碼,以PHP為例子,例如:

$contents = htmlentities(urldecode($_POST['contents']),ENT_QUOTES);

urldecode() — 解碼

urlencode() — 編碼

注意:為了安全起見,不管前端用哪個函數(shù)?只要是URL編碼過的,后端都需要解碼,好兼容。

其它解決方法:

Ajax請求傳數(shù)據(jù)類型,可以改為:json、text。具體請參考:HTTP Content-type 類型

總結(jié):

這個問題其實解決方法真的是太多了,我只是講了最簡單也是最常見的幾種吧!

到此這篇關(guān)于AJAX POST數(shù)據(jù)中有特殊符號(轉(zhuǎn)義字符)導(dǎo)致數(shù)據(jù)丟失的解決方法的文章就介紹到這了,更多相關(guān)AJAX POST數(shù)據(jù)丟失內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Ajax
相關(guān)文章:
主站蜘蛛池模板: 亚洲 [12p] | 99视频只有精品 | 精品视频国产狼人视频 | 亚洲国产成人久久精品影视 | 欧美精品做人一级爱免费 | 国产久草在线 | 亚洲精品国产精品一区二区 | 久99久精品视频免费观看v | 日韩精品一区二区三区免费视频 | 在线观看日本免费视频大片一区 | 老司机精品福利视频 | 九九热国产精品视频 | 国产在视频线在精品 | 亚洲天堂色视频 | 香蕉久久高清国产精品免费 | 成年人毛片 | 无圣光福利视频 | 欧美一区二区在线观看 | 国产成人免费高清激情视频 | 一个人看的日本免费视频 | 精品自拍一区 | 九九成人 | 视频精品一区 | 毛片图片| 成 人 黄 色 免费网 | 美国一级毛片不卡无毒 | 国产精品久久久久久久久久久不卡 | 国产成人啪精品视频免费网 | 精品视频亚洲 | 日本一级aaaa特黄毛片 | a级做爰视频免费观看 | 亚洲国产一区在线二区三区 | 欧美三级做爰在线 | 久久最新视频 | 12一15女人a毛片 | 国产一区二区亚洲精品天堂 | 国产香港特级一级毛片 | 久青草青综合在线视频 | 一区二区三区欧美在线 | 国产亚洲在线 | 久草视频在线观 |