首页

Node.js实战(中文).pdf

标签: Java     发布时间:2023-04-07   
  • 云盘下载:
  • [提取码:cg2r]
       ( 需积分:4  )

Node.js实战.jpg


第一部分 Node基础

第1章 欢迎进入Node.js世界 2

1.1 构建于JavaScript之上 3

1.2 异步和事件触发:浏览器 4

1.3 异步和事件触发:服务器 5

1.4 DIRT程序 6

1.5 默认DIRT 8

1.5.1 简单的异步程序 9

1.5.2 Hello World HTTP服务器 10

1.5.3 流数据 10

1.6 小结 11


第2章 构建有多个房间的聊天室程序 12

2.1 程序概览 12

2.2 程序需求及初始设置 15

2.2.1 提供HTTP和WebSocket服务 15

2.2.2 创建程序的文件结构 16

2.2.3 指明依赖项 16

2.2.4 安装依赖项 17

2.3 提供HTML、CSS和客户端JavaScript的服务 18

2.3.1 创建静态文件服务器 19

2.3.2 添加HTML和CSS文件 21

2.4 用Socket.IO处理与聊天相关的消息 23

2.4.1 设置Socket.IO服务器 24

2.4.2 处理程序场景及事件 25

2.5 在程序的用户界面上使用客户端JavaScript 29

2.5.1 将消息和昵称/房间变更请求传给服务器 29

2.5.2 在用户界面中显示消息及可用房间 30

2.6 小结 34


第3章 Node编程基础 35

3.1 Node功能的组织及重用 36

3.1.1 创建模块 37

3.1.2 用module.exports微调模块的创建 39

3.1.3 用node_modules重用模块 40

3.1.4 注意事项 41

3.2 异步编程技术 42

3.2.1 用回调处理一次性事件 43

3.2.2 用事件发射器处理重复性事件 46

3.2.3 异步开发的难题 53

3.3 异步逻辑的顺序化 54

3.3.1 什么时候使用串行流程控制 55

3.3.2 实现串行化流程控制 56

3.3.3 实现并行化流程控制 58

3.3.4 利用社区里的工具 60

3.4 小结 61


第二部分 用Node开发Web程序

第4章 构建Node Web程序 64

4.1 HTTP服务器的基础知识 64

4.1.1 Node如何向开发者呈现HTTP请求 65

4.1.2 一个用“Hello World”做响应的HTTP服务器 67

4.1.3 读取请求头及设定响应头 67

4.1.4 设定HTTP响应的状态码 67

4.2 构建RESTful Web服务 68

4.2.1 用POST请求创建资源 69

4.2.2 用GET请求获取资源 71

4.2.3 用DELETE请求移除资源 72

4.3 提供静态文件服务 73

4.3.1 创建一个静态文件服务器 73

4.3.2 处理服务器错误 77

4.3.3 用fs.stat()实现先发制人的错误处理 77

4.4 从表单中接受用户输入 78

4.4.1 处理提交的表单域 78

4.4.2 用formidable处理上传的文件 81

4.4.3 计算上传进度 84

4.5 用HTTPS加强程序的安全性 85

4.6 小结 86


第5章 存储Node程序中的数据 87

5.1 无服务器的数据存储 88

5.1.1 内存存储 88

5.1.2 基于文件的存储 88

5.2 关系型数据库管理系统 91

5.2.1 MySQL 91

5.2.2 PostgreSQL 99

5.3 NoSQL数据库 100

5.3.1 Redis 101

5.3.2 MongoDB 105

5.3.3 Mongoose 107

5.4 小结 109


第6章 Connect 110

6.1 搭建一个Connect程序 111

6.2 Connect的工作机制 112

6.2.1 做日志的中间件 112

6.2.2 响应“hello world”的中间件 113

6.3 为什么中间件的顺序很重要 114

6.3.1 中间件什么时候不调用next() 114

6.3.2 用中间件的顺序执行认证 115

6.4 挂载中间件和服务器 115

6.4.1 认证中间件 116

6.4.2 显示管理面板的中间件 117

6.5 创建可配置中间件 118

6.5.1 创建可配置的logger中间件组件 119

6.5.2 构建路由中间件组件 120

6.5.3 构建一个重写URL的中间件组件 122

6.6 使用错误处理中间件 123

6.6.1 Connect的默认错误处理器 124

6.6.2 自行处理程序错误 124

6.6.3 使用多个错误处理中间件组件 125

6.7 小结 129


第7章 Connect自带的中间件 130

7.1 解析cookie、请求主体和查询字符串的中间件 131

7.1.1 cookieParser():解析HTTP cookie 131

7.1.2 bodyParser():解析请求主体 134

7.1.3 limit():请求主体的限制 135

7.1.4 query():查询字符串解析 137

7.2 实现Web程序核心功能的中间件 138

7.2.1 logger():记录请求 138

7.2.2 favicon():提供favicon 140

