浏览器缓存与时间戳

    很多时候我们访问一个网页,但是当我们再次向访问服务器时,可能返回的页面内容是存储在浏览器的缓存里的,比如说提交图片验证码的时候,我们点击“下一张”,图片验证码没有发生改变,如下伪代码

<img src="imageServlet" id="validateImg"/>

<a href="javascript:nextValidateImg()">换一张</a>

点击超链接时,得到浏览器缓存里的图片验证码,因为浏览器根据前后访问的页面是否相同来判断是否采用缓存页面,为了骗过浏览器,我们可以采用时间戳的方法

function nextValidateImg(){
    var url="imageServlet";
    url = convertUrl(url);
    $("#validateImg").src = "url";
}

function convertUrl(url){
    var timeStamp = (new Date()).valueOf();

    if(url.indexOf("?") >= 0){
        url = url + "&time=" + timeStamp;
    }else{
        url = url + "?time=" + timeStamp;
    }

    return url;
}

相关推荐