扫码阅读
手机扫码阅读
为什么访问同一个网址却返回不同的内容
191 2024-07-20
我们非常重视原创文章,为尊重知识产权并避免潜在的版权问题,我们在此提供文章的摘要供您初步了解。如果您想要查阅更为详尽的内容,访问作者的公众号页面获取完整文章。
查看原文:为什么访问同一个网址却返回不同的内容
文章来源:
咸鱼运维杂谈
扫码关注公众号
咸鱼在本文中分享了一个关于HTTP内容协商的有趣现象。他展示了同一URL在不同工具中访问时返回的不同结果。当使用浏览器访问链接时,显示的是网页,而使用curl或wget命令时,返回的是csv文件。
这种现象的背后是内容协商机制。HTTP客户端在向服务器发送请求时,会包含accept字段的响应头,列出客户端支持的媒体类型。例如,Google浏览器的accept字段首选text/html,然后是application/xhtml+xml和application/xml,并按优先级降低地列举了其他类型。
当使用curl或wget工具时,它们默认的Accept字段是*/*
,意味着它们可以接受任何类型的响应。因为csvbase网站默认响应格式是csv,所以这些工具接收到的是csv格式的内容。
内容协商确保客户端和服务器可以协商出最适合的响应数据格式,提高通信效率和可靠性。它包括基于请求头、URL或实体的内容协商。其中,基于请求头的内容协商允许客户端在请求头中指定接受的内容类型,服务器根据这些信息选择响应内容类型。如果客户端接受的类型与服务器响应的类型不匹配,可能会返回406错误状态码。
如果用户不希望使用curl或wget命令接收csv格式的响应,可以手动修改请求头来指定接受的媒体类型。
文章末尾,作者引用了一个参考资料并鼓励读者支持他的写作。
想要了解更多内容?
查看原文:为什么访问同一个网址却返回不同的内容
文章来源:
咸鱼运维杂谈
扫码关注公众号
咸鱼运维杂谈的其他文章
加入社区微信群
与行业大咖零距离交流学习
软件研发质量管理体系建设
白皮书上线