7.2.3 methodOverride():伪造HTTP方法 141

7.2.4 vhost():虚拟主机 143

7.2.5 session():会话管理 144

7.3 处理Web程序安全的中间件 148

7.3.1 basicAuth():HTTP基本认证 148

7.3.2 csrf():跨站请求伪造防护 150

7.3.3 errorHandler():开发错误处理 150

7.4 提供静态文件服务的中间件 152

7.4.1 static():静态文件服务 152

7.4.2 compress():压缩静态文件 154

7.4.3 directory():目录列表 156

7.5 小结 157


第8章 Express 158

8.1 生成程序骨架 160

8.1.1 安装Express的可执行程序 161

8.1.2 生成程序 162

8.1.3 探索程序 162

8.2 配置Express和你的程序 164

8.3 渲染视图 166

8.3.1 视图系统配置 167

8.3.2 视图查找 169

8.3.3 把数据输出到视图中 171

8.4 处理表单和文件上传 175

8.4.1 实现照片模型 175

8.4.2 创建照片上传表单 176

8.4.3 显示上传照片列表 178

8.5 创建资源下载 179

8.5.1 创建照片下载路由 179

8.5.2 实现照片下载路由 180

8.6 小结 182


第9章 Express进阶 183

9.1 认证用户 184

9.1.1 保存和加载用户 184

9.1.2 注册新用户 189

9.1.3 已注册用户登录 194

9.1.4 用户加载中间件 197

9.2 先进的路由技术 199

9.2.1 校验用户内容提交 199

9.2.2 特定路由中间件 202

9.2.3 实现分页 205

9.3 创建一个公开的REST API 208

9.3.1 设计API 208

9.3.2 添加基本的认证 209

9.3.3 实现路由 209

9.3.4 启用内容协商 212

9.4 错误处理 214

9.4.1 处理404错误 215

9.4.2 处理错误 217

9.5 小结 220


第10章 测试Node程序 221

10.1 单元测试 222

10.1.1 assert模块 222

10.1.2 Nodeunit 225

10.1.3 Mocha 227

10.1.4 Vows 232

10.1.5 should.js 234

10.2 验收测试 235

10.2.1 Tobi 236

10.2.2 Soda 237

10.3 小结 239


第11章 Web程序模板 240

11.1 用模板保持代码的整洁性 240

11.2 嵌入JavaScript的模板 244

11.2.1 创建模板 245

11.2.2 用EJS过滤器处理模板数据 246

11.2.3 将EJS集成到你的程序中 249

11.2.4 在客户端程序中使用EJS 250

11.3 使用Mustache模板语言与Hogan 251

11.3.1 创建模板 251

11.3.2 Mustache标签 252

11.3.3 微调Hogan 254

11.4 用Jade做模板 255

11.4.1 Jade基础知识 256

11.4.2 Jade模板中的逻辑 258

11.4.3 组织Jade模板 260

11.5 小结 264


第三部分 在Node中更进一步

第12章 部署Node程序并维持正常运行时间 266

12.1 安置Node程序 266

12.1.1 专用的和虚拟私有服务器 267

12.1.2 云主机 268

12.2 部署的基础知识 269

12.2.1 从Git存储库部署 270

12.2.2 让Node保持运行 270

12.3 让正常运行时间和性能达到最优 271

12.3.1 用Upstart维护正常运行时间 272

12.3.2 集群API:利用多核的优势 273

12.3.3 静态文件及代理 275

12.4 小结 277


第13章 超越Web服务器 278

13.1 Socket.IO 278

13.1.1 创建一个最小的Socket.IO程序 279

13.1.2 用Socket.IO触发页面和CSS的重新加载 281

13.1.3 Socket.IO的其他用法 283

13.2 深入TCP/IP网络 284

13.2.1 处理缓冲区和二进制数据 284

13.2.2 创建TCP服务器 286

13.2.3 创建TCP客户端 289

13.3 跟操作系统交互的工具 290

13.3.1 单例的全局process对象 291

13.3.2 使用文件系统模块 293

13.3.3 繁衍外部进程 296

13.4 开发命令行工具 301

13.4.1 解析命令行参数 301

13.4.2 处理stdin和stdout 302

13.4.3 添加彩色的输出 304

13.5 小结 306


第14章 Node生态系统 307

14.1 给Node开发人员的在线资源 308

14.1.1 Node和模块的参考资料 308

14.1.2 Google群组 309

14.1.3 IRC 309

14.1.4 GitHub问题列表 310

14.2 GitHub 310

14.2.1 GitHub入门 311

14.2.2 添加一个项目到GitHub中 312

14.2.3 用GitHub协作 314

14.3 为npm库做贡献 316

14.3.1 准备包 317

14.3.2 编写包规范 317

14.3.3 测试和发布包 318

14.4 小结 320


附录A 安装Node和社区附加组件 321

附录B 调试Node 329

附录C Express的扩展及配置 336