亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

jQuery調用AJAX時Get和post公用的亂碼解決方法實例說明

2024-09-01 08:31:38
字體:
來源:轉載
供稿:網友
js調用AJAX時Get和post的亂碼解決辦法以前有寫過的但是使用js代碼比較繁瑣,下面與大家分享下使用jQuery該怎么解決,遇到類似情況的朋友可以參考下哈

以前在新浪博客寫過js調用AJAX時Get和post的亂碼解決辦法,但是使用js代碼比較繁瑣,我們在使用ajax進行數據交互時可以使用js的一個成熟框架---jQuery。

一個網站的設計,不管是注冊登錄還是分頁查找,都需要提交參數到服務器以便得到所需的頁面數據。為了減少用戶因刷新頁面帶來的煎熬,ajax誕生。但是初學者進行項目開發時,會遇到一個很煩人的問題:中文亂碼。

下面我就通過一個簡單的實例來告訴大家哪些地方可能會導致亂碼,我們需要通過什么方式來解決。
我們這個實例主要實現用戶注冊時用戶名是否正確(已存在),在焦點移開username文本text時,對username進行異步提交并由servlet進行提取判斷,并將結果返回頁面做出相應提示。

第一步,新建一個web工程(默認GBK格式),取名jQuery_Ajax。在其WebRoot目錄下新建js文件包,將jquery-1.4.4.js放于其中。

第二步,在src下創建servlet包,并編寫Vali.java

復制代碼 代碼如下:


package servlet;
import java.io.IOException;
import java.io.PrintWriter;
import java.net.URLDecoder;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
importjavax.servlet.http.HttpServletRequest;
importjavax.servlet.http.HttpServletResponse;
public class Vali extends HttpServlet {
@Override
protectedvoid service(HttpServletRequest request, HttpServletResponse response)
throwsServletException, IOException {
StringuserName = URLDecoder.decode(request.getParameter("userName"),"utf-8");
System.out.println(userName);
response.setContentType("text/html;charset=utf-8");
PrintWriter pw =response.getWriter();
if(userName.equals("張三")){
pw.println("錯誤");
}else{
pw.println("正確");
}
}
}


從可從代碼看出,含有編碼格式的語句便是解決亂碼的辦法之一。
在代碼中注意:
1.URLDecoder.decode(request.getParameter("userName"),"utf-8")——將頁面傳來的數據進行格式轉換并提取
2.response.setContentType("text/html;charset=utf-8")——將響應返回值進行utf-8編碼后返回頁面
3.特別注意2中的轉換需寫在本方法內一切的response之前,否則可能失效
4.本servlet對數據的格式編碼只適合Post方法,若提交方式為GET則提取頁面數據的代碼如下:

復制代碼 代碼如下:


request.setCharacterEncoding("utf-8");
StringuserName = request.getParameter("userName");
userName= new String(userName.getBytes("iso-8859-1"),"utf-8");


第三步,編寫簡單注冊頁面ajax.jsp

復制代碼 代碼如下:


<%@ page language="java"import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath =request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTDHTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'ajax.jsp' starting page</title>
<metahttp-equiv="pragma" content="no-cache">
<metahttp-equiv="cache-control" content="no-cache">
<metahttp-equiv="expires" content="0">
<metahttp-equiv="keywords"content="keyword1,keyword2,keyword3">
<metahttp-equiv="description" content="This is my page">
<!--
<linkrel="stylesheet" type="text/css"href="styles.css">
-->
<scripttype="text/javascript"src="js/jquery-1.4.4.js"></script>
<scripttype="text/javascript">
function vali(){
$.ajax({
type:"POST",
url:"/jQuery_Ajax/Vali",
data:encodeURI(encodeURI("userName="+$(":text").val())),
success:function(data){
$("span").text(data);
}
});
}
</script>
</head>
<body>
用戶名:<inputtype="text"onblur="vali();"/><span></span><br/>
密碼:<inputtype="password" />
</body>
</html>


