《PHP和MySQL Web开发 原书第5版》PDF下载

  • 购买积分:18 如何计算积分?
  • 作  者:(美)卢克·韦林(Luke Welling),劳拉·汤姆森
  • 出 版 社:北京:机械工业出版社
  • 出版年份:2018
  • ISBN:9787111587736
  • 页数:646 页
图书介绍:本书共分五篇。第一篇通过一些示例概述了PHP语言的主要部分。第二篇介绍了一些概念和设计,这些概念和设计包括使用关系型数据库系统(例如MySQL)、使用SQL、使用PHP连接MySQL数据库以及MySQL高级技术的使用。第三篇讲解了使用任何语言开发Web应用所涉及的一些常见问题,并且介绍了如何使用PHP和MySQL来进行用户身份验证,以及安全地搜集、传输和保存数据。第四篇介绍了PHP中的一些主要内置函数。第五篇介绍了如何解决真实项目中可能遇到的实际问题,例如管理和调试大型项目,提供了一些能够说明PHP和MySQL强大功能的示例项目。

第一篇 使用PHP 2

第1章 PHP快速入门教程 2

1.1 开始之前:了解PHP 3

1.2 创建示例Web应用:Bob汽车零部件商店 3

1.2.1 创建订单表单 3

1.2.2 表单处理 5

1.3 在HTML中嵌入PHP 5

1.3.1 PHP标记 6

1.3.2 PHP语句 7

1.3.3 空格 7

1.3.4 注释 8

1.4 添加动态内容 8

1.4.1 调用函数 9

1.4.2 使用date()函数 9

1.5 访问表单变量 10

1.5.1 表单变量 10

1.5.2 字符串连接 12

1.5.3 变量和字面量 12

1.6 理解标识符 13

1.7 检查变量类型 14

1.7.1 PHP的数据类型 14

1.7.2 类型强度 14

1.7.3 类型转换 15

1.7.4 可变变量 15

1.8 声明和使用常量 16

1.9 理解变量作用域 16

1.10 使用操作符 17

1.10.1 算术操作符 18

1.10.2 字符串操作符 18

1.10.3 赋值操作符 19

1.10.4 比较操作符 21

1.10.5 逻辑操作符 22

1.10.6 位操作符 22

1.10.7 其他操作符 23

1.11 计算表单总金额 25

1.12 理解操作符优先级和结合性 26

1.13 使用变量处理函数 27

1.13.1 测试和设置变量类型 27

1.13.2 测试变量状态 28

1.13.3 变量的重解释 29

1.14 根据条件进行决策 29

1.14.1 if语句 29

1.14.2 代码块 30

1.14.3 else语句 30

1.14.4 elseif语句 31

1.14.5 switch语句 32

1.14.6 比较不同条件 33

1.15 通过迭代实现重复动作 34

1.15.1 while循环 35

1.15.2 for循环和foreach循环 36

1.15.3 do…while循环 37

1.16 从控制结构或脚本中跳出 38

1.17 使用其他控制结构语法 38

1.18 使用declare 39

1.19 下一章 39

第2章 数据存储和读取 40

2.1 保存数据以便后期使用 40

2.2 存储和获取Bob的订单 41

2.3 文件处理 41

2.4 打开文件 42

2.4.1 选择文件模式 42

2.4.2 使用fopen()打开文件 42

2.4.3 通过FTP或HTTP打开文件 44

2.4.4 解决打开文件时可能遇到的问题 45

2.5 写文件 47

2.5.1 fwrite()的参数 47

2.5.2 文件格式 47

2.6 关闭文件 48

2.7 读文件 50

2.7.1 以只读模式打开文件:fopen() 51

2.7.2 知道何时读完文件:feof() 51

2.7.3 每次读取一行数据:fgets()、fgetss()和fgetcsv() 52

2.7.4 读取整个文件:readfile()、fpassthru()、file()以及file_get_contents() 53

2.7.5 读取一个字符:fgetc() 53

2.7.6 读取任意长度:fread() 54

2.8 使用其他文件函数 54

2.8.1 查看文件是否存在:file_exists() 54

2.8.2 确定文件大小:filesize() 55

2.8.3 删除一个文件:unlink() 55

2.8.4 在文件中定位:rewind()、fseek()和ftell() 55

