以前在新浪博客写过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("正确");
}
}
}
. 代码如下:
request.setcharacterencoding("utf-8");
stringusername = request.getparameter("username");
username= new string(username.getbytes("iso-8859-1"),"utf-8");
. 代码如下:
<%@ 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" name="username"onblur="vali();"/><span></span><br/>
密码:<inputtype="password" name="password" />
</body>
</html>
. 代码如下:
function vali(){
$.ajax({
type:"get",
url:"/jquery_ajax/vali",
data:encodeuri("username="+$(":text").val()),
success:function(data){
$("span").text(data);
}
});
}
. 代码如下:
<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>
如对本文有疑问, 点击进行留言回复!!
selenium + ajax抓取英雄联盟全部英雄的详细信息及多线程保存全部皮肤图片到本地
网友评论