也可以在js发送数据之前用escape函数把data转换为16进制的字符串,用js读取数据的时候再用unescape转换回来就ok了。
今天突发奇想,AJAX调用的时候会不会发送cookie 呢?马上写了一个程序测试一下,果然能,这样就可以在调用ajax之前,先把数据通过javascript写到cookie里,然后再send就可以将cookie里的数据发送出去了,太爽了!!
演示地址:http://cn5.cn/ajax/ajax12.htm
客户端代码 ajax.htm
<title>AJAX使用cookie传值例子</title>
<script>
var oDiv
var xh
function getXML()
{
setcookie($('name').value,$('val').value);
oDiv = document.all.m
oDiv.innerHTML = "正在装载,请稍侯......."
oDiv.style.display= ""
xh = new ActiveXObject("Microsoft.XMLHTTP")
xh.onreadystatechange = getReady
xh.open("POST","a.php",false)
xh.send();
}
function getReady()
{
if(xh.readyState==4)
{
if(xh.status==200)
{
oDiv.innerHTML = "完成"
}
else
{
oDiv.innerHTML = "抱歉,装载数据失败。原因:" + xh.statusText
}
}
} //author : longbill www.longbill.cn
function setcookie(name,value)
{
var cookiestr=name+"="+value+";";
var expires = "";
var cookieexp=60*60*1000;
var d = new Date();
d.setTime( d.getTime() + cookieexp);
expires = "expires=" + d.toGMTString()+";";
document.cookie = cookiestr+ expires;
}
function $(a)
{
return document.getElementById(a);
}
</script>
<body>
AJAX使用cookie传值例子:<br/>
<form name=myform>
name:<input id=name value="变量名甚至可以是中文" size=20><br/>
value:<input type=text size=20 id=val value=这里><br/>
<input onclick="getXML()" type="button" value="送出数据">
<input onclick="if(xh && xh.responseText) {alert(xh.responseText);}" type="button" value="显示返回结果"><br/>
<div id=m bgcolor=blue>在此显示状态</div>
<input type=button onclick="alert(document.cookie)" value=显示本地COOKIE>
</form>
服务器端代码 a.php
<?
header("Content-type: text/html;charset=GB2312");
echo "以下是您送出的所有COOKIE变量及其值\n";
print_r($_COOKIE);
?>
第一,javascript沿用java的字符处理方式,内部是使用unicode来处理所有字符的,
第二,utf-8是每个汉字(unicode字符)用3个字节来存储。
第三,用utf-8来send数据是不会出现乱码的,是后台程序没有正确解码才会出现乱码。
第四,ajax发送数据的时候如果修改 Content-Type 为 application/x-www-form-urlencoded",肯定是用post方式,而“太大的数据往往会出错”是用GET方式发送数据造成的。
第五,用vbscript写的函数是用来把数据转成gbk编码(操作系统默认的编码方式。如果在繁体系统上就是big5之类的编码)的,而不是gb2312,两者的编码字符数量相差3倍左右。
第六,用cookie来发送数据,一是很容易溢出,二是要不停的擦屁股,否则cookie里面的数据在每个http请求(包括图片和脚本请求)中都会被发送。三是并发几个http请求的时候,没有办法指定那个cookie是要发送给那个http请求的。
用
AJAX来GET回一个页面时,RESPONSETEXT里面的中文多半会出现乱码,这是因为xmlhttp在处理返回的responseText的时
候,是把resposeBody按UTF-8编码进解码考形成的,如果服务器送出的确实是UTF-8的数据流的时候汉字会正确显示,而送出了GBK编码流
的时候就乱了。解决的办法就是在送出的流里面加一个HEADER,指明送出的是什么编码流,这样XMLHTTP就不会乱搞了。
PHP:header('Content-Type:text/html;charset=GB2312');
ASP:Response.Charset("GB2312")
JSP:response.setHeader("Charset","GB2312");
来源:http://www.fwvv.net/info/2007/12/04/20071204-53970.shtml
分享到:
相关推荐
本文将深入探讨如何使用JS操作Cookie的子键,以及如何利用jQuery的Ajax方法进行无刷新的数据提交,并接收后台返回的值。 首先,让我们了解什么是Cookie和它的子键。Cookie是一种在客户端存储小量信息的方法,它由...
在这个示例中,HTML页面通过Ajax发送数据,而不是传统的表单提交,使得用户交互更加流畅。 2. Ajax请求:Ajax(Asynchronous JavaScript and XML)是一种创建动态网页的技术,允许在不重新加载整个页面的情况下更新...
本课主要关注AJAX(异步JavaScript和XML)、Cookie以及Session这三个关键概念,它们都是构建交互式Web应用的重要工具。 **一、AJAX** AJAX(Asynchronous JavaScript and XML)是一种创建动态网页的技术,它允许在...
然而,在使用Ajax向Django后端发送POST请求时,可能会遇到403 Forbidden错误,提示“CSRF token missing or incorrect.”。这个问题是由于Django的安全机制——跨站请求伪造(Cross-Site Request Forgery,简称CSRF...
本篇文章将详细解释如何在Vue项目中配置axios,使其在发送Ajax请求时自动携带cookie。 首先,axios在默认情况下不会自动将浏览器的cookie添加到请求头中。这是因为跨域请求(CORS)的安全策略限制,防止恶意网站...
然后,我们可以编写jQuery事件监听器来发送AJAX请求: ```javascript $(document).ready(function() { $("#getVerifyCode").click(function() { $.ajax({ type: "POST", // 通常用POST方式发送验证码请求 url: ...
JavaScript部分负责从客户端读取Cookie中的值,并发送Ajax请求到服务器端进行验证。 ```javascript function getCookieValue() { var allCookies = document.cookie; var cookie_User = allCookies.indexOf(...
在购物车应用中,商品信息如ID、名称、价格等可以被转换为JSON对象,通过AJAX发送到服务器,或者从服务器接收返回的商品数据。 **Cookie** 是一小段存储在用户浏览器中的文本信息,用于在用户与服务器之间保持状态...
首先,需要了解的是,在Ajax请求中,cookies是通过HTTP头中的`Cookie`字段携带的,而浏览器同源策略限制了跨域请求中`Cookie`字段的自动发送。为了实现跨域请求携带cookies,需要让浏览器知道该请求允许携带cookies...
5. **用户输入验证**:用户输入验证码后,前端再次通过Ajax发送用户的输入值到服务器进行验证。 6. **服务器验证**:服务器比较用户输入的验证码与之前存储的验证码是否一致,如果匹配则验证成功,否则失败。 关于...
当一个跨域Ajax请求被发送时,如果服务端没有设置正确的CORS响应头,那么浏览器将不会在请求中发送cookie和认证信息。 针对前端jquery的处理方式,关键在于设置`withCredentials`属性为`true`。这样设置之后,Ajax...
在Django中,我们通常使用jQuery库,它提供了便捷的Ajax函数,如`$.ajax()`和`$.get()`、`$.post()`等,使得发送Ajax请求变得简单。 **一、创建Ajax请求** 在前端,我们通常在JavaScript或jQuery代码中创建Ajax...
在使用Django框架进行Web开发时,经常需要通过AJAX发送POST请求以实现异步数据交互。本文将详细介绍在Django中如何通过AJAX发送POST请求的两种方法,这两种方法分别涉及到表单中的CSRF Token的使用以及在AJAX请求中...
后台 wamp=Apache+Mysql+**PHP5** 前端 - jquery-1.12.4.js - jq-ajax - jquery.cookie. https://blog.csdn.net/qq_16546829/article/details/82814403
为了解决这个问题,服务器会发送一个Cookie到客户端(通常是浏览器),这个Cookie包含了识别用户会话的信息。 描述中提到的“NULL”没有提供具体细节,但我们可以从常规的Cookie登录机制来探讨。当用户成功登录后,...
这里使用了 XMLHttpRequest 对象来发送请求并获取服务器端的响应。在服务器端,我们需要编写对应的处理程序来处理投票请求并返回投票结果。 License 信息 在代码的开头,我们可以看到 GNU Lesser General Public ...
**添加商品**:当用户点击“加入购物车”按钮时,Ajax发送一个包含商品信息的请求到服务器,JSP接收到请求后处理商品的添加操作,然后返回一个确认信息或错误消息。客户端根据返回的结果更新购物车显示。\n2. **...
在“php+ajax写的留言板”中,AJAX负责异步发送用户提交的留言,如`post.php`可能处理AJAX发送的留言数据,而`reply.php`可能用于处理回复功能。通过JavaScript(如`cookies.js`中的代码)来实现与服务器的通信,并...
【Ajax简易聊天室】是一个基于JSP、Ajax和Java技术实现的在线实时交流平台,它允许用户无需刷新页面即可发送和接收消息,提供了一种轻松、便捷的沟通体验。在这个项目中,Ajax起到了关键作用,它是一种在不重新加载...