JQuery getJSON 跨域 统计用户操作 问题

请教大家一下:

我想统计用户在每个页面的停留时间,然后,通过AJAX技术跨域提交给服务器处理;
目前我采用方法是通过js读取用户进入页面的时间,和用户离开页面的时间,并将得到的参数值通过getJSON方法传给服务器;具体代码如下:
js代码:
para1={
'isfrist':"y", //是否第一次进入网站
'fristTime': fristTime, //第一次进入网站的时间
'system':system, //浏览器端操作系统类型
'color':color,//颜色 32 bit
'ratio':ratio,//屏幕分辨率
'typ':typ,//浏览器的类型
'lan':lan,//浏览器的语言
'dist':dist,//客户端的时区
'entrance':entrance,//用户进入网站的页面地址
'source':source//用户来源,google或baidu搜索
}
参数的值都已经得到,当页面初次加载的时候,调用以下函数:
window.οnlοad=recordPara;//用户初次进入页面时加载的函数
window.οnunlοad=sendPara;//用户离开页面时的调用的函数
function recordPara(){
if(get_cookie("load")=="") { //判断用户是否是第一次进入网站,如果是,怎在第一次加载页面的时候,向服务器发送请求;
$.getJSON(userSite+'cartInfo.php?jsoncallback=?',para1,function(data){
alert(data);
if(data){
alert("first go in");

}
})
}
else {
enterTime=getDate();//进入页面时间
current=getUserInfo("current"); //获取用户当前浏览的页面
}
}
而当页面离开时,调用
function sendPara(){

leaveTime=getDate();//离开页面时间
if(get_cookie("load")==""){ //判断是否是第一次离开页面
enterTime=leaveTime;
document.cookie="load=yes";
}
var para2={
'isfrist':"n",//是否是第一次进入页面
'enterTime':enterTime,
'current':current,
'leaveTime':leaveTime
};
$.getJSON(userSite+'cartInfo.php?jsoncallback=?',para2,function(data){
alert("second");
if(data){
alert("发送成功!");
}
})

}
服务器端:
$i=$_GET['isfrist'];
if ( $i == 'y' ) {
$fristTime=$_GET['fristTime'];
$system=$_GET['system'];
$color=$_GET['color'];
$ratio=$_GET['ratio'];
$type=$_GET['typ'];
$lan=$_GET['lan'];
$dist=$_GET['dist'];
$entrance=$_GET['entrance'];
$source=$_GET['source'];
//插入数据库
echo json_encode($i);
}
if( $i == 'n') {
$enterTime=$_GET['enterTime'];
$current=$_GET['current'];
$leaveTime=$_GET['leaveTime'];
//插入数据库
echo json_encode('y');
}
而现在,getJSON回调函数没有返回值,但服务器端能接受参数,并且插入数据库;而经过测试在ie,firefox中运行正常,而在safari和google浏览器中,进入下一个页面,离开上一个页面(onunload)数据没有发送到服务器端,而当关闭浏览器时才发送到服务器。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
<h3>回答1:</h3><br/>在使用 jQuery 的 AJAX 跨域请求时,可以采用以下方法来解决跨域问题: 1. JSONP(JSON with Padding)跨域请求:使用 JSONP 可以通过在请求 URL 中添加一个回调函数名来实现跨域请求。服务器返回一个函数调用,并将数据作为参数传递给该函数。在 jQuery 中,可以设置 `dataType: 'jsonp'` 来发送 JSONP 请求。 2. CORS(Cross-Origin Resource Sharing)跨域请求:使用 CORS 可以在服务器端设置允许跨域请求的响应头,从而实现跨域请求。在 jQuery 中,可以设置 `crossDomain: true` 和 `xhrFields: {withCredentials: true}` 来发送 CORS 请求。 3. 代理跨域请求:在服务器端设置一个代理,将客户端的请求转发到目标服务器上,并将目标服务器返回的响应返回给客户端。在 jQuery 中,可以使用 `$.ajax()` 方法的 `url` 属性指定代理服务器的 URL。 需要注意的是,以上方法都有各自的限制和适用场景,具体使用时需要根据实际情况选择合适的方法来解决跨域问题。 <h3>回答2:</h3><br/>跨域问题指的是浏览器出于安全考虑,禁止进行跨域访问,即在A域名下的网页无法访问B域名下的资源。而jQuery Ajax是一种强大的工具,通过它我们可以方便地进行服务器端和客户端之间的异步数据交互。但是,由于Ajax请求也受到跨域限制,导致我们在使用Ajax进行跨域数据请求时需要进行一定的处理。 跨域问题的解决办法有很多种,可以通过后端设置Header头信息,也可以通过前端设置JSONP或CORS等方式进行解决。接下来,我们针对Ajax跨域问题,主要介绍以下两种解决方案: 1、JSONP 方式 JSONP是一种跨域数据请求的协议,其原理是在前端代码中添加一个脚本标签,通过向服务器端动态加载一个JS脚本,使得服务器返回的数据被包裹在一个回调函数中,并在前端代码中调用该回调函数。 示例代码: ``` $.jsonp({ url: 'http://www.example.com/api/testjsonp', // jsonp地址 type: 'GET', dataType: 'jsonp', jsonp: 'callback', //callback参数名 success: function(obj) { // 成功回调函数 // 处理返回的json数据... }, error: function() { // 失败回调函数 console.log('fail'); } }); ``` 在实现JSONP请求时,需要注意以下几点: (1)需要后端接口支持JSONP回调函数,即在后端接口中返回的数据需要被包裹在一个函数中,并通过callback参数名来传递前端定义的回调函数名称。 (2)需要定义一个callback参数名,该参数名需要在后端接口和前端代码中保持一致。 (3)需要在前端代码中定义一个回调函数,该回调函数会在后端接口返回数据时被调用,在该函数内部进行数据处理操作。 2、通过CORS方式 CORS即跨域资源共享,是一种使用了浏览器内置的安全机制,允许符合条件的网站进行跨域访问。CORS的实现需要在服务端支持,并且在请求头中添加特定的信息来启动。 示例代码: ``` $.ajax({ url: "http://www.example.com/api/testcors", // cors地址 type: "GET", dataType: "json", xhrFields: { withCredentials: true }, // 允许带 cookie 请求,不加会丢失 crossDomain: true, // 允许跨域请求 success: function(data) { // 成功回调函数 // 处理返回数据... }, error: function() { // 失败回调函数 console.log("fail"); } }); ``` 在使用CORS时,需要注意以下几点: (1)需要在服务端开启CORS,允许其他域名的访问。 (2)在前端AJAX请求时需要设置crossDomain为true,同时设置xhrFields中的withCredentials为true。 (3)需要在服务端响应中添加特定的header信息,如Access-Control-Allow-Origin等,来告知浏览器该请求被允许。 通过上述两种方式,我们可以轻松地解决Ajax跨域问题,并实现服务端和客户端之间的数据交互。 <h3>回答3:</h3><br/>跨域是指在当前页面的域名、协议、端口与请求的 URL 不同,根据浏览器的同源策略,会阻止跨域请求。jQuery ajax 跨域解决方法主要有以下几种: 1. JSONP JSONP 是一种利用 `<script>` 标签进行跨域的方式。首先客户端定义一个回调函数,然后将该函数名作为参数放在请求 URL 中,服务端接收到请求后动态生成 JSON 数据并将其作为函数参数传递给回调函数,以实现跨域访问。 常见代码示例: ``` $.ajax({ url: 'http://example.com/data?callback=mycallback', dataType: 'jsonp', jsonpCallback: 'mycallback', success: function(data){ // 处理数据 } }); ``` 2. CORS CORS(Cross-Origin Resource Sharing)是一种机制,允许服务器在响应头中设置一个 Access-Control-Allow-Origin 字段,指定允许跨域访问的域名。 常见代码示例: ``` $.ajax({ url: 'http://example.com/data', type: 'GET', xhrFields: { withCredentials: true }, crossDomain: true, success: function(data){ // 处理数据 } }); ``` 需要注意的是,使用 CORS 时浏览器需要支持 CORS 并开启,服务端需要设置 Access-Control-Allow-Origin,同时需要注意处理预请求(OPTIONS 请求)。 3. 代理 使用代理是一种比较常见的解决跨域问题的方法,即在同一域名下设置一个代理服务器,将客户端请求转发至目标服务器,然后将目标服务器的响应返回给客户端。通过代理服务器可以绕过浏览器的同源策略,实现跨域访问。 常见代码示例: ``` // 代理服务器代码 const http = require('http'); const request = require('request'); const url = require('url'); const server = http.createServer(function(req, res){ const target = url.parse(req.url).query; req.pipe(request(target)).pipe(res); }); server.listen(8000); // 客户端代码 $.ajax({ url: '/proxy?url=http://example.com/data', type: 'GET', success: function(data){ // 处理数据 } }); ``` 需要注意的是,使用代理时需要考虑代理服务器的负载以及安全问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

iteye_12762

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值