论坛首页 Web前端技术论坛

解决使用oscache不能缓存ajax跨域请求的问题

浏览 2878 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-03-10  
    最近在开发一个功能,由于用户访问数量巨大,每天有千万级别的访问量。所以多数jsp页面使用了oscache作为缓存。
    但是有些页面是提供给其他项目使用的,而且使用了ajax的跨域请求。所以当页面有一个ajax请求到服务器时,总是创建一个new cache,经过研究发现,ajax跨域请求时总是随机生成一个jsoncallback的方法名,所以每次调用的url都不一样。
http://******/loginAction.do?method=login&prog=10&tags=cat&tagmode=any&format=json&jsoncallback=?
    后来把这个jsoncallback的名称设成固定的名称
http://******/loginAction.do?method=login&prog=10&tags=cat&tagmode=any&format=json&jsoncallback=callbackfunction
   发现这样也可以跨域请求,但是每次还是生成新的cache.后来发现,原来jquery在执行跨域请求时,为了清除cache在url后面额外增加了一个参数"_",每次生成不同的值。于是修改jquery.js文件,将其中生成随机值的去掉。
if ( s.dataType == "script" && s.cache == null )
s.cache = false;
             //在此处插入s.cache=true
if ( s.cache === false && type == "GET" ) {
var ts = now();
// try replacing _= if it is there
var ret = s.url.replace(/(\?|&)_=.*?(&|$)/, "$1_=" + ts + "$2");
// if nothing was replaced, add timestamp to the end
s.url = ret + ((ret == s.url) ? (s.url.match(/\?/) ? "&" : "?") + "_=" + ts : "");
}

到此,解决了使用oscache不能缓存ajax跨域请求的问题
   发表时间:2009-03-11  
jQuery 里的 ajax在请求时可以设置 cache 属性
0 请登录后投票
   发表时间:2009-03-11  
跨域请求时有这个设置吗?
0 请登录后投票
论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics