图解HTTP

出版日期:2014-4-15
ISBN:9787115351538
作者:【日】上野宣
页数:308页

作者简介

本书对互联网基盘——HTTP协议进行了全面系统的介绍。作者由HTTP协议的发展历史娓娓道来,严谨细致地剖析了HTTP协议的结构,列举诸多常见通信场景及实战案例,最后延伸到Web安全、最新技术动向等方面。本书的特色为在讲解的同时,辅以大量生动形象的通信图例,更好地帮助读者深刻理解HTTP通信过程中客户端与服务器之间的交互情况。读者可通过本书快速了解并掌握HTTP协议的基础,前端工程师分析抓包数据,后端工程师实现REST API、实现自己的HTTP服务器等过程中所需的HTTP相关知识点本书均有介绍。
本书适合Web开发工程师,以及对HTTP协议感兴趣的各层次读者。

书籍目录

目录
第1章 了解Web及网络基础  001
1.1  使用HTTP协议访问Web  002
1.2  HTTP的诞生003
1.2.1 为知识共享而规划Web    003
1.2.2 Web成长时代    004
1.2.3 驻足不前的HTTP    005
1.3  网络基础TCP/IP  006
1.3.1 TCP/IP协议族    006
1.3.2 TCP/IP的分层管理    007
1.3.3 TCP/IP通信传输流    009
1.4  与HTTP关系密切的协议:IP、TCP和DNS  010
1.4.1 负责传输的IP协议    011
1.4.2 确保可靠性的TCP协议    012
1.5  负责域名解析的DNS服务  013
1.6  各种协议与HTTP协议的关系  014
1.7  URI和URL  016
1.7.1 统一资源标识符  016
1.7.2 URI格式  017
第2章 简单的HTTP协议  021
2.1  HTTP协议用于客户端和服务器端之间的通信  022
2.2  通过请求和响应的交换达成通信  022
2.3  HTTP是不保存状态的协议  025
2.4  请求URI定位资源  026
2.5  告知服务器意图的HTTP  方法027
2.6  使用方法下达命令  033
2.7  持久连接节省通信量  034
2.7.1 持久连接  036
2.7.2 管线化  037
2.8  使用Cookie的状态管理  037
第3章HTTP报文内的HTTP信息  041
3.1HTTP报文  042
3.2  请求报文及响应报文的结构  042
3.3  编码提升传输速率  044
3.3.1 报文主体和实体主体的差异  044
3.3.2 压缩传输的内容编码  044
3.3.3 分割发送的分块传输编码  045
3.4  发送多种数据的多部分对象集合  046
3.5  获取部分内容的范围请求048
3.6  内容协商返回最合适的内容050
第4章 返回结果的HTTP状态码  053
4.1  状态码告知从服务器端返回的请求结果054
4.2  2XX成功  055
4.2.1 200 OK    055
4.2.2 204 No Content    056
4.2.3 206 Partial Content    056
4.3  3XX 重定向 056
4.3.1 301 Moved Permanently  057
4.3.2 302 Found 057
4.3.3 303 See Other    058
4.3.4 304 Not Modified  059
4.3.5 307 Temporary Redirect  059
4.4  4XX 客户端错误  060
4.4.1 400 Bad Request  060
4.4.2 401 Unauthorized  060
4.4.3 403 Forbidden  061
4.4.4 404 Not Found  061
4.5  5XX 服务器错误  062
4.5.1 500 Internal Server Error  062
4.5.2 503 Service Unavailable  062
第5章 与HTTP协作的Web服务器  065
5.1  用单台虚拟主机实现多个域名  066
5.2  通信数据转发程序:代理、网关、隧道  067
5.2.1 代理  068
5.2.2 网关  070
5.2.3 隧道  070
5.3  保存资源的缓存  071
5.3.1 缓存的有效期限  072
5.3.2 客户端的缓存  072
第6章 HTTP 首部  075
6.1  HTTP 报文首部  076
6.2  HTTP 首部字段  078
6.2.1 HTTP首部字段传递重要信息  078
6.2.2 HTTP首部字段结构  078
6.2.3 4种HTTP首部字段类型  079
6.2.4 HTTP/1.1首部字段一览  080
6.2.5 非HTTP/1.1首部字段  082
6.2.6   End-to-end首部和Hop-by-hop首部  083
6.3  HTTP/1.1  通用首部字段  083
6.3.1 Cache-Control  084
6.3.2 Connection  091
6.3.3 Date  093
6.3.4 Pragma  094
6.3.5 Trailer  095
6.3.6 Transfer-Encoding  096
6.3.7 Upgrade  097
6.3.8 Via  098
6.3.9 Warning  099
6.4  请求首部字段  100
6.4.1 Accept  101
6.4.2 Accept-Charset  102
6.4.3 Accept-Encoding  103
6.4.4 Accept-Language  104
6.4.5 Authorization  105
6.4.6 Expect  106
6.4.7 From  107
6.4.8 Host  107
6.4.9 If-Match  108
6.4.10 If-Modified-Since  110
6.4.11 If-None-Match  111
6.4.12 If-Range  112
6.4.13 If-Unmodified-Since  113
6.4.14 Max-Forwards  114
6.4.15 Proxy-Authorization  115
6.4.16 Range  116
6.4.17 Referer  116
6.4.18 TE  117
6.4.19 User-Agent  118
6.5  响应首部字段119
6.5.1 Accept-Ranges  119
6.5.2 Age  120
6.5.3 ETag    120
6.5.4 Location  122
6.5.5 Proxy-Authenticate  123
6.5.6 Retry-After  123
6.5.7 Server  124
6.5.8 Vary  125
6.5.9 WWW-Authenticate  125
6.6  实体首部字段126
6.6.1 Allow  126
6.6.2 Content-Encoding  127
6.6.3 Content-Language  128
6.6.4 Content-Length  128
6.6.5 Content-Location  129
6.6.6 Content-MD5  129
6.6.7 Content-Range  130
6.6.8 Content-Type  131
6.6.9 Expires  131
6.6.10  Last-Modified  132
6.7  为Cookie服务的首部字段  132
6.7.1 Set-Cookie  134
6.7.2 Cookie  136
6.8  其他首部字段137
6.8.1 X-Frame-Options  137
6.8.2 X-XSS-Protection  138
6.8.3 DNT  138
6.8.4 P3P  139
第7章 确保Web安全的HTTPS  141
7.1  HTTP的缺点  142
7.1.1 通信使用明文可能会被窃听  142
7.1.2 不验证通信方的身份就可能遭遇伪装  146
7.1.3 无法证明报文完整性,可能已遭篡改  148
7.2  HTTP+加密+认证+完整性保护=HTTPS  150
7.2.1 HTTP加上加密处理和认证以及完整性保护后即是HTTPS  150
7.2.2 HTTPS是身披SSL外壳的HTTP  151
7.2.3 相互交换密钥的公开密钥加密技术  152
7.2.4 证明公开密钥正确性的证书  155
7.2.5 HTTPS的安全通信机制  161
第8章 确认访问用户身份的认证  167
8.1  何为认证  168
8.2  BASIC 认证  169
8.3  DIGEST 认证171
8.4  SSL客户端认证173
8.4.1 SSL客户端认证的认证步骤  174
8.4.2 SSL客户端认证采用双因素认证  175
8.4.3 SSL客户端认证必要的费用  175
8.5  基于表单认证  175
8.5.1 认证多半为基于表单认证  176
8.5.2 Session管理及Cookie应用  177
第9章 基于HTTP的功能追加协议  179
9.1  基于HTTP的协议180
9.2  消除HTTP瓶颈的SPDY  180
9.2.1 HTTP的瓶颈  180
9.2.2 SPDY的设计与功能  184
9.2.3 SPDY消除Web瓶颈了吗  185
9.3  使用浏览器进行全双工通信的WebSocket  186
9.3.1 WebSocket的设计与功能  186
9.3.2 WebSocket协议  186
9.4  期盼已久的HTTP/2.0  189
9.5  Web  服务器管理文件的WebDAV  190
9.5.1 扩展HTTP/1.1的WebDAV  191
9.5.2 WebDAV内新增的方法及状态码  192
第10章 构建Web内容的技术  195
10.1  HTML  196
10.1.1 Web页面几乎全由HTML构建  196
10.1.2 HTML的版本  197
10.1.3 设计应用CSS  198
10.2  动态HTML  198
10.2.1 让Web页面动起来的动态HTML  198
10.2.2 更易控制HTML  的DOM  198
10.3  Web应用  200
10.3.1   通过Web提供功能的Web应用  200
10.3.2 与Web服务器及程序协作的CGI  200
10.3.3 因Java  而普及的Servlet  201
10.4  数据发布的格式及语言  203
10.4.1 可扩展标记语言  203
10.4.2 发布更新信息的RSS/Atom  204
10.4.3 JavaScript衍生的轻量级易用JSON  206
第11章 Web的攻击技术  207
11.1  针对Web的攻击技术  208
11.1.1 HTTP不具备必要的安全功能  208
11.1.2 在客户端即可篡改请求  209
11.1.3 针对Web应用的攻击模式  210
11.2  因输出值转义不完全引发的安全漏洞  212
11.2.1 跨站脚本攻击  213
11.2.2 SQL注入攻击  218
11.2.3 OS命令注入攻击  223
11.2.4 HTTP首部注入攻击  225
11.2.5 邮件首部注入攻击  228
11.2.6 目录遍历攻击  229
11.2.7 远程文件包含漏洞  230
11.3  因设置或设计上的缺陷引发的安全漏洞  232
11.3.1 强制浏览  232
11.3.2 不正确的错误消息处理  234
11.3.3 开放重定向  237
11.4  因会话管理疏忽引发的安全漏洞  237
11.4.1 会话劫持  238
11.4.2 会话固定攻击  239
11.4.3 跨站点请求伪造  241
11.5  其他安全漏洞  242
11.5.1 密码破解  242
11.5.2 点击劫持  247
11.5.3 DoS攻击  249
11.5.4 后门程序  250

内容概要

作者简介
上野 宣
OWASP 日本分会会长,TRICORDER株式会社董事长。
主要从事安全咨询、风险评估、信息安全教育等工作。著有《今晚我们一起学习邮件协议》(今夜わかるメールプロトコル)、《今晚我们一起学习TCP/IP》(今夜わかるTCP/IP)、《今晚我们一起学习HTTP》(今夜わかるHTTP)。担任The Tangled Web:A Guide to Securing Modern Web Application日文版的审校工作。
译者简介
于均良
上海交通大学硕士,高级软件工程师,马拉松跑者,四点网创始人。


 图解HTTP下载 精选章节试读 更多精彩书评



发布书评

 
 


精彩书评 (总计4条)

  •     用了一个月时间认真阅读了这本书,十分适合没有任何网络基础的技术人员阅读。读完这本之后去看了 《计算机网络:自顶向下方法》,图解比自顶向下更详细介绍了 HTTP 报文的相关内容,并且更能给读者展现一个与HTTP 相关的技术框架。如果希望深入理解推荐 HTTP 权威指南,我也买了,囤着待看:)
  •     有必要提一下译者:「扇贝访谈:全扇贝网打卡天数第一的奇男子Chain」 目前供职于某公司的研发部担任软件工程师兼日语(现场/会议)口译http://www.shanbay.com/weekly/article/184/
  •     记得早些年,弄了一本《HTTP权威指南》阅读,感觉晦涩难懂,弃之。前些日子,从余果的《Web全栈工程师的自我修养》获取了这本书的推荐,觉得是时候该了解一下HTTP的原理的。果不其然,所有内容以配图的方式进行阐述,清晰易懂。固推荐所有从事互联网开发(不管前后端)的人如果觉得权威指南无趣,可以拾起本书进行参考,体验一段轻松愉快的HTTP协议及互联网附带的技术之旅。如果之前没有接触过协议这块,一定会让你豁然开朗。

精彩短评 (总计50条)

  •     【20161213~20161228】,图解知识非常的直观,一图胜千言,看完之后有了总体性的认知。之前也学习过这方面的知识,到学过之后很快就忘记了。看了这本书之后终于被理顺了。刚入门的同志,非常推荐看这本书。
  •     不错 适合概念普及 不过就是太科普了很多概念一带而过 让读者自己去查标准ˊ_>ˋ当小说看吧
  •     比那本HTTP权威指南好看一点 不那么枯燥
  •     基础得不能更基础,萌是真萌,当个卡通形象设计书吧少年!
  •     插画真的很萌。但大多泛泛而谈,点到为止,嘛对于这种类型的书不能要求太多。算茶余饭后的轻松读物类型吧。其实更适合对计算机网络有基础的人进行阅读,会对所掌握的知识进行回顾、连接、重新思考,形成更加清晰的知识体系结构。
  •      good book for beginner !
  •     内容太浅显 点到为止而已 图解系列还是太浅了 只适合草草读过
  •     简明有效
  •     读起来很舒畅,图文并茂,可能也和说的浅有关系。还是学习到好多东西,好书!
  •     同事的书,匆匆度过,确实也有收获,但匆匆读来,毕竟收获不大。
  •     图多好理解啊,快速入门好选择。
  •     了解底层通信原理
  •     地铁读书系列第三本。比较直观,不深入,大多内容已经多少有点了解。入门推荐。
  •     对于任何一本入门级书籍,如果拿专业的眼光来看,那肯定会发现一大堆深度,广度,概念的问题。 但这是一本入门级的图书,相较于"专业"更偏向"科普"。 快速的浏览了一遍,对我帮助很大。此书详细讲解了HTTP方面的知识。特别是最后一章"Web的攻击技术",对于每一种技术都做了详细的图示举例,简单易懂,收获颇丰。
  •     作为http的入门书和参考书还是真真极好的
  •     入门级别的 HTTP guide,译者居然是扇贝打卡天数第一的奇男子 Chain٩(•̤̀ᵕ•̤́๑)ᵒᵏᵎᵎᵎᵎ
  •     再看再新
  •     简易工具书,可以入手纸质版。
  •     有种读规范的感觉
  •     主要是对HTTP了解和理解太少。但作为入门这本书已经很不错了。 还得多看看这方面的知识。
  •     该略过的都略过了,该讲到的也讲了
  •     读的亚马逊电子书,黑白的各种图,亏了。不过当做复习网络知识也挺好
  •     推薦給高階的產品經理和入門級的測試/前後端工程師(很多人工作了幾年不打好基礎的話照樣被劃入入門級)。算是比較不枯燥比較新的協議書了,新手觀看時請攜帶好Chrome(本書涉及的內容不需要Wireshark),確定每一個重要的概念你都能在瀏覽器里對應到。最後面涉及Web攻防的,非測試非安全領域的可選擇性跳過。
  •     相比http权威手册,此书比较精简,比较适合了解下http工作机理的web开发人员。后半部包含了https和tls的工作原理的讲解,以及其他web相关的技术。
  •     距离读这本书已经很久了,图书风格很吸引人,想到日本就想到漫画,没想到漫画还能和技术结合,形象生动,给个赞,让本来和死板的东西变得这么有趣
  •     介绍挺多概念,但太简略了,后面讲网络攻击的实例代码根本都不全,导致理解困难,结果最后一章都不想看,评分这么高难道是因为书薄?
  •     通俗易懂,但是深度不是很够,比较适合入门或者培养兴趣
  •     看了两章,是初学者的良师益友。
  •     删繁就简,大体了解。不过协议啊一条条看起来还是很无趣。
  •     跟Head First系列一样,通俗易懂,当然讲得也很浅显
  •     一直很推崇图解系列,相见恨晚,可以说将相关知识最直观地展现出来,更容易理解和学习。个人认为除了内容的深度,一点不比国内作者写的专业教材差,当然更比所谓的从入门到精通系列高端不知道到哪里去了。
  •     非常精炼的解释了http的相关知识,特别好的一本书。
  •     相当于一个简介
  •     真是一本很好的入门工具书,20块钱花的值!省的我到处Google了。
  •     一本小书,但是读起来比较有趣,不像一般的技术书籍那样枯燥
  •     补课
  •     https部分讲得不错,对https的机制有了详细了解
  •     太浅了,内容太少
  •     深入浅出的 HTTP 好书
  •     内容非常浅显。http头部占了很多内容,适合作为一个手册。读起来还是蛮轻松的。 那些图画好呆萌啊!
  •     写给外行看的http协议书。websocket,https和web 攻击等内容专业人士看看也挺好的
  •     入门读物 通俗易懂不装逼
  •     感觉还行吧,对我来说这本书,不好不坏,也没有其他好书给的那种醍醐灌顶的感觉,不过入门看看还可以,给4星。
  •     太浅显
  •     内容过于浅显,很多东西没讲明白,反而看着模糊
  •     有图解有代码。只是现在不需要这样的原理知识了。
  •     浅显易懂,软件开发够用了。
  •     也许是个人原因,感觉一般,收获不大。
  •     入门级读物
  •     简单工具书,还可以
 

农业基础科学,时尚,美术/书法,绘画,软件工程/开发项目管理,研究生/本专科,爱情/情感,动漫学堂PDF下载,。 PDF下载网 

PDF下载网 @ 2024