2分六合

IT技术互动交流平台

你知道HTTP状态码204和304的区别么?

作者:iData  发布日期:2013-08-01 20:21:17

在搜索引擎中输入“HTTP状态码”,或者输入“http status code”,可以找到详尽的资料。但是,这些资料大都是描述了状态码的定义,至于技术上的微妙之处,只能是靠自己摸索了吧。

 

204和304的区别,直接告诉大家答案,还是先卖个关子呢?知道答案的看到这里可以离开了,不知道答案的如果着急,可以直接跳到最后。如果还有些兴趣,那就跟我一步步来吧,这样记忆会更长久一些。

 

204和304的定义,简单描述如下:

204 No Content
304 Not Modified

 

顾名思义倒是能看出一些端倪。但是,无论是英文还是中文,204的补充说明很有误导性:

If the client is a user agent, it SHOULD NOT change its document view.
在并没有新文档的情况下,204 (SC_NO_CONTENT)确保浏览器继续显示先前的文档。

 

在真相大白之前,还是先看看我遇到的问题吧。

 

现象:

网页使用了jQuery。本机IE10打开页面没有问题。两位同事的IE10打开页面报$函数不存在错误。

分析:

两位同事的IE10对两个页面中相同来源的javascript文件,只执行一遍。打开第一个页面能够正常显示,打开第二个页面则报$函数不存在错误。

错误的解决方式:

恢复IE默认配置,如下图所示:

正确的解决方式:

注意到这个站点在输出内容之前有这么一个逻辑

if(resultText.equals("")){
httpServletResponse.setStatus(204);
}

正确的做法是把整个if语句全部注掉。浏览器的配置是“自动”还是“每次访问网页时”,都行。错误现象中“本机IE10打开页面没有问题”是个误导,只要操作“得当”,问题在本机也是可以再现的。

 

真相,204和304的区别:

在本例中,204的同时返回了空文件,这个空文件要替换上次缓存的文件。这样第一次打开页面获取jQuery代码是正确的,页面正常显示;第二次打开页面时询问是否要更新,结果返回了空文件,这个空文件成为了新的缓存,然后错误现象看起来就像是jQuery没有加载,而且以后也不会再“加载”了,因为文件是空的拿什么加载?注释掉那个httpServletResponse.setStatus(204)的程序指令,Web服务器就自动返回304了,304的意思是还用上次的缓存,这样就不会有空文件的问题,所以页面正常显示。这就解释了为什么当出现问题时清空缓存有用,也不难理解为什么“每次从服务器刷新”更有用。因为浏览器安装的默认配置就是有缓存机制的,我们要求每个用户去修改他们的配置不现实,所以倘若不能够正确地理解到204和304的微妙区别,便不能铲除错误的根源,留下一个阴影在那里微笑。


延伸阅读:

Tag标签:   
  • 专题推荐

About IT165 - 广告服务 - 隐私声明 - 版权申明 - 免责条款 - 网站地图 - 网友投稿 - 联系方式
本站内容来自于互联网,仅供用于网络技术学习,学习中请遵循相关法律法规