2.9 文件锁定 56

2.10 更好的方式:数据库管理系统 57

2.10.1 使用普通文件的几个问题 58

2.10.2 RDBMS是如何解决这些问题的 58

2.11 进一步学习 59

2.12 下一章 59

第3章 使用数组 60

3.1 什么是数组 60

3.2 数字索引数组 61

3.2.1 数字索引数组的初始化 61

3.2.2 访问数组内容 62

3.2.3 使用循环访问数组 63

3.3 使用不同索引的数组 64

3.3.1 初始化数组 64

3.3.2 访问数组元素 64

3.3.3 使用循环语句 64

3.4 数组操作符 66

3.5 多维数组 66

3.6 数组排序 69

3.6.1 使用sort()函数 69

3.6.2 使用asort()函数和ksort()函数对数组排序 70

3.6.3 反向排序 70

3.7 多维数组排序 70

3.7.1 使用array_multisort()函数 71

3.7.2 用户定义排序 71

3.7.3 自定义排序函数的反序 73

3.8 对数组进行重新排序 73

3.8.1 使用shuffle()函数 73

3.8.2 逆序数组内容 75

3.9 从文件载入数组 75

3.10 执行其他数组操作 79

3.10.1 在数组中浏览:each()、current()、reset()、end()、next()、Pos()和prev() 79

3.10.2 对数组每一个元素应用函数:array_walk() 80

3.10.3 统计数组元素个数:count()、sizeof()和array_count_values() 81

3.10.4 将数组转换成标量变量:extract() 81

3.11 进一步学习 83

3.12 下一章 83

第4章 字符串操作与正则表达式 84

4.1 创建一个示例应用:智能表单邮件 84

4.2 字符串的格式化 86

4.2.1 字符串截断:chop()、ltrim()和trim() 87

4.2.2 格式化字符串以便输出 87

4.3 使用字符串函数连接和分割字符串 93

4.3.1 使用函数explode()、implode()和join() 93

4.3.2 使用strtok()函数 94

4.3.3 使用substr()函数 95

4.4 字符串比较 96

4.4.1 字符串的排序:strcmp()、strcasecmp()和strnatcmp() 96

4.4.2 使用strlen()函数判断字符串长度 96

4.5 使用字符串函数匹配和替换子字符串 97

4.5.1 在字符串中查找字符串:strstr()、strchr()、strrchr()和stristr() 97

4.5.2 查找子字符串的位置:strpos()和strrpos() 98

4.5.3 替换子字符串:str replace()和substr replace() 99

4.6 正则表达式的介绍 100

4.6.1 基础知识 100

4.6.2 分隔符 101

4.6.3 字符类和类型 101

4.6.4 重复 102

4.6.5 子表达式 102

4.6.6 子表达式计数 103

4.6.7 定位到字符串的开始或末尾 103

4.6.8 分支 103

4.6.9 匹配特殊字符 103

4.6.10 元字符一览 104

4.6.11 转义序列 104

4.6.12 回溯引用 105

4.6.13 断言 105

4.6.14 在智能表单中应用 106

4.7 用正则表达式查找子字符串 107

4.8 用正则表达式替换子字符串 107

4.9 使用正则表达式分割字符串 108

4.10 进一步学习 109

4.11 下一章 109

第5章 代码重用与函数编写 110

5.1 代码重用的好处 110

5.1.1 成本 111

5.1.2 可靠性 111

5.1.3 一致性 111

5.2 使用require()和include()函数 111

5.2.1 使用require()函数引入代码 112

5.2.2 使用require()制作Web站点模板 113

5.2.3 使用auto_prepend_file和auto_append_file 118

5.3 使用PHP函数 119

5.3.1 调用函数 119

5.3.2 调用未定义函数 120

5.3.3 理解大小写和函数名称 121

5.4 自定义函数 121

5.5 了解函数基本结构 122

5.6 参数使用 123

5.7 理解作用域 126

5.8 引用传递和值传递 128

5.9 使用return关键字 129

5.10 递归实现 131

5.11 进一步学习 134

5.12 下一章 134

第6章 面向对象特性 135

6.1 理解面向对象概念 135

6.1.1 类和对象 136

6.1.2 多态性 137

6.1.3 继承 137

6.2 在PHP中创建类、属性和操作 138

6.2.1 类结构 138

6.2.2 构造函数 138

6.2.3 析构函数 139

6.3 类的实例化 139

6.4 使用类属性 140

6.5 调用类操作 141

6.6 使用private和public关键字控制访问 141

6.7 编写访问器函数 142

6.8 在PHP中实现继承 143

6.8.1 通过继承使用private和protected控制可见性 144

6.8.2 覆盖 145

6.8.3 使用final关键字禁止继承和覆盖 147

6.8.4 理解多重继承 147

6.8.5 实现接口 148

6.9 使用Trait 149

6.10 类设计 151

6.11 编写自定义类代码 151

6.12 理解PHP面向对象高级功能 158

6.12.1 使用类级别常量 159

6.12.2 实现静态方法 159

6.12.3 检查类类型和类型提示 159

6.12.4 延迟静态绑定 160

6.12.5 对象克隆 161

6.12.6 使用抽象类 161

6.12.7 使用_call()重载方法 162

6.12.8 使用_autoload()方法 163

6.12.9 实现迭代器和迭代 163

6.12.10 生成器 165

6.12.11 将类转换成字符串 166

6.12.12 使用反射API 166

6.12.13 名称空间 168

6.12.14 使用子名称空间 169

6.12.15 理解全局名称空间 169

6.12.16 名称空间的导入和别名 170

6.13 下一章 170

第7章 错误和异常处理 171

7.1 异常处理的概念 171

7.2 Exception类 173

7.3 用户自定义异常 174

7.4 Bob汽车零部件商店应用的异常 176

7.5 异常和PHP的其他错误处理机制 179

7.6 进一步学习 180

7.7 下一章 180

第二篇 使用MySQL 182

第8章 Web数据库设计 182

8.1 关系型数据库的概念 183

8.1.1 表 183

8.1.2 列 183

8.1.3 行 183

8.1.4 值 184

8.1.5 键 184

8.1.6 模式 185

8.1.7 关系 185

8.2 设计Web数据库 185

8.2.1 考虑真实建模对象 186

8.2.2 避免保存冗余数据 187

8.2.3 使用原子列值 188

8.2.4 选择有意义的键 188

8.2.5 思考需要从数据库获得的数据 189

8.2.6 避免多个空属性的设计 189

8.2.7 表类型总结 190

8.3 Web数据库架构 190

8.4 进一步学习 191

8.5 下一章 191

第9章 Web数据库创建 192

9.1 使用MySQL监视程序 193

9.2 登录MySQL 194

9.3 创建数据库和用户 195

9.4 设置用户与权限 195

9.5 MySQL权限系统介绍 196

9.5.1 最少权限原则 196

9.5.2 创建用户和设置权限:CREATE USER和GRANT命令 196

9.5.3 权限的类型和级别 198

9.5.4 REVOKE命令 200

9.5.5 使用GRANT和REVOKE示例 200

9.6 设置Web用户 201

9.7 使用正确的数据库 202

9.8 创建数据库表 202

9.8.1 理解其他关键字 204

9.8.2 理解列类型 205

9.8.3 使用SHOW和DESCRIBE来查看数据库 207

9.8.4 创建索引 207

9.9 理解MySQL标识符 208

9.10 选择列数据类型 209

9.10.1 数字类型 210

9.10.2 日期和时间类型 211

9.10.3 字符串类型 212

9.11 进一步学习 213

9.12 下一章 213

第10章 使用MySQL数据库 214

10.1 什么是SQL 214

10.2 在数据库中插入数据 215

10.3 从数据库读取数据 217

10.3.1 读取满足特定条件的数据 218

10.3.2 多表数据读取 220

10.3.3 以特定顺序读取数据 224

10.3.4 数据分组和聚合 225

10.3.5 选择要返回的数据行 227

10.3.6 使用子查询 227

10.4 更新数据库记录 229

10.5 创建后修改表 230

10.6 删除数据库记录 232

10.7 删除表 233

10.8 删除数据库 233

10.9 进一步学习 233

10.10 下一章 233

第11章 使用PHP从Web访问MySQL数据库 234

11.1 Web数据库架构及工作原理 234

11.2 从Web查询数据库 238

11.2.1 检查并过滤输入数据 238

11.2.2 设置连接 239

11.2.3 选择要使用的数据库 240

11.2.4 查询数据库 240

11.2.5 使用prepared statement 241

11.2.6 读取查询结果 242

11.2.7 断开数据库连接 243

11.3 向数据库写入数据 243

11.4 使用其他PHP与数据库交互接口 247

11.5 进一步学习 250

11.6 下一章 250

第12章 MySQL高级管理 251

12.1 深入理解权限系统 251

12.1.1 user表 253

12.1.2 db表 254

12.1.3 tables_priv、columns_priv、procs_priv以及proxies_priv表 254

12.1.4 访问控制:MySQL如何使用Grant表 256

12.1.5 更新权限:更新结果何时生效 256

12.2 提升MySQL数据库安全 257

12.2.1 从操作系统视角看MySQL 257

12.2.2 密码 257

12.2.3 用户权限 258

12.2.4 Web问题 258

12.3 获取数据库的更多信息 259

12.3.1 使用SHOW获取信息 259

12.3.2 使用DESCRIBE获取列信息 261

12.3.3 使用EXPLAIN了解查询的执行过程 261

12.4 优化数据库 265

12.4.1 设计优化 265

12.4.2 权限 265

12.4.3 表优化 265

12.4.4 使用索引 266

12.4.5 使用默认值 266

12.4.6 其他技巧 266

12.5 MySQL数据库备份 266

12.6 MySQL数据库恢复 267

12.7 实现复制 267

12.7.1 设置主服务器 268

12.7.2 执行初始数据传输 268

12.7.3 设置从服务器 269

12.8 进一步学习 269

12.9 下一章 269

第13章 MySQL高级编程 270

13.1 LOAD DATA INFILE语句 270

13.2 存储引擎 271

13.3 事务 272

13.3.1 理解事务定义 272

13.3.2 使用InnoDB事务 272

13.4 外键 273

13.5 存储过程 274

13.5.1 基础示例 274

13.5.2 本地变量 277

13.5.3 游标和控制结构 278

13.6 触发器 281

13.7 进一步学习 283

13.8 下一章 283

第三篇 Web应用安全性 286

第14章 Web应用安全风险 286

14.1 识别面临的安全威胁 286

14.1.1 访问敏感数据 286

14.1.2 数据篡改 288

14.1.3 数据丢失或破坏 289

14.1.4 拒绝服务 289

14.1.5 恶意代码注入 291

14.1.6 被攻破服务器 291

14.1.7 否认 292

14.2 了解对手 292

14.2.1 攻击者和破解者 292

14.2.2 受影响机器的无意识用户 293

14.2.3 不满的员工 293

14.2.4 硬件窃贼 293

14.2.5 我们自己 293

14.3 下一章 293

第15章 构建安全的Web应用 294

15.1 安全策略 294

15.1.1 从正确心态开始 295

15.1.2 安全性和可用性之间的平衡 295

15.1.3 安全监控 295

15.1.4 基本方法 296

15.2 代码安全 296

15.2.1 过滤用户输入 296

15.2.2 转义输出 300

15.2.3 代码组织结构 302

15.2.4 代码自身问题 303

15.2.5 文件系统因素 303

15.2.6 代码稳定性和缺陷 304

15.2.7 执行命令 305

15.3 Web服务器和PHP的安全 306

15.3.1 保持软件更新 306

15.3.2 查看php.ini文件 307

15.3.3 Web服务器配置 307

15.3.4 Web应用共享主机托管服务 308

15.4 数据库服务器的安全 308

15.4.1 用户和权限系统 308

15.4.2 发送数据至服务器 309

15.4.3 连接服务器 309

15.4.4 运行服务器 310

15.5 保护网络 310

15.5.1 防火墙 310

15.5.2 使用隔离区 311

15.5.3 应对DoS和DDoS攻击 311

15.6 计算机和操作系统的安全 312

15.6.1 保持操作系统更新 312

15.6.2 只运行必需的软件 312

15.6.3 服务器的物理安全 312

15.7 灾难计划 313

15.8 下一章 313

第16章 使用PHP实现身份验证方法 314

16.1 识别访问者 314

16.2 实现访问控制 315

16.2.1 保存密码 317

16.2.2 加密密码 318

16.2.3 保护多页面 319

16.3 使用基本认证 320

16.4 在PHP中使用基本认证 320

16.5 使用Apache的.htaccess基本认证 321

16.6 创建自定义认证 324

16.7 进一步学习 325

16.8 下一章 325

第四篇 PHP高级编程技术 328

第17章 与文件系统和服务器交互 328

17.1 上传文件 328

17.1.1 文件上传的HTML 329

17.1.2 编写处理文件的PHP脚本 330

17.1.3 会话上传进度 334

17.1.4 避免常见上传问题 335

17.2 使用目录函数 336

17.2.1 从目录读入 336

17.2.2 获取当前目录信息 340

17.2.3 创建和删除目录 340

17.3 与文件系统交互 341

17.3.1 获取文件信息 341

17.3.2 修改文件属性 343

17.3.3 创建、删除和移动文件 344

17.4 使用程序执行函数 344

17.5 与环境交互:getenv()和putenv() 347

17.6 进一步学习 347

17.7 下一章 347

第18章 使用网络和协议函数 348

18.1 了解可用协议 348

18.2 发送和读取邮件 349

18.3 使用其他站点数据 349

18.4 使用网络查询函数 352

18.5 备份或镜像文件 355

18.5.1 使用FTP备份或镜像文件 356

18.5.2 上传文件 362

18.5.3 避免超时 362

18.5.4 使用其他FTP函数 362

18.6 进一步学习 363

18.7 下一章 363

第19章 管理日期和时间 364

19.1 在PHP中获得日期和时间 364

19.1.1 理解时区 364

19.1.2 使用date()函数 365

19.1.3 处理UNIX时间戳 366

19.1.4 使用getdate()函数 368

19.1.5 使用checkdate()函数验证日期 369

19.1.6 格式化时间戳 369

19.2 PHP和MySQL的日期格式互转 371

19.3 在PHP中计算日期 372

19.4 在MySQL中计算日期 373

19.5 使用微秒 374

19.6 使用日历函数 375

19.7 进一步学习 375

19.8 下一章 376

第20章 国际化与本地化 377

20.1 本地化不只是翻译 377

20.2 理解字符集 378

20.2.1 字符集的安全风险 379

20.2.2 使用PHP多字节字符串函数 379

20.3 创建可本地化页面基础结构 380

20.4 在国际化应用中使用gettext()函数 383

20.4.1 配置系统使用gettext() 383

20.4.2 创建翻译文件 384

20.4.3 使用gettext()在PHP中实现本地化内容 385

20.5 进一步学习 386

20.6 下一章 386

第21章 生成图像 387

21.1 设置PHP图像支持 387

21.2 理解图像格式 388

21.2.1 JPEG 388

21.2.2 PNG 388

21.2.3 GIF 389

21.3 创建图像 389

21.3.1 创建画布图像 390

21.3.2 在图像上绘制或打印文本 390

21.3.3 最终图形输出 392

21.3.4 清理 393

21.4 在其他页面中使用自动创建的图像 393

21.5 使用文本和字体创建图像 394

21.5.1 设置基础画布 397

21.5.2 调整按钮文本大小 398

21.5.3 文本定位 400

21.5.4 在按钮上写入文本 401

21.5.5 完成 401

21.6 绘制图形图像数据 401

21.7 使用其他图像函数 409

21.8 下一章 409

第22章 使用PHP会话控制 410

22.1 什么是会话控制 410

22.2 理解基本会话功能 410

22.2.1 什么是cookie 411

22.2.2 通过PHP设置cookie 411

22.2.3 在会话中使用cookie 412

22.2.4 保存会话ID 412

22.3 实现简单会话 412

22.3.1 启动会话 413

22.3.2 注册会话变量 413

22.3.3 使用会话变量 413

22.3.4 销毁变量和会话 414

22.4 创建简单会话示例 414

22.5 配置会话控制 416

22.6 使用会话控制实现身份验证 417

22.7 下一章 423

第23章 JavaScript与PHP集成 424

23.1 理解AJAX 424

23.2 jQuery概述 425

23.3 在Web应用中使用jQuery 425

23.4 在PHP中使用jQuery和AJAX 434

23.4.1 支持AJAX的聊天脚本/服务器 434

23.4.2 jQuery AJAX方法 437

23.4.3 聊天客户端/jQuery应用 439

23.5 进一步学习 445

