- 浏览: 89338 次
- 性别:
- 来自: 杭州
文章分类
最新评论
-
kuge6688:
我的中文还不显示啊。。。。。。。。。。。。。。。求
Itext中文处理pdf(转) -
xmllong:
奇怪,第一个代码例子就不行,只输出start ok,中间的中文 ...
Itext中文处理pdf(转) -
byandby:
Class类有一个forName()静态方法,可以根据传入的类 ...
Java中的Class对象 -
xiaoyuqi00:
c:/aoke_temp/userInfo2009070710 ...
用jspsmartupload下载文件 -
wsbwindy:
good
怎样用JspSmartUpload实现文件上传攻略
这里的方案是页面(page)是基于GBK(gb2312) 的编码格式
AJAX的中文情况,默认情况下,tomcat和weblogic的get和post请求的编码方案都不一样,不过前提都是要设置
request.setCharactorEncoding("UTF-8")如下面代码中,get方案是很烦琐的那种将得到的参数重新编码来实现
的|new String(request.getParameter("para name").getBytes("encoding
name"))|而post方案是比较简单而方便的,也提倡使用这种方式,因为可以基于filter来管理编码
tomcat可以通过设置在server.xml里的Connector元素下设置URIencoding="gbk"参数来让get使用
post的方案(即get和post都使用request.setCharactorEncoding("UTF-
8"),request.getParameter("para name")
)具体设置参考http://www.iteye.com/topic/131542,不过在weblogic下无解(我个人还没发现如何实
现),weblogic好像在解析get参数后自己又用什么编码格式包装过......其实AJAX
get根本没有普通请求get请求作为标签的作用,我们完全可以不使用get,而只使用post
测试用的jsp和servlet在下面,丢到一个项目里,在web.xml里配置servlet后运行可以看到效果,servlet的url-
pattern是这个<url-pattern>/GetAndPostExample</url-pattern>
getAndPostExample.jsp
- <%@ page language= "java" import = "java.util.Date" contentType= "text/html; charset=gbk" %>
- <html>
- <head>
- <title>发送带参数的信息到服务器,以及get,post的区别</title>
- <script type="text/javascript" >
- var xmlHttp;
- function show()
- {
- document.getElementById("show" ).value=document.getElementById( "firstName" ).value;
- }
- function createXMLHttpRequest()
- {
- if (window.ActiveXObject)
- xmlHttp = new ActiveXObject( "Microsoft.XMLHTTP" );
- else if (window.XMLHttpRequest)
- xmlHttp = new XMLhttpRequest();
- }
- function createQueryString()
- {
- var firstName = document.getElementById("firstName" ).value;
- var secondName = document.getElementById("secondName" ).value;
- var birthday = document.getElementById("birthday" ).value;
- var queryString = "firstName=" +firstName+ "&secondName=" +secondName
- +"&birthday=" +birthday;
- return queryString;
- }
- function doRequestUsingGET()
- {
- createXMLHttpRequest();
- show();
- var queryString = "GetAndPostExample?" ;
- queryString = queryString + createQueryString()
- + "&timeStamep=" + new Date().getTime();
- xmlHttp.onreadystatechange = handleStateChange;
- xmlHttp.open("GET" ,queryString, true );
- xmlHttp.setRequestHeader("RequestType" , "ajax" );
- xmlHttp.send(null );
- //alert(queryString);
- }
- function doRequestUsingPOST()
- {
- createXMLHttpRequest();
- show();
- var url = "GetAndPostExample"
- var queryString = createQueryString()+ "&timeStamp=" + new Date().getTime();
- xmlHttp.open("POST" ,url, true );
- xmlHttp.onreadystatechange = handleStateChange;
- xmlHttp.setRequestHeader("Content-Type" , "application/x-www-form-urlencoded;" );
- //设置报头,说明此请求是ajax请求
- xmlHttp.setRequestHeader("RequestType" , "ajax" );
- xmlHttp.send(queryString);
- }
- function handleStateChange()
- {
- if (xmlHttp.readyState == 4 )
- {
- if (xmlHttp.status == 200 )
- parseResults();
- }
- }
- function parseResults()
- {
- var responseDiv = document.getElementById("serverResponse" );
- if (responseDiv.hasChildNodes())
- {
- responseDiv.removeChild(responseDiv.childNodes[0 ]);
- }
- var responseText = document.createTextNode(xmlHttp.responseText);
- responseDiv.appendChild(responseText);
- }
- </script>
- </head>
- <body>
- <h1>输入你的姓,名,生日日期</h1>
- <br>
- <table>
- <tr>
- <td>
- 姓:
- </td>
- <td>
- <input type="text" name= "firstName" id= "firstName" value= "羽飞" >
- </td>
- </tr>
- <td>
- 名:
- </td>
- <td>
- <input type="text" name= "secondName" id= "secondName" value= "翼" >
- </td>
- <tr>
- </tr>
- <tr>
- <td>
- 生日:
- </td>
- <td>
- <input type="text" name= "birthday" id= "birthday" value= "五月" >
- </td>
- <td>
- <input type="text" name= "show" id= "show" >
- </td>
- </tr>
- </table>
- <form action="#" >
- <input type="button" value= "使用GET提交" onclick= "doRequestUsingGET();" >
- <br>
- <input type="button" value= "使用POST提交" onclick= "doRequestUsingPOST();" >
- </form>
- <br>
- <br>
- <h2>服务器返回信息:</h2>
- <div id="serverResponse" >
- </div>
- </body>
- </html>
<%@ page language="java" import="java.util.Date" contentType="text/html; charset=gbk"%> <html> <head> <title>发送带参数的信息到服务器,以及get,post的区别</title> <script type="text/javascript"> var xmlHttp; function show() { document.getElementById("show").value=document.getElementById("firstName").value; } function createXMLHttpRequest() { if (window.ActiveXObject) xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); else if (window.XMLHttpRequest) xmlHttp = new XMLhttpRequest(); } function createQueryString() { var firstName = document.getElementById("firstName").value; var secondName = document.getElementById("secondName").value; var birthday = document.getElementById("birthday").value; var queryString = "firstName="+firstName+"&secondName="+secondName +"&birthday="+birthday; return queryString; } function doRequestUsingGET() { createXMLHttpRequest(); show(); var queryString = "GetAndPostExample?"; queryString = queryString + createQueryString() + "&timeStamep=" + new Date().getTime(); xmlHttp.onreadystatechange = handleStateChange; xmlHttp.open("GET",queryString,true); xmlHttp.setRequestHeader("RequestType","ajax"); xmlHttp.send(null); //alert(queryString); } function doRequestUsingPOST() { createXMLHttpRequest(); show(); var url = "GetAndPostExample" var queryString = createQueryString()+ "&timeStamp="+ new Date().getTime(); xmlHttp.open("POST",url,true); xmlHttp.onreadystatechange = handleStateChange; xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded;"); //设置报头,说明此请求是ajax请求 xmlHttp.setRequestHeader("RequestType","ajax"); xmlHttp.send(queryString); } function handleStateChange() { if (xmlHttp.readyState == 4) { if (xmlHttp.status == 200) parseResults(); } } function parseResults() { var responseDiv = document.getElementById("serverResponse"); if (responseDiv.hasChildNodes()) { responseDiv.removeChild(responseDiv.childNodes[0]); } var responseText = document.createTextNode(xmlHttp.responseText); responseDiv.appendChild(responseText); } </script> </head> <body> <h1>输入你的姓,名,生日日期</h1> <br> <table> <tr> <td> 姓: </td> <td> <input type="text" name="firstName" id="firstName" value="羽飞"> </td> </tr> <td> 名: </td> <td> <input type="text" name="secondName" id="secondName" value="翼"> </td> <tr> </tr> <tr> <td> 生日: </td> <td> <input type="text" name="birthday" id="birthday" value="五月"> </td> <td> <input type="text" name="show" id="show"> </td> </tr> </table> <form action="#"> <input type="button" value="使用GET提交" onclick="doRequestUsingGET();"> <br> <input type="button" value="使用POST提交" onclick="doRequestUsingPOST();"> </form> <br> <br> <h2>服务器返回信息:</h2> <div id="serverResponse"> </div> </body> </html>
GetAndPostExample.java
- package yufei;
- import java.io.*;
- import java.net.*;
- import javax.servlet.*;
- import javax.servlet.http.*;
- public class GetAndPostExample extends HttpServlet
- {
- protected void processRequest(HttpServletRequest request,
- HttpServletResponse response, String method1)
- throws ServletException,IOException
- {
- //设置文本类型(content type)
- response.setContentType("text/xml" );
- //设置文本类型的编码格式
- response.setCharacterEncoding("GBK" );
- response.setHeader("Cache-Control" , "no-cache" );
- String firstName =null ;
- String secondName = null ;
- String birthday = null ;
- //无论是get还是post,都要使用下面这句
- request.setCharacterEncoding("UTF-8" );
- if (method1.equals( "GET" ))
- {
- firstName = new String(request.getParameter( "firstName" ).getBytes( "ISO8859-1" ));
- secondName = new String(request.getParameter( "secondName" ).getBytes( "ISO8859-1" ));
- birthday = new String(request.getParameter( "birthday" ).getBytes( "ISO8859-1" ));
- }
- else if (method1.equals( "POST" ))
- { firstName = request.getParameter("firstName" );
- secondName = request.getParameter("secondName" );
- birthday = request.getParameter("birthday" );
- }
- String responseText = "Hello " + firstName + " " + secondName
- + " 你的生日是 " + birthday + " " + "(method: " + method1 + ")" ;
- PrintWriter out = response.getWriter();
- out.println(responseText);
- out.close();
- }
- protected void doGet(HttpServletRequest request,
- HttpServletResponse response)
- throws ServletException,IOException
- {
- processRequest(request,response,"GET" );
- }
- protected void doPost(HttpServletRequest request,
- HttpServletResponse response)
- throws ServletException,IOException
- {
- processRequest(request,response,"POST" );
- }
- }
package yufei; import java.io.*; import java.net.*; import javax.servlet.*; import javax.servlet.http.*; public class GetAndPostExample extends HttpServlet { protected void processRequest(HttpServletRequest request, HttpServletResponse response, String method1) throws ServletException,IOException { //设置文本类型(content type) response.setContentType("text/xml"); //设置文本类型的编码格式 response.setCharacterEncoding("GBK"); response.setHeader("Cache-Control","no-cache"); String firstName =null; String secondName = null; String birthday = null; //无论是get还是post,都要使用下面这句 request.setCharacterEncoding("UTF-8"); if (method1.equals("GET")) { firstName = new String(request.getParameter("firstName").getBytes("ISO8859-1")); secondName = new String(request.getParameter("secondName").getBytes("ISO8859-1")); birthday = new String(request.getParameter("birthday").getBytes("ISO8859-1")); } else if (method1.equals("POST")) { firstName = request.getParameter("firstName"); secondName = request.getParameter("secondName"); birthday = request.getParameter("birthday"); } String responseText = "Hello " + firstName + " " + secondName + " 你的生日是 " + birthday + " " + "(method: " + method1 + ")"; PrintWriter out = response.getWriter(); out.println(responseText); out.close(); } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException,IOException { processRequest(request,response,"GET"); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException,IOException { processRequest(request,response,"POST"); } }
-
-
当我们的ajax请求只使用post(tomcat下可以实现get和post同样方案)请求时,我们可以使用过滤器来实现其编码设置,就可以把
servlet中的request.setCharactorEncoding提出来,去掉servlet里的
request.setCharactorEncoding("encoding name"),加入下面的过滤器
根据fins大大的指导,将过滤器重写为可以区分普通请求和ajax请求的样式了(ajax请求中设置了header)
SetCharacterEncodingFilter.java
- package yufei;
- import java.io.IOException;
- import javax.servlet.FilterChain;
- import javax.servlet.FilterConfig;
- import javax.servlet.ServletException;
- import javax.servlet.ServletRequest;
- import javax.servlet.ServletResponse;
- import javax.servlet.Filter;
- import javax.servlet.http.HttpServletRequest;
- public class CharactorEncodingFilter implements Filter
- {
- public CharactorEncodingFilter()
- {
- super ();
- }
- private FilterConfig filterConfig;
- private String ajaxEncoding = "UTF-8" ;
- private String commonEncoding;
- protected boolean ignore = true ;
- public void init(FilterConfig filterConfig) throws ServletException
- {
- this .filterConfig = filterConfig;
- commonEncoding = filterConfig.getInitParameter("CommonRequestEncoding" );
- String value = filterConfig.getInitParameter("ignore" );
- if (value == null )
- this .ignore = true ;
- else if (value.equalsIgnoreCase( "true" ))
- this .ignore = true ;
- else if (value.equalsIgnoreCase( "yes" ))
- this .ignore = true ;
- else
- this .ignore = false ;
- }
- public void doFilter(ServletRequest req, ServletResponse res,
- FilterChain filterChain)
- {
- try
- {
- HttpServletRequest request = (HttpServletRequest) req;
- if (ignore || (request.getCharacterEncoding() == null ))
- {
- if (request.getHeader( "RequestType" ) != null
- && request.getHeader("RequestType" )
- .equalsIgnoreCase("ajax" ))
- {
- request.setCharacterEncoding(ajaxEncoding);
- }
- else if (commonEncoding != null )
- {
- request.setCharacterEncoding(commonEncoding);
- }
- else
- {
- request.setCharacterEncoding("UTF-8" );
- }
- }
- filterChain.doFilter(req, res);
- }
- catch (IOException e)
- {
- e.printStackTrace();
- }
- catch (ServletException e)
- {
- e.printStackTrace();
- }
- }
- public void destroy()
- {
- this .commonEncoding = null ;
- this .filterConfig = null ;
- }
- }
package yufei; import java.io.IOException; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.Filter; import javax.servlet.http.HttpServletRequest; public class CharactorEncodingFilter implements Filter { public CharactorEncodingFilter() { super(); } private FilterConfig filterConfig; private String ajaxEncoding = "UTF-8"; private String commonEncoding; protected boolean ignore = true; public void init(FilterConfig filterConfig) throws ServletException { this.filterConfig = filterConfig; commonEncoding = filterConfig.getInitParameter("CommonRequestEncoding"); String value = filterConfig.getInitParameter("ignore"); if (value == null) this.ignore = true; else if (value.equalsIgnoreCase("true")) this.ignore = true; else if (value.equalsIgnoreCase("yes")) this.ignore = true; else this.ignore = false; } public void doFilter(ServletRequest req, ServletResponse res, FilterChain filterChain) { try { HttpServletRequest request = (HttpServletRequest) req; if (ignore || (request.getCharacterEncoding() == null)) { if (request.getHeader("RequestType") != null && request.getHeader("RequestType") .equalsIgnoreCase("ajax")) { request.setCharacterEncoding(ajaxEncoding); } else if (commonEncoding != null) { request.setCharacterEncoding(commonEncoding); } else { request.setCharacterEncoding("UTF-8"); } } filterChain.doFilter(req, res); } catch (IOException e) { e.printStackTrace(); } catch (ServletException e) { e.printStackTrace(); } } public void destroy() { this.commonEncoding = null; this.filterConfig = null; } }
web.xml加入如下过滤器配置
- <filter>
- <filter-name>CharactorEncoding</filter-name>
- <filter-class >org.apache.struts2.dispatcher.FilterDispatcher</filter- class >
- <!-- 设置编码格式到initparameter里去 -->
- <init-param>
- <param-name>CommonRequestEncoding</param-name>
- <param-value>GBK</param-value>
- </init-param>
- </filter>
- <filter-mapping>
- <filter-name>CharactorEncoding</filter-name>
- <url-pattern>/*</url-pattern>
- </filter-mapping>
发表评论
-
Itext中文处理pdf(转)
2010-06-04 17:26 8090http://quicker.iteye.com/blog/5 ... -
JfreeChart学习总结
2008-09-10 17:35 1060JfreeChart学习总结 关键 ... -
Tomcat 5/6 utf-8 编码下完美解决(post/get)中文表单问题的过滤器
2008-05-30 00:40 68761.过滤器 (包含get与post方式)SetCharacte ... -
Tomcat 5/6 GBK 编码下完美解决中文表单问题的过滤器
2008-05-29 21:40 1825常 见的 Tomcat 5 表单编码提交后乱码的 ... -
对象的初始化
2008-05-27 09:39 1104调用构造器的具体处理步骤: 1.所有数据域被初始化为默认值(0 ... -
简单的FTP客户端 sun.net.ftp.FtpClient
2008-01-04 23:15 3113某些数据交换,我们需要通过ftp来完成。sun.net.ftp ... -
sun.net.ftp.FtpClient的函数说明
2008-01-04 23:14 1331sun.net.ftp.FtpClient., ... -
java实现的ftp文件上传例题
2008-01-04 23:13 2506前几天写过一编"关于java的http协议文件上传实 ... -
用smartUpload传文件的同时,传递参数的注意事项
2008-01-04 23:12 2109用smartUpload传文件的同时,传递参数时,在获取参数时 ... -
jsp下载文件的问题
2008-01-04 23:10 1337程序如下: <%@page language ... -
怎样用JspSmartUpload实现文件上传攻略
2008-01-04 23:08 2391㈠ 表单要求 对于上传文件的FORM表单,有两个 ... -
用jspsmartupload下载文件
2008-01-04 23:06 8304一般无论网站还是其他系统都会用到文件的上传和下载, ... -
从追MM谈Java的23种设计模式
2008-01-04 23:05 896设计模式做为程序员的& ... -
java操作Excel、PDF文件
2008-01-04 23:03 1652下面这些是在开发中用到的一些东西,有的代码贴的不是完整的,只是 ... -
Java中的内部类
2008-01-04 22:59 1034从Java1.1开始引入了内部类以来,它就引起了人们的激烈争论 ... -
用servlet filter 解决编码问题的一个小例子
2008-01-04 22:58 1642当在做程序的是你也许会遇到一些很让你恼火的乱码问题,就是在你在 ... -
JSTL标签的使用
2008-01-04 22:57 37041. <c:out>标签的用法 ... -
用java实现简单的email正则表达式判断
2008-01-04 22:56 1555import java.sql.*; import java. ... -
eclipse内存不足解决方法
2008-01-04 22:55 2100问题解决]用ECLIPSE3.2+MYECLIPS ... -
如何编写一个简单的Servlet
2008-01-04 22:54 19461.写一个Servlet的java源文件2.编译Servlet ...
相关推荐
- **编码与字符集处理**:Ajax默认使用UTF-8编码,但在服务器端处理时需要注意匹配这一设置,否则可能出现乱码。在Servlet中应通过`setCharacterEncoding("UTF-8")`方法进行设置。 - **安全性考量**:虽然Ajax增强...
Ajax请求的成功回调函数会接收服务器的响应,例如登录是否成功,然后更新页面状态,如显示错误消息或重定向到其他页面。 在文件名"codefans.net"中,我们可以推测这可能是一个网站域名,暗示这个登录实例可能是从...
jQuery中的AJAX请求是一种非常常见的前端异步数据交互方式,它的作用是使得页面无需重新加载即可向服务器请求数据,并将数据动态地加载到页面中。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它...
在Ajax请求中发送汉字,需要关注字符编码问题。默认情况下,Ajax请求的数据是以UTF-8编码的,而Servlet默认的编码可能不是UTF-8,这可能导致汉字传输过程中出现乱码。为了解决这个问题,我们需要在Ajax请求时指定...
然而,在处理中文字符时,Ajax请求可能会遇到乱码问题,这主要是由于编码格式不一致或者处理不当导致的。本文将深入探讨Ajax中文乱码问题的成因,并提供一系列解决方案。 **一、问题原因** 1. **编码格式不一致**...
1. 设置请求头编码:在发送Ajax请求时,可以设置`contentType`为`'application/x-www-form-urlencoded; charset=UTF-8'`,确保数据以UTF-8编码发送。 ```javascript $.ajax({ url: 'your-url', type: 'GET', ...
解决方法是在服务器端设置字符编码,例如Java中的`request.setCharacterEncoding("utf-8")`。 - **GET请求乱码**: - IE使用GBK编码,其他浏览器使用UTF-8。在服务器端设置编码(如Tomcat的`...
这主要涉及到字符编码的处理,特别是当Ajax请求发送的数据包含中文字符时。以下是两种常见的解决方法: **方法一:使用`encodeURI`进行编码** 在jQuery的Ajax请求中,可以对包含中文的参数进行两次`encodeURI`编码...
通过open()方法设置请求类型(GET或POST),URL(指向Java Servlet)和是否异步执行。接着,使用send()方法发送请求,参数通常是表单数据。 3. **Java Servlet**:在后端,Servlet接收到Ajax请求后,解析请求参数...
当接收到Ajax请求时,服务器需要正确识别请求中的编码,同时在返回响应时也需要使用正确的编码格式。在Servlet中,可以通过以下方式设置编码: ```java request.setCharacterEncoding("UTF-8"); // 设置请求编码 ...
然而,在实际应用中,开发者常常会遇到AJAX请求中的编码问题,特别是POST方式提交数据时出现的乱码现象。本文将详细探讨AJAX编码问题,并提供几种解决方案。 #### 一、AJAX编码问题概述 AJAX(Asynchronous ...
综上所述,解决JSP中Ajax GET请求的中文乱码问题需要从服务器配置、Servlet处理、JSP页面编码和Ajax请求等多个角度综合考虑,并进行相应的调整。通过这些步骤,可以有效地避免并解决中文乱码问题,保证数据传输的...
- Java Servlet:接收和处理Ajax请求,可以使用HttpServletRequest和HttpServletResponse对象。 - JSON(JavaScript Object Notation):通常用于交换数据,因为它的格式简洁且易于解析。 - Spring MVC或Struts2...
1. 创建Java后端:首先,我们需要定义一个Java类,比如一个名为`AjaxController`的Spring MVC控制器,其中包含处理Ajax请求的方法。这个方法可能接收JSON或URL编码的参数,处理后返回JSON数据。 ```java import org...
3. **Ajax对象的属性**:包括`readyState`、`status`、`responseText`或`responseXML`等,这些属性反映了Ajax请求的状态和响应内容。 4. **编程步骤**:一般包括创建XMLHttpRequest对象、打开连接、设置请求方法和...
- **使用`URLEncoder`编码**:在发送请求之前,可以先使用Java的`URLEncoder.encode()`方法将中文字符串进行编码,然后再发送到服务器。示例代码如下: ```javascript data: {"innerId": innerId, "flag": 1, ...
Ajax请求中的中文乱码问题主要是由于字符编码不一致导致的。以下是对这个问题的详细解析和解决方案。 首先,我们需要理解字符编码的基本概念。字符编码是用来表示文本字符的一种规则,常见的有ASCII、GBK、UTF-8等...
在Web开发中,尤其是在使用Java与JSP技术栈进行开发时,经常会遇到的一个问题是:如何处理AJAX请求中的中文字符乱码问题。本篇文章将详细介绍如何通过前端编码处理、后端参数接收以及响应头设置等手段来有效解决这一...
本篇将重点讲解如何使用POST方式发送AJAX请求,并对表单数据进行封装。 一、AJAX基本原理 AJAX基于JavaScript的XMLHttpRequest对象,该对象是浏览器内置的对象,用于在后台与服务器进行通信。通过创建...