在代碼中注意:
1.頁面要設置為utf-8,且引入jquery-1.4.4.js
2.ajax通過POST方法傳遞數據,注意data的設置。將返回數據填入span標簽。

如果使用GET方法傳遞頁面數據,js代碼如下:

復制代碼 代碼如下:


function vali(){
$.ajax({
type:"GET",
url:"/jQuery_Ajax/Vali",
data:encodeURI("userName="+$(":text").val()),
success:function(data){
$("span").text(data);
}
});
}


最后一步,在web.xml配置servlet和映射

復制代碼 代碼如下:


<servlet>
<description>This is the description of my J2EEcomponent</description>
<display-name>This is the display name of my J2EEcomponent</display-name>
<servlet-name>Vali</servlet-name>
<servlet-class>servlet.Vali</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Vali</servlet-name>
<url-pattern>/Vali</url-pattern>
</servlet-mapping>


經過以上代碼的編寫,本注冊驗證的項目已完成,將其部署至tomcat并通過網頁訪問。

最后總結大神的jQuery亂碼問題解決方法:
1. 檢查頁面編碼,將頁面編碼設置為utf8,如下:
<metahttp-equiv="content-type" content="text/html;charset=utf-8">
2. 檢查servlet,在doPost或doGet方法中添加如下代碼:
response.setContentType("text/xml;charset=utf-8");
3. 修改tomcat文件,在TOMCAT_HOME/conf/server.xml文件中增加URIEncoding=”utf8”:
<Connector port="8080"protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443"URIEncoding="utf-8"/>
4. 在工程中新增過濾器,將編碼方式設置為utf8
經過以上四步操作后,問題依舊。
5. 檢查ie的http header,查看contentType字段,如下:
contentType:"application/x-www-form-urlencoded"
6.檢查firefox的http header,查看contentType字段,如下:
contentType:"application/x-www-form-urlencoded;charset=UTF-8"
對比5,6兩步,問題出現。
7.修改jQuery-1.x.x.js文件,將
contentType:"application/x-www-form-urlencoded"改為下面的代碼
contentType:"application/x-www-form-urlencoded;charset=UTF-8"
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美国产日本在线| 亚洲国产美女久久久久| 97国产成人精品视频| 日韩美女视频免费看| 国内精品久久久久伊人av| 欧美精品videosex性欧美| 日韩av一区二区在线观看| 欧美日韩裸体免费视频| 毛片精品免费在线观看| 国产精品久久久久久婷婷天堂| 久久99精品视频一区97| 国产精品久久久久久久美男| 亚洲性夜色噜噜噜7777| 日韩日本欧美亚洲| 国产小视频91| 国产精品入口日韩视频大尺度| 亚洲系列中文字幕| 91久久精品美女| 亚洲精品99久久久久| 97成人精品视频在线观看| 欧美成在线观看| 亚洲自拍偷拍色图| 日韩欧美视频一区二区三区| 欧美成年人视频网站欧美| 国产91精品久久久久| 中文在线不卡视频| 亚洲日韩中文字幕| 国产精品久久婷婷六月丁香| 亚洲精品免费一区二区三区| 欧美最顶级丰满的aⅴ艳星| 久久这里只有精品99| 欧美第一淫aaasss性| 日韩大片免费观看视频播放| 国产成人精品久久二区二区91| 久久91亚洲精品中文字幕| 91在线免费视频| 亚洲国产精品女人久久久| 欧美伦理91i| 91亚洲va在线va天堂va国| 久久成人精品电影| 正在播放欧美一区| 欧美大胆在线视频| 欧美成人精品不卡视频在线观看| 中文字幕日韩在线播放| 欧美一区二区视频97| 亚洲综合在线做性| 亚洲美女喷白浆| 5566日本婷婷色中文字幕97| 成人黄色短视频在线观看| 亚洲xxxx3d| 影音先锋日韩有码| 一区二区三区在线播放欧美| 国产极品精品在线观看| 精品久久久中文| 日韩一级裸体免费视频| 2019中文字幕在线免费观看| 成人在线观看视频网站| 国产精品精品视频一区二区三区| 欧美大学生性色视频| 亚洲香蕉成人av网站在线观看| 久久成人精品视频| 97热精品视频官网| 成人免费观看网址| 一本色道久久88综合亚洲精品ⅰ| 久久久久久久久久av| 欧美日韩亚洲国产一区| 国产精品高潮粉嫩av| 日韩一中文字幕| 8050国产精品久久久久久| 91九色在线视频| 91免费精品国偷自产在线| 亚洲精品wwwww| 韩国三级电影久久久久久| 亚洲精品久久久久中文字幕欢迎你| 亚洲免费影视第一页| 成人久久18免费网站图片| 亚洲欧美日韩高清| 中文字幕在线亚洲| 国产在线拍揄自揄视频不卡99| 日韩av综合网站| 成人妇女淫片aaaa视频| 欧美激情一级精品国产| 欧美午夜无遮挡| 欧美激情高清视频| 91久久精品久久国产性色也91| 国产精品美乳一区二区免费| 久久不射热爱视频精品| 国产精品日韩在线一区| 久久精品电影网| 一夜七次郎国产精品亚洲| 亚洲专区中文字幕| 亚洲电影免费观看高清完整版| 成人免费午夜电影| 国产精品扒开腿做爽爽爽视频| 精品成人在线视频| 综合国产在线视频| 久久香蕉国产线看观看网| 富二代精品短视频| 欧美二区在线播放| 欧美又大粗又爽又黄大片视频| 亚洲网站在线观看| 欧美一级视频免费在线观看| 色噜噜久久综合伊人一本| 日韩欧美国产激情| 国产精品免费久久久久久| 国产成人精品国内自产拍免费看| 亚洲永久免费观看| 欧美电影院免费观看| 成人精品在线观看| 亚洲女人天堂成人av在线| 国产精品三级美女白浆呻吟| 久久精品99久久久久久久久| 国产91色在线|免| 精品magnet| 最近日韩中文字幕中文| 欧美亚洲另类视频| 国产美女久久久| 国产精自产拍久久久久久蜜| 一区二区欧美久久| 国产欧美日韩中文字幕在线| 国产男人精品视频| 久久亚洲精品一区二区| 亚洲国产精品成人精品| 欧美天天综合色影久久精品| 亚洲欧美第一页| 国产精品嫩草影院久久久| 欧美极品少妇xxxxⅹ裸体艺术| 国产视频福利一区| 97精品国产97久久久久久春色| 国产精品一区久久久| 中文.日本.精品| 欧美黑人巨大精品一区二区| 欧美日韩免费在线观看| 91国产美女视频| 精品国产自在精品国产浪潮| 国产亚洲欧美另类中文| 亚洲欧美综合精品久久成人| 久久中文字幕在线视频| 亚洲综合小说区| 亚洲精品国产精品国自产在线| 国产精品激情av电影在线观看| 上原亚衣av一区二区三区| 亚洲乱码一区av黑人高潮| 51久久精品夜色国产麻豆| 久久男人av资源网站| 欧美视频二区36p| 日韩av理论片| 国产九九精品视频| 精品成人久久av| 国产精品男女猛烈高潮激情| 久久久久久久久久av| 最近2019免费中文字幕视频三| 全亚洲最色的网站在线观看| 亚洲人成电影网站色www| 欧美噜噜久久久xxx| 中文字幕亚洲欧美日韩高清| 成人av.网址在线网站| 97精品在线视频| 欧美精品videosex牲欧美| 国产91精品久久久| 久久这里有精品视频| 国产91精品在线播放| 日韩大陆毛片av| 热久久视久久精品18亚洲精品|