23.6 下一章 445

第24章 PHP的其他有用特性 446

24.1 字符串计算函数:eval() 446

24.2 终止执行:die()和exit() 447

24.3 序列化变量和对象 448

24.4 获取PHP环境信息 448

24.4.1 找到已载入的扩展 449

24.4.2 识别脚本属主 450

24.4.3 获知脚本被修改时间 450

24.5 临时修改运行时环境 450

24.6 高亮源代码 451

24.7 在命令行上使用PHP 452

24.8 下一章 453

第五篇 构建实用的PHP和MySQL项目 456

第25章 在大型项目中使用PHP和MySQL 456

25.1 在Web开发中应用软件工程技术 457

25.2 规划和运营Web应用项目 457

25.3 代码重用 458

25.4 编写可维护代码 458

25.4.1 代码标准 459

25.4.2 代码分解 461

25.4.3 使用标准目录结构 462

25.4.4 文档化和共享内部函数 462

25.5 实现版本控制 462

25.6 选择开发环境 463

25.7 项目文档化 463

25.8 原型定义 464

25.9 隔离逻辑和内容 464

25.10 代码优化 465

25.11 测试 466

25.12 进一步学习 466

25.13 下一章 467

第26章 调试和日志 468

26.1 编程错误 468

26.1.1 语法错误 468

26.1.2 运行时错误 469

26.1.3 逻辑错误 474

26.2 变量调试辅助 475

26.3 错误报告级别 477

26.4 修改错误报告设置 478

26.5 触发自定义错误 479

26.6 错误日志记录 480

26.7 错误日志文件 482

26.8 下一章 483

第27章 构建用户身份验证和个性化 484

27.1 解决方案组件 484

27.1.1 用户识别和个性化 485

27.1.2 保存书签 485

27.1.3 推荐书签 485

27.2 解决方案概述 486

27.3 实现数据库 487

27.4 实现基本网站 488

27.5 实现用户身份验证 491

27.5.1 用户注册 491

27.5.2 登录 496

27.5.3 退出 500

27.5.4 修改密码 501

27.5.5 重设密码 502

27.6 实现书签存储和读取 507

27.6.1 添加书签 507

27.6.2 显示书签 509

27.6.3 删除书签 510

27.7 实现书签推荐 513

27.8 考虑可能的扩展 516

第28章 使用Laravel构建基于Web的电子邮件客户端(第一部分) 517

28.1 Laravel5介绍 517

28.1.1 创建Laravel新项目 517

28.1.2 Laravel应用结构 518

28.1.3 Laravel请求周期与MVC模式 519

28.1.4 理解Laravel模型、视图和控制器类 520

第29章 使用Laravel构建基于Web的电子邮件客户端(第二部分) 536

29.1 使用Laravel构建简单的IMAP客户端 536

29.1.1 PHP IMAP函数 536

29.1.2 为Laravel应用封装IMAP 544

29.2 创建基于Web的电子邮件客户端 561

29.2.1 实现ImapServiceProvider 562

29.2.2 Web客户端认证页面 563

29.2.3 实现主视图 567

29.2.4 实现删除和发送邮件 576

29.3 小结 581

第30章 社交媒体集成分享以及验证 582

30.1 OAuth : Web服务认证 582

30.1.1 认证码授权 583

30.1.2 隐式授权 584

30.1.3 创建instagram Web客户端 585

30.1.4 Instagram的点赞照片功能 593

30.2 小结 594

第31章 构建购物车 595

31.1 解决方案组件 595

31.1.1 构建在线类目 596

31.1.2 记录用户希望购买的商品 596

31.1.3 实现支付系统 596

31.1.4 构建管理界面 597

31.2 解决方案概述 597

31.3 实现数据库 599

31.4 实现在线类目 601

31.4.1 类目列表 603

31.4.2 类目图书清单 605

31.4.3 显示图书详情 607

31.5 实现购物车 608

31.5.1 使用show_cart.php脚本 609

31.5.2 查看购物车 612

31.5.3 向购物车中添加商品 614

31.5.4 保存更新的购物车 615

31.5.5 打印标题栏总结信息 616

31.5.6 结账 617

31.6 实现支付 622

31.7 实现管理界面 624

31.8 扩展项目 631

附录A 安装Apache、PHP和MySQL 632