ajax傳送參數(shù)含有特殊字符的快速解決方法
JQuery AJAX中遇到這樣一個問題,參數(shù)中包含特殊字符,比如&'#@等, 這時執(zhí)行AJAX的時候就會出問題,因為所傳的參數(shù)變了.看個示例就明白:
方案一:
$.ajax({ url: '/ashx/ajax.ashx', type: 'post', data: 'option=delete&name=11&adb, success: function (data) { if (data != 'error ') { } } }); '
上面執(zhí)行的ajax就是異步刪除一個name為 11&abd 的數(shù)據 當請求到ajax.ashx頁面時,我們獲取到的name參數(shù)為11 執(zhí)行操作后會發(fā)現(xiàn)其實刪除了name 為 11的數(shù)據,而沒有刪除 name 為 11&abc 的數(shù)據 這是由于有&特殊字符,把以前的倆個參數(shù)變成了三個參數(shù) option,name,abc 這時就需要用另外一種方法傳遞參數(shù):
$.ajax({ url: '/ashx/ajax.ashx', type: 'post', data: { 'option': 'delete', 'name': '11&adb' }, success: function(data) { if (data != 'error') {} } });
采用上面的json格式傳遞參數(shù)就可以避免特殊字符引起的參數(shù)錯誤問題.
方案二: 統(tǒng)一編碼UTF-8.
1.JSP頁面:
<%@ page language="java" pageEncoding="UTF-8"%>
2.Ajax.js頁面:傳遞參數(shù)時,可能出現(xiàn)特殊字符的參數(shù)用 escape(encodeURIComponent())兩函數(shù)進行轉碼,傳遞到后臺!
var url = "/ZX/servlet/AddMemoServlet memo=" + memoCode + "&otherMemo=" + escape(encodeURIComponent(otherMemo)) + "&applNo=" + applNo.innerText.substr(0, 16); //alert("url="+url); xmlHttp.open("POST", url, true); xmlHttp.onreadystatechange = doMemo; xmlHttp.send(null);
3.服務器端接收傳遞的數(shù)據 比如:一個servlet的doGet方法中: request.setCharacterEncoding("gb2312"); response.setContentType("text/xml;charset=utf-8"); response.setHeader("Cache-Control", "no-cache"); ...... //以下解決Ajax中url傳遞的參數(shù)值中包含特殊字符,后端解析出錯的問題:以utf-8以方式解碼 java.net.URLDecoder urlDecoder=new java.net.URLDecoder(); String otherMemo = urlDecoder.decode(request.getParameter("otherMemo"),"utf-8"); logger.info("otherMemo:" + otherMemo);
以上這篇ajax傳送參數(shù)含有特殊字符的快速解決方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
ajax回調函數(shù)中使用$(this)取不到對象的解決方法
如果在ajax的回調函數(shù)內使用$(this)的話,實踐證明,是取不到任何對象的,需要的朋友可以參考下2014-06-06Ajax中數(shù)據傳遞的另一種模式 javascript Object Notation思想(JSON)
JSON是一個誘人的技術,準備做一個大量的試用。希望屆時可以獲取大的性能提高。2010-12-12解析ajax核心XMLHTTPRequest對象的創(chuàng)建與瀏覽器的兼容問題
這篇文章主要介紹了ajax核心XMLHTTPRequest對象的創(chuàng)建與瀏覽器的兼容問題。需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12