本周我的分享主题:404中的学问。
404的基本理解就是网页不存在,它是HTTP协议中的一个状态码。
最近需要通过404来解决一个问题,所以产生了一系列关于404的研究,总结一些小小收获分享出来:
1.即使你自定义了404的页面,但http头信息返回的一定要是404状态。这主要是对搜索引擎有关系,因为如果你网站产生较多页面时候但搜索引擎看到的是很多一样的正常页面,有可能会误被认为作弊。
2.404页面不要自动跳转,让用户来决定去向。
3.自定义404页面内容不要太小,否则浏览器不认。这个我可是吃过苦头了,就因为这个原因折腾了一天。http的数据分为header和content ,对于浏览器来说显示什么内容其实并不是header决定的而是content,也就是当header信息是404状态的时候,如果你输出的content有内容还应该象是一个页面,那浏览器就把你这个内容输出给用户,反之浏览就会把它默认的404页面显示给用户。
关于其它希望更多补充…
我们的404页面,做了这么几个工作:
1.识别图片,也就是说如果url是图片那我返回的是图片而不是html,这样就不会造成,假设你的网站有些图片被删除后网站上显示红X的不好体验。
2.重新生成静态页,在信息详细页如果静态页不存在可以在404页触发时被生成。
3.识别搜索引擎关键字,给用户更好的引导信息,也就是如果用户从搜索引擎进来的页面是不存在的,那么我们可以通过用户在搜索引擎输入的关键字提供我们网站的相关信息给用户,以防止用户直接流失,效果直接看下图:
百度的某个关键字搜索:
http://www.baidu.com/s?wd=%B3%F6%CA%DB+%C3%C0%C8%CB%B1%AA+%BA%DA
用户点击上图273的链接到达的下面的页面:
|