作者:
LUKE WELLING
出版社: 机械工业出版社
原作名: PHP and MySQL Web Development, 3rd Ed
译者: 武欣 / 邵煜
出版年: 2005-12
页数: 666
定价: 78.00元
装帧: 平装
丛书: 开发人员专业技术丛书
ISBN: 9787111154709
出版社: 机械工业出版社
原作名: PHP and MySQL Web Development, 3rd Ed
译者: 武欣 / 邵煜
出版年: 2005-12
页数: 666
定价: 78.00元
装帧: 平装
丛书: 开发人员专业技术丛书
ISBN: 9787111154709
内容简介 · · · · · ·
本书将PHP开发与MySQL应用相结合,分别对PHP和MySQL做了深入浅出的分析,不仅介绍PHP和MySQL的一般概念,而且对PHP和MySQL的Web应用做了较全面的阐述,并包括几个经典且实用的例子。
PHP和MySQL Web开发的创作者
· · · · · ·
-
LUKE WELLING 作者
作者简介 · · · · · ·
Laura Thomson是澳大利亚墨尔本RMIT大学计算机科学信息技术学院的讲师。她也是Tangled Web Design公司的合伙人。Laura曾经在Telstra和波士顿顾问集团工作过。她获得了应用科学(计算机科学)的学士学位和工程学(计算机系统工程)学士学位,目前她正在攻读适应性Web站点的博士学位。
目录 · · · · · ·
第一篇 使用PHP
第1章 PHP快速入门教程 1
1.1 使用PHP 2
1.2 创建一个示例应用:Bob's Auto Parts(Bob汽车零部件商店)2
1.2.1 创建订单表单 2
1.2.2 表单处理 4
· · · · · · (更多)
第1章 PHP快速入门教程 1
1.1 使用PHP 2
1.2 创建一个示例应用:Bob's Auto Parts(Bob汽车零部件商店)2
1.2.1 创建订单表单 2
1.2.2 表单处理 4
· · · · · · (更多)
第一篇 使用PHP
第1章 PHP快速入门教程 1
1.1 使用PHP 2
1.2 创建一个示例应用:Bob's Auto Parts(Bob汽车零部件商店)2
1.2.1 创建订单表单 2
1.2.2 表单处理 4
1.3 在HTML中嵌入PHP 4
1.3.1 使用PHP标记 5
1.3.2 PHP标记风格 5
1.3.3 PHP语句 6
1.3.4 空格 6
1.3.5 注释 7
1.4 添加动态内容 8
1.4.1 调用函数 8
1.4.2 使用date()函数 9
1.5 访问表单变量 9
1.5.1 表单变量 9
1.5.2 字符串的连接 11
1.5.3 变量和文本 12
1.6 理解标识符 13
1.7 创建用户声明的变量 13
1.8 给变量赋值 13
1.9 检查变量的类型 13
1.9.1 PHP的数据类型 13
1.9.2 类型强度 14
1.9.3 类型转换 14
1.9.4 可变变量 14
1.10 声明和使用常量 15
1.11 理解变量的作用域 16
1.12 使用操作符 16
1.12.1 算术操作符 17
1.12.2 字符串操作符 17
1.12.3 赋值操作符 17
1.12.4 比较操作符 19
1.12.5 逻辑操作符 20
1.12.6 位操作符 21
1.12.7 其他操作符 21
1.13 使用操作符:计算表单总金额 23
1.14 理解操作符的优先级和结合性:表达式求值 24
1.15 使用可变函数 25
1.15.1 测试和设置变量类型 26
1.15.2 测试变量状态 26
1.15.3 变量的重解释 27
1.16 实现控制结构 27
1.17 根据条件进行判断 27
1.17.1 if语句 28
1.17.2 代码块 28
1.17.3 else语句 28
1.17.4 elseif语句 29
1.17.5 switch语句 30
1.17.6 比较不同的条件 31
1.18 通过迭代实现重复动作 32
1.18.1 while循环 33
1.18.2 for和foreach循环 34
1.18.3 do...while循环 35
1.19 从控制结构或脚本中跳出 35
1.20 使用可替换的控制结构语法 36
1.21 使用declare 36
1.22 下一章:保存客户的订单 37
第2章 数据的存储与检索 38
2.1 保存数据以便后期使用 38
2.2 存储和检索Bob的订单 38
2.3 文件处理 39
2.4 打开文件 40
2.4.1 选择文件模式 40
2.4.2 使用fopen()打开文件 40
2.4.3 通过FTP或HTTP打开文件 42
2.4.4 解决打开文件时可能遇到的问题 42
2.5 写文件 44
2.5.1 fwrite()的参数 44
2.5.2 文件格式 45
2.6 关闭文件 45
2.7 读文件 47
2.7.1 以只读模式打开文件:fopen() 48
2.7.2 知道何时读完文件:feof() 48
2.7.3 每次读取一行数据:fgets()、fgetss()和fgetcsv() 49
2.7.4 读取整个文件:readfile()、fpassthru()和file() 49
2.7.5 读取一个字符:fgetc() 50
2.7.6 读取任意长度:fread() 51
2.8 使用其他有用的文件函数 51
2.8.1 查看文件是否存在:file_exists() 51
2.8.2 确定文件大小:filesize() 51
2.8.3 删除一个文件:unlink() 51
2.8.4 在文件中定位:rewind()、fseek()和ftell() 52
2.9 文件锁定 52
2.10 更好的方式:数据库管理系统 53
2.10.1 使用普通文件的几个问题 54
2.10.2 RDBMS是如何解决这些问题的 54
2.11 进一步学习 54
2.12 下一章 55
第3章 使用数组 56
3.1 什么是数组 56
3.2 数字索引数组 57
3.2.1 数字索引数组的初始化 57
3.2.2 访问数组的内容 57
3.2.3 使用循环访问数组 58
3.3 使用不同索引的数组 59
3.3.1 初始化相关数组 59
3.3.2 访问数组元素 59
3.3.3 使用循环语句 59
3.4 数组操作符 60
3.5 多维数组 61
3.6 数组排序 64
3.6.1 使用sort()函数 64
3.6.2 使用asort()函数和ksort()函数对相关数组排序 64
3.6.3 反向排序 65
3.7 多维数组的排序 65
3.7.1 用户定义排序 65
3.7.2 反向用户排序 66
3.8 对数组进行重新排序 67
3.8.1 使用shuffle()函数 67
3.8.2 使用array-reverse()函数 68
3.9 从文件载入数组 69
3.10 执行其他的数组操作 71
3.10.1 在数组中浏览:each()、current()、reset()、end()、next()、pos()和prev() 71
3.10.2 对数组的每一个元素应用任何函数:array_walk() 72
3.10.3 统计数组元素个数:count()、sizeof()和array_count_values(}73
3.10.4 将数组转换成标量变量:extract() 73
3.11 进一步学习 75
3.12 下一章 75
第4章 字符串操作与正则表达式 76
4.1 创建一个示例应用程序:智能表单邮件 76
4.2 字符串的格式化 78
4.2.1 字符串的整理:chop()、ltrim()和trim() 78
4.2.2 格式化字符串以便显示 78
4.2.3 格式化字符串以便存储:addslashes()和stripslashes() 81
4.3 用字符串函数连接和分割字符串 82
4.3.1 使用函数explode()、implode()和join() 82
4.3.2 使用strtok()函数 83
4.3.3 使用substr()函数 83
4.4 字符串的比较 84
4.4.1 字符串的排序:strcmp()、strcasecmp()和strnatcmp() 84
4.4.2 使用strlen()函数测试字符串的长度 85
4.5 使用字符串函数匹配和替换子字符串 85
4.5.1 在字符串中查找字符串:strstr()、strchr()、strrchr()stristr()85
4.5.2 查找子字符串的位置:strpos()、strrpos() 86
4.5.3 替换子字符串:str_replace()、substr_replace() 87
4.6 正则表达式的介绍 88
4.6.1 基础知识 88
4.6.2 字符集和类 88
4.6.3 重复 89
4.6.4 子表达式 89
4.6.5 子表达式计数 90
4.6.6 定位到字符串的开始或末尾 90
4.6.7 分支 90
4.6.8 匹配特殊字符 90
4.6.9 特殊字符一览 91
4.6.10 在智能表单中应用 91
4.7 用正则表达式查找子字符串 92
4.8 用正则表达式替换子字符串 93
4.9 使用正则表达式分割字符串 93
4.10 比较字符串函数和正则表达式函数 93
4.11 进一步学习 93
4.12 下一章 93
第5章 代码重用与函数编写 94
5.1 代码重用 94
5.1.1 成本 94
5.1.2 可靠性 94
5.1.3 一致性 95
5.2 使用require()和include()函数 95
5.2.1 require()函数 95
5.2.2 文件扩展名和require()语句 96
5.2.3 PHP标记和require()语句 96
5.3 使用require()制作Web站点的模版 96
5.3.1 使用include() 100
5.3.2 使用require_once()和include_once() 100
5.3.3 使用auto_prepend_file和auto_append_file 101
5.4 在PHP中使用函数 101
5.4.1 调用函数 101
5.4.2 调用未定义的函数 103
5.4.3 理解字母大小写和函数名称 103
5.5 理解为什么要定义自己的函数 103
5.6 了解基本的函数结构 104
5.7 使用参数 105
5.8 理解作用域 107
5.9 参数的引用传递和值传递 109
5.10 从函数中返回 110
5.11 从函数返回一个值 111
5.12 实现递归 113
5.13 进一步学习 114
5.14 下一章 114
第6章 面向对象的PHP 115
6.1 面向对象的概念 115
6.1.1 类和对象 115
6.1.2 多态性 116
6.1.3 继承 117
6.2 在PHP中创建类、属性和操作 117
6.2.1 类的结构 117
6.2.2 构造函数 118
6.2.3 析构函数 118
6.3 类的实例化 118
6.4 使用类的属性 119
6.5 使用private和public关键字控制访问 121
6.6 类操作的调用 121
6.7 在PHP中实现继承 122
6.7.1 通过继承使用private和protected访问修饰符控制可见性 123
6.7.2 重载 124
6.7.3 使用final关键字禁止继承和重载 125
6.7.4 理解多重继承 126
6.7.5 实现接口 126
6.8 类的设计 127
6.9 编写类代码 128
6.10 理解PHP面向对象新的高级功能 135
6.10.1 提示:PHP4和PHP5的比较 135
6.10.2 使用Per-Class常量 135
6.10.3 实现静态方法 135
6.10.4 检查类的类型和类型提示 136
6.10.5 克隆对象 136
6.10.6 使用抽象类 137
6.10.7 使用__call()重载方法 137
6.10.8 使用__autoload()方法 138
6.10.9 实现迭代器和迭代 138
6.10.10 将类转换成字符串 140
6.10.11 使用Reflection(反射)API 140
6.11 下一章 141
第7章 异常处理 142
7.1 异常处理的概念 142
7.2 Exception类 144
7.3 用户自定义异常 144
7.4 Bob的汽车零部件商店应用程序的异常 146
7.5 异常和PHP的其他错误处理机制 150
7.6 进一步学习 150
7.7 下一章 150
第二篇 使用MySQL
第8章 设计Web数据库 151
8.1 关系数据库的概念 152
8.1.1 表格 152
8.1.2 列 152
8.1.3 行 152
8.1.4 值 152
8.1.5 键 152
8.1.6 模式 153
8.1.7 关系 153
8.2 如何设计Web数据库 154
8.2.1 考虑要建模的实际对象 154
8.2.2 避免保存冗余数据 154
8.2.3 使用原子列值 155
8.2.4 选择有意义的键 156
8.2.5 考虑需要询问数据库的问题 156
8.2.6 避免多个空属性的设计 156
8.2.7 表格类型的总结 157
8.3 Web数据库架构 157
8.4 进一步学习 158
8.5 下一章 158
第9章 创建Web数据库 159
9.1 使用MySQL监视程序 160
9.2 登录到MySQL 160
9.3 创建数据库和用户 161
9.4 设置用户与权限 162
9.5 MySQL权限系统的介绍 162
9.5.1 最少权限原则 162
9.5.2 创建用户:GRANT命令 162
9.5.3 权限的类型和级别 163
9.5.4 REVOKE命令 165
9.5.5 使用GRANT和REVOKE的例子 165
9.6 创建一个Web用户 166
9.7 使用正确的数据库 166
9.8 创建数据库表 167
9.8.1 理解其他关键字的意思 168
9.8.2 理解列的类型 169
9.8.3 用SHOW和DESCRIBE来查看数据库 170
9.8.4 创建索引 171
9.8.5 表格类型的提示 171
9.9 理解MySQL的标识符 171
9.10 选择列数据类型 172
9.10.1 数字类型 173
9.10.2 日期和时间类型 174
9.10.3 字符串类型 174
9.11 进一步学习 176
9.12 下一章 176
第10章 使用MySQL数据库 177
10.1 SQL是什么 177
10.2 在数据库中插入数据 177
10.3 从数据库中获取数据 179
10.3.1 获取满足特定条件的数据 181
10.3.2 从多个表中获取数据 182
10.3.3 以特定的顺序获取数据 186
10.3.4 分组与合计数据 186
10.3.5 选择要返回的行 188
10.3.6 使用子查询 188
10.4 更新数据库记录 190
10.5 创建后修改表 191
10.6 删除数据库中的记录 193
10.7 表的删除 193
10.8 删除整个数据库 193
10.9 进一步学习 194
10.10 下一章 194
第11章 使用PHP从Web访问MySQL数据库 195
11.1 Web数据库架构的工作原理 195
11.2 从Web查询数据库的基本步骤 198
11.3 检查与过滤用户输入数据 198
11.4 建立一个连接 199
11.5 选择使用的数据库 200
11.6 查询数据库 200
11.7 检索查询结果 201
11.8 从数据库断开连接 202
11.9 将新信息放入数据库 202
11.10 使用Prepared语句 205
11.11 使用PHP与数据库交互的其他接口 206
11.12 使用常规的数据库接口:PEAR DB 206
11.13 进一步学习 209
11.14 下一章 209
第12章 MySQL高级管理 210
12.1 深入理解权限系统 210
12.1.1 user表 211
12.1.2 db表和host表 212
12.1.3 tables_priv表和columns_priv表 212
12.1.4 访问控制:MySQL如何使用Grant表 213
12.1.5 更新权限:修改什么时候生效 213
12.2 提高MySQL数据库的安全性 214
12.2.1 从操作系统角度来保护MySQL 214
12.2.2 密码 214
12.2.3 用户权限 215
12.2.4 Web问题 215
12.3 获取更多关于数据库的信息 216
12.3.1 使用SHOW获取信息 216
12.3.2 使用DESCRIBE获取关于列的信息 218
12.3.3 用EXPLAIN理解查询操作的工作过程 218
12.4 使用索引提高查询速度 221
12.5 优化数据库 221
12.5.1 设计优化 222
12.5.2 权限 222
12.5.3 表的优化 222
12.5.4 使用索引 222
12.5.5 使用默认值 222
12.5.6 其他技巧 222
12.6 备份MySQL数据库 222
12.7 恢复MySQL数据库 223
12.8 实现复制 223
12.8.1 设置主服务器 224
12.8.2 执行初始的数据传输 224
12.8.3 设置一个/多个从服务器 225
12.9 进一步学习 225
12.10 下一章 225
第13章 MySQL高级编程 226
13.1 LOAD DATA INFILE语句 226
13.2 存储引擎 226
13.3 事务 227
13.3.1 理解事务的定义 227
13.3.2 通过InnoDB使用事务 228
13.4 外键 229
13.5 存储过程 230
13.5.1 基本示例 230
13.5.2 局部变量 232
13.5.3 游标和控制结构 233
13.6 进一步学习 236
13.7 下一章 236
第三篇 电子商务与安全性
第14章 运营一个电子商务网站 237
14.1 我们要实现什么目标 237
14.2 考虑电子商务网站的类型 237
14.2.1 使用在线说明书公布信息 238
14.2.2 接收产品或服务的订单 240
14.2.3 提供服务和数字产品 243
14.2.4 为产品或服务增值 243
14.2.5 减少成本 243
14.3 理解风险和威胁 244
14.3.1 网络黑客 244
14.3.2 不能招揽足够的生意 245
14.3.3 计算机硬件故障 245
14.3.4 电力、通信、网络或运输故障 245
14.3.5 广泛的竞争 245
14.3.6 软件错误 245
14.3.7 不断变化的政府政策和税收 246
14.3.8 系统容量限制 246
14.4 基于策略作决定 246
14.5 下一章 246
第15章 电子商务的安全问题 247
15.1 信息的重要程度 247
15.2 安全威胁 248
15.2.1 机密数据的泄露 248
15.2.2 数据丢失和数据破坏 249
15.2.3 数据修改 250
15.2.4 拒绝服务 251
15.2.5 软件错误 251
15.2.6 否认 252
15.3 易用性,性能、成本和安全性 253
15.4 建立一个安全政策 253
15.5 身份验证原则 254
15.6 使用身份验证 254
15.7 加密技术基础 255
15.8 私有密钥加密 256
15.9 公有密钥加密 256
15.10 数字签名 256
15.11 数字证书 257
15.12 安全的Web服务器 258
15.13 审计与日志记录 259
15.14 防火墙 259
15.15 备份数据 259
15.15.1 备份常规文件 260
15.15.2 备份与恢复MySQL数据库 260
15.16 自然环境安全 260
15.17 下一章 261
第16章 使用PHP和MySQL实现身份验证 262
16.1 识别访问者 262
16.2 实现访问控制 263
16.2.1 保存密码 265
16.2.2 密码的加密 267
16.2.3 保护多个网页 268
16.3 使用基本身份验证 269
16.4 在PHP中使用基本身份验证 270
16.5 在Apache的.htaccess文件中使用基本身份验证 271
16.6 在IIS上使用基本身份验证 274
16.7 使用mod_auth_mysql身份验证 276
16.7.1 安装mod_auth_mysql 276
16.7.2 检查是否正常工作 276
16.7.3 使用mod_auth_mysql 277
16.8 创建自定义身份验证 277
16.9 进一步学习 278
16.10 下一章 278
第17章 使用PHP和MySQL实现安全事务 279
17.1 提供安全的事务处理 279
17.1.1 用户机器 280
17.1.2 Internet 281
17.1.3 我们的系统 281
17.2 使用加密套接字层(SSL) 282
17.3 屏蔽用户的输入 284
17.4 提供安全存储 284
17.5 确定是否需要存储信用卡号码 285
17.6 在PHP中使用加密技术 286
17.6.1 安装GPG 286
17.6.2 测试GPG 288
17.7 进一步学习 293
17.8 下一章 293
第四篇 PHP的高级技术
第18章 与文件系统和服务器的交互 295
18.1 文件上载 295
18.1.1 文件上载的HTML 296
18.1.2 关于安全性的提示 296
18.1.3 编写处理文件的PHP 297
18.1.4 常见问题 300
18.2 使用目录函数 300
18.2.1 从目录读取 300
18.2.2 获得当前目录的信息 302
18.2.3 创建和删除目录 302
18.3 与文件系统的交互 302
18.3.1 获取文件信息 302
18.3.2 更改文件属性 304
18.3.3 创建、删除和移动文件 305
18.4 使用程序执行函数 305
18.5 与环境变量交互:getenv()和putenv() 308
18.6 进一步学习 308
18.7 下一章 308
第19章 使用网络函数和协议函数 309
19.1 了解可供使用的协议 309
19.2 发送和读取电子邮件 309
19.3 使用其他Web站点 310
19.4 使用网络查找函数 312
19.5 使用FTP 316
19.5.1 使用FTP备份或镜像一个文件 316
19.5.2 上传文件 321
19.5.3 避免超时 321
19.5.4 使用其他的FTP函数 322
19.6 进一步学习 322
19.7 下一章 323
第20章 日期和时间的管理 324
20.1 在PHP中获取日期和时间 324
20.1.1 使用date()函数 324
20.1.2 使用UNIX时间戳 325
20.1.3 使用getdate()函数 326
20.1.4 检验日期有效性 327
20.2 在PHP日期格式和MySQL日期格式之间进行转换 327
20.3 在PHP中计算日期 329
20.4 在MySQL中计算日期 329
20.5 使用微秒 331
20.6 使用日历函数 331
20.7 进一步学习 332
20.8 下一章 332
第21章 创建图像 333
21.1 在PHP中设定图像支持 333
21.2 理解图像格式 334
21.2.1 JPEG 334
21.2.2 PNG 334
21.2.3 WBMP 335
21.2.4 GIF 335
21.3 创建图像 335
21.3.1 创建一个背景图像 336
21.3.2 在图像上绘图或打印文本 337
21.3.3 输出最终图形 338
21.3.4 清理 339
21.4 在其他页面中使用自动生成的图像 339
21.5 使用文本和字体创建图像 339
21.5.1 创建基本画布 342
21.5.2 将文本调整到适合按钮 342
21.5.3 放置文本 345
21.5.4 将文本写到按钮上 345
21.5.5 完成 345
21.6 绘制图像与用图表描绘数据 346
21.7 使用其他的图像函数 352
21.8 进一步学习 352
21.9 下一章 353
第22章 在PHP中使用会话控制 354
22.1 什么是会话控制 354
22.2 理解基本的会话功能 354
22.2.1 什么是cookie 354
22.2.2 通过PHP设置cookie 355
22.2.3 在会话中使用cookie 355
22.2.4 存储会话 ID 356
22.3 实现简单的会话 356
22.3.1 开始一个会话 356
22.3.2 注册一个会话变量 356
22.3.3 使用会话变量 357
22.3.4 注销变量与销毁会话 357
22.4 创建一个简单的会话例子 357
22.5 配置会话控制 359
22.6 通过会话控制实现身份验证 360
22.7 进一步学习 365
22.8 下一章 365
第23章 其他有用的特性 366
23.1 使用魔术引用 366
23.2 使用eval()函数对字符串求值 367
23.3 中断执行:die和exit 367
23.4 序列化变量和对象 368
23.5 获取PHP环境信息 369
23.5.1 找到所加载的PHP扩展部件 369
23.5.2 识别脚本所有者 370
23.5.3 确定脚本最近修改时间 370
23.6 动态加载扩展部件 370
23.7 暂时改变运行时环境 370
23.8 源代码加亮 371
23.9 在命令行中使用PHP 372
23.10 下一章 372
第五篇 创建实用的PHP和MySQL项目
第24章 在大型项目中使用PHP和MySQL 373
24.1 在Web开发中应用软件工程 374
24.2 规划和运行Web应用程序项目 374
24.3 重用代码 375
24.4 编写可维护代码 375
24.4.1 编码标准 375
24.4.2 分解代码 378
24.4.3 使用标准的目录结构 378
24.4.4 文档化和共享内部函数 378
24.5 实现版本控制 379
24.6 选择一个开发环境 380
24.7 项目的文档化 380
24.8 建立原型 381
24.9 将逻辑和内容分离 381
24.10 优化代码 382
24.10.1 使用简单优化 382
24.10.2 使用Zend产品 382
24.11 测试 383
24.12 进一步学习 383
24.13 下一章 384
第25章 调试 385
25.1 编程错误 385
25.1.1 语法错误 385
25.1.2 运行时错误 386
25.1.3 逻辑错误 391
25.2 使用变量帮助调试 392
25.3 错误报告级别 393
25.4 改变错误报告设置 394
25.5 触发自定义错误 395
25.6 巧妙地处理错误 396
25.7 下一章 398
第26章 建立用户身份验证机制和个性化设置 399
26.1 问题所在 399
26.2 解决方案的组成 399
26.2.1 用户识别和个性化设置 399
26.2.2 保存书签 400
26.2.3 推荐书签 400
26.3 解决方案概述 400
26.4 实现数据库 402
26.5 实现基本的网站 403
26.6 实现用户身份验证 405
26.6.1 注册 405
26.6.2 登录 410
26.6.3 登出 413
26.6.4 修改密码 414
26.6.5 重设遗忘的密码 416
26.7 实现书签的存储和检索 420
26.7.1 添加书签 420
26.7.2 显示书签 422
26.7.3 删除书签 422
26.8 实现书签推荐 424
26.9 封装和可能的扩展 427
26.10 下一章 427
第27章 创建一个购物车 428
27.1 问题所在 428
27.2 解决方案的组成 428
27.2.1 创建一个在线目录 428
27.2.2 在用户购买商品的时候记录购买行为 429
27.2.3 实现一个付款系统 429
27.2.4 创建一个管理界面 429
27.3 解决方案概述 429
27.4 实现数据库 432
27.5 实现在线目录 434
27.5.1 列出目录 434
27.5.2 列出一个目录中的所有图书 437
27.5.3 显示图书详细信息 438
27.6 实现购物车 440
27.6.1 使用show_cart.php脚本 440
27.6.2 浏览购物车 442
27.6.3 将物品添加到购物库 444
27.6.4 保存更新后的购物车 446
27.6.5 打印标题栏摘要 447
27.6.6 结账 447
27.7 实现付款 452
27.8 实现一个管理界面 454
27.9 扩展该项目 460
27.10 使用一个已有系统 461
27.11 下一章 461
第28章 创建一个内容管理系统 462
28.1 问题所在 462
28.2 解决方案的需求 462
28.3 已有系统 462
28.4 编辑内容 463
28.4.1 使内容进入系统 463
28.4.2 数据库与文件存储的对比 463
28.4.3 文档结构 464
28.5 使用元数据 464
28.6 格式化输出 465
28.7 解决方案的设计/概述 465
28.8 设计数据库 466
28.9 实现CMS 467
28.9.1 前台 467
28.9.2 图像处理 471
28.9.3 后台 473
28.9.4 搜索 480
28.9.5 编辑页面 483
28.10 扩展该项目 485
28.11 下一章 485
第29章 创建一个基于Web的电子邮件服务系统 486
29.1 问题所在 486
29.2 解决方案的组成 486
29.3 解决方案概述 488
29.4 建立数据库 489
29.5 了解脚本架构 490
29.6 登录与登出 495
29.7 建立账户 498
29.7.1 创建一个新账户 499
29.7.2 修改已有账户 501
29.7.3 删除账户 501
29.8 阅读邮件 502
29.8.1 选择账户 502
29.8.2 查看邮箱内容 504
29.8.3 阅读邮件消息 507
29.8.4 查看消息标题 509
29.8.5 删除邮件 509
29.9 发送邮件 510
29.9.1 发送一则新消息 510
29.9.2 回复或转发邮件 512
29.10 扩展这个项目 514
29.11 下一章 514
第30章 创建一个邮件列表管理器 515
30.1 问题所在 515
30.2 解决方案的组成 515
30.2.1 建立列表和订阅者数据库 516
30.2.2 使用文件上载 516
30.2.3 发送带附件的邮件 516
30.3 解决方案概述 516
30.4 建立数据库 518
30.5 定义脚本架构 520
30.6 实现登录 526
30.6.1 新账户的创建 527
30.6.2 登录 529
30.7 用户函数的实现 531
30.7.1 查看列表 531
30.7.2 查看邮件列表信息 535
30.7.3 查看邮件列表存档 536
30.7.4 订阅与取消订阅 538
30.7.5 更改账户设置 539
30.7.6 更改密码 539
30.7.7 登出 540
30.8 管理功能的实现 541
30.8.1 创建新的邮件列表 541
30.8.2 上载新的新闻信件 543
30.8.3 多文件上载的处理 545
30.8.4 预览新闻信件 549
30.8.5 发送邮件 550
30.9 扩展这个项目 555
30.10 下一章 555
第31章 创建一个Web论坛 556
31.1 问题所在 556
31.2 解决方案的组成 556
31.3 解决方案概述 557
31.4 数据库的设计 558
31.5 查看文章的树型结构 560
31.5.1 展开和折叠 561
31.5.2 显示文章 564
31.5.3 使用treenode类 564
31.6 查看单个的文章 570
31.7 添加新文章 572
31.8 添加扩充 578
31.9 使用一个已有的系统 578
31.10 下一章 578
第32章 生成PDF格式的个性化文档 579
32.1 问题所在 579
32.2 评估文档格式 579
32.2.1 纸张 580
32.2.2 ASCII 580
32.2.3 HTML 580
32.2.4 字处理器格式 580
32.2.5 RTF格式 581
32.2.6 PostScript 581
32.2.7 可移植文档格式(PDF) 582
32.3 解决方案的组成 582
32.3.1 问题与回答系统 583
32.3.2 文档生成软件 583
32.4 解决方案概述 585
32.4.1 提问 585
32.4.2 给答题评分 587
32.4.3 生成RTF证书 589
32.4.4 从模板生成PDF证书 591
32.4.5 使用PDFlib生成PDF文档 595
32.4.6 使用PDFlib的一个“Hello World”程序 595
32.4.7 用PDFlib生成证书 598
32.5 处理标题的问题 605
32.6 扩展该项目 605
32.7 进一步学习 606
32.8 下一章 606
第33章 使用XML和SOAP来连接Web服务 607
33.1 问题所在 607
33.2 理解XML 608
33.3 理解Web服务 611
33.3.1 SOAP 611
33.3.2 WSDL 612
33.4 解决方案的组成 612
33.4.1 创建购物车 613
33.4.2 使用Amazon的Web服务接口 613
33.4.3 XML的解析 613
33.4.4 在PHP中使用SOAP 614
33.4.5 缓存 614
33.5 解决方案概述 614
33.5.1 核心应用程序 618
33.5.2 显示特定种类的图书 623
33.5.3 获得一个AmazonResultSet类 624
33.5.4 使用基于HTTP的REST/XML 631
33.5.5 使用SOAP 635
33.5.6 缓存数据 636
33.5.7 创建购物车 639
33.5.8 到Amazon付账 642
33.6 安装项目代码 642
33.7 扩展这个项目 643
33.8 进一步学习 643
第六篇 附 录
附录A 安装PHP及MySQL 645
附录B Web资源 664
· · · · · · (收起)
第1章 PHP快速入门教程 1
1.1 使用PHP 2
1.2 创建一个示例应用:Bob's Auto Parts(Bob汽车零部件商店)2
1.2.1 创建订单表单 2
1.2.2 表单处理 4
1.3 在HTML中嵌入PHP 4
1.3.1 使用PHP标记 5
1.3.2 PHP标记风格 5
1.3.3 PHP语句 6
1.3.4 空格 6
1.3.5 注释 7
1.4 添加动态内容 8
1.4.1 调用函数 8
1.4.2 使用date()函数 9
1.5 访问表单变量 9
1.5.1 表单变量 9
1.5.2 字符串的连接 11
1.5.3 变量和文本 12
1.6 理解标识符 13
1.7 创建用户声明的变量 13
1.8 给变量赋值 13
1.9 检查变量的类型 13
1.9.1 PHP的数据类型 13
1.9.2 类型强度 14
1.9.3 类型转换 14
1.9.4 可变变量 14
1.10 声明和使用常量 15
1.11 理解变量的作用域 16
1.12 使用操作符 16
1.12.1 算术操作符 17
1.12.2 字符串操作符 17
1.12.3 赋值操作符 17
1.12.4 比较操作符 19
1.12.5 逻辑操作符 20
1.12.6 位操作符 21
1.12.7 其他操作符 21
1.13 使用操作符:计算表单总金额 23
1.14 理解操作符的优先级和结合性:表达式求值 24
1.15 使用可变函数 25
1.15.1 测试和设置变量类型 26
1.15.2 测试变量状态 26
1.15.3 变量的重解释 27
1.16 实现控制结构 27
1.17 根据条件进行判断 27
1.17.1 if语句 28
1.17.2 代码块 28
1.17.3 else语句 28
1.17.4 elseif语句 29
1.17.5 switch语句 30
1.17.6 比较不同的条件 31
1.18 通过迭代实现重复动作 32
1.18.1 while循环 33
1.18.2 for和foreach循环 34
1.18.3 do...while循环 35
1.19 从控制结构或脚本中跳出 35
1.20 使用可替换的控制结构语法 36
1.21 使用declare 36
1.22 下一章:保存客户的订单 37
第2章 数据的存储与检索 38
2.1 保存数据以便后期使用 38
2.2 存储和检索Bob的订单 38
2.3 文件处理 39
2.4 打开文件 40
2.4.1 选择文件模式 40
2.4.2 使用fopen()打开文件 40
2.4.3 通过FTP或HTTP打开文件 42
2.4.4 解决打开文件时可能遇到的问题 42
2.5 写文件 44
2.5.1 fwrite()的参数 44
2.5.2 文件格式 45
2.6 关闭文件 45
2.7 读文件 47
2.7.1 以只读模式打开文件:fopen() 48
2.7.2 知道何时读完文件:feof() 48
2.7.3 每次读取一行数据:fgets()、fgetss()和fgetcsv() 49
2.7.4 读取整个文件:readfile()、fpassthru()和file() 49
2.7.5 读取一个字符:fgetc() 50
2.7.6 读取任意长度:fread() 51
2.8 使用其他有用的文件函数 51
2.8.1 查看文件是否存在:file_exists() 51
2.8.2 确定文件大小:filesize() 51
2.8.3 删除一个文件:unlink() 51
2.8.4 在文件中定位:rewind()、fseek()和ftell() 52
2.9 文件锁定 52
2.10 更好的方式:数据库管理系统 53
2.10.1 使用普通文件的几个问题 54
2.10.2 RDBMS是如何解决这些问题的 54
2.11 进一步学习 54
2.12 下一章 55
第3章 使用数组 56
3.1 什么是数组 56
3.2 数字索引数组 57
3.2.1 数字索引数组的初始化 57
3.2.2 访问数组的内容 57
3.2.3 使用循环访问数组 58
3.3 使用不同索引的数组 59
3.3.1 初始化相关数组 59
3.3.2 访问数组元素 59
3.3.3 使用循环语句 59
3.4 数组操作符 60
3.5 多维数组 61
3.6 数组排序 64
3.6.1 使用sort()函数 64
3.6.2 使用asort()函数和ksort()函数对相关数组排序 64
3.6.3 反向排序 65
3.7 多维数组的排序 65
3.7.1 用户定义排序 65
3.7.2 反向用户排序 66
3.8 对数组进行重新排序 67
3.8.1 使用shuffle()函数 67
3.8.2 使用array-reverse()函数 68
3.9 从文件载入数组 69
3.10 执行其他的数组操作 71
3.10.1 在数组中浏览:each()、current()、reset()、end()、next()、pos()和prev() 71
3.10.2 对数组的每一个元素应用任何函数:array_walk() 72
3.10.3 统计数组元素个数:count()、sizeof()和array_count_values(}73
3.10.4 将数组转换成标量变量:extract() 73
3.11 进一步学习 75
3.12 下一章 75
第4章 字符串操作与正则表达式 76
4.1 创建一个示例应用程序:智能表单邮件 76
4.2 字符串的格式化 78
4.2.1 字符串的整理:chop()、ltrim()和trim() 78
4.2.2 格式化字符串以便显示 78
4.2.3 格式化字符串以便存储:addslashes()和stripslashes() 81
4.3 用字符串函数连接和分割字符串 82
4.3.1 使用函数explode()、implode()和join() 82
4.3.2 使用strtok()函数 83
4.3.3 使用substr()函数 83
4.4 字符串的比较 84
4.4.1 字符串的排序:strcmp()、strcasecmp()和strnatcmp() 84
4.4.2 使用strlen()函数测试字符串的长度 85
4.5 使用字符串函数匹配和替换子字符串 85
4.5.1 在字符串中查找字符串:strstr()、strchr()、strrchr()stristr()85
4.5.2 查找子字符串的位置:strpos()、strrpos() 86
4.5.3 替换子字符串:str_replace()、substr_replace() 87
4.6 正则表达式的介绍 88
4.6.1 基础知识 88
4.6.2 字符集和类 88
4.6.3 重复 89
4.6.4 子表达式 89
4.6.5 子表达式计数 90
4.6.6 定位到字符串的开始或末尾 90
4.6.7 分支 90
4.6.8 匹配特殊字符 90
4.6.9 特殊字符一览 91
4.6.10 在智能表单中应用 91
4.7 用正则表达式查找子字符串 92
4.8 用正则表达式替换子字符串 93
4.9 使用正则表达式分割字符串 93
4.10 比较字符串函数和正则表达式函数 93
4.11 进一步学习 93
4.12 下一章 93
第5章 代码重用与函数编写 94
5.1 代码重用 94
5.1.1 成本 94
5.1.2 可靠性 94
5.1.3 一致性 95
5.2 使用require()和include()函数 95
5.2.1 require()函数 95
5.2.2 文件扩展名和require()语句 96
5.2.3 PHP标记和require()语句 96
5.3 使用require()制作Web站点的模版 96
5.3.1 使用include() 100
5.3.2 使用require_once()和include_once() 100
5.3.3 使用auto_prepend_file和auto_append_file 101
5.4 在PHP中使用函数 101
5.4.1 调用函数 101
5.4.2 调用未定义的函数 103
5.4.3 理解字母大小写和函数名称 103
5.5 理解为什么要定义自己的函数 103
5.6 了解基本的函数结构 104
5.7 使用参数 105
5.8 理解作用域 107
5.9 参数的引用传递和值传递 109
5.10 从函数中返回 110
5.11 从函数返回一个值 111
5.12 实现递归 113
5.13 进一步学习 114
5.14 下一章 114
第6章 面向对象的PHP 115
6.1 面向对象的概念 115
6.1.1 类和对象 115
6.1.2 多态性 116
6.1.3 继承 117
6.2 在PHP中创建类、属性和操作 117
6.2.1 类的结构 117
6.2.2 构造函数 118
6.2.3 析构函数 118
6.3 类的实例化 118
6.4 使用类的属性 119
6.5 使用private和public关键字控制访问 121
6.6 类操作的调用 121
6.7 在PHP中实现继承 122
6.7.1 通过继承使用private和protected访问修饰符控制可见性 123
6.7.2 重载 124
6.7.3 使用final关键字禁止继承和重载 125
6.7.4 理解多重继承 126
6.7.5 实现接口 126
6.8 类的设计 127
6.9 编写类代码 128
6.10 理解PHP面向对象新的高级功能 135
6.10.1 提示:PHP4和PHP5的比较 135
6.10.2 使用Per-Class常量 135
6.10.3 实现静态方法 135
6.10.4 检查类的类型和类型提示 136
6.10.5 克隆对象 136
6.10.6 使用抽象类 137
6.10.7 使用__call()重载方法 137
6.10.8 使用__autoload()方法 138
6.10.9 实现迭代器和迭代 138
6.10.10 将类转换成字符串 140
6.10.11 使用Reflection(反射)API 140
6.11 下一章 141
第7章 异常处理 142
7.1 异常处理的概念 142
7.2 Exception类 144
7.3 用户自定义异常 144
7.4 Bob的汽车零部件商店应用程序的异常 146
7.5 异常和PHP的其他错误处理机制 150
7.6 进一步学习 150
7.7 下一章 150
第二篇 使用MySQL
第8章 设计Web数据库 151
8.1 关系数据库的概念 152
8.1.1 表格 152
8.1.2 列 152
8.1.3 行 152
8.1.4 值 152
8.1.5 键 152
8.1.6 模式 153
8.1.7 关系 153
8.2 如何设计Web数据库 154
8.2.1 考虑要建模的实际对象 154
8.2.2 避免保存冗余数据 154
8.2.3 使用原子列值 155
8.2.4 选择有意义的键 156
8.2.5 考虑需要询问数据库的问题 156
8.2.6 避免多个空属性的设计 156
8.2.7 表格类型的总结 157
8.3 Web数据库架构 157
8.4 进一步学习 158
8.5 下一章 158
第9章 创建Web数据库 159
9.1 使用MySQL监视程序 160
9.2 登录到MySQL 160
9.3 创建数据库和用户 161
9.4 设置用户与权限 162
9.5 MySQL权限系统的介绍 162
9.5.1 最少权限原则 162
9.5.2 创建用户:GRANT命令 162
9.5.3 权限的类型和级别 163
9.5.4 REVOKE命令 165
9.5.5 使用GRANT和REVOKE的例子 165
9.6 创建一个Web用户 166
9.7 使用正确的数据库 166
9.8 创建数据库表 167
9.8.1 理解其他关键字的意思 168
9.8.2 理解列的类型 169
9.8.3 用SHOW和DESCRIBE来查看数据库 170
9.8.4 创建索引 171
9.8.5 表格类型的提示 171
9.9 理解MySQL的标识符 171
9.10 选择列数据类型 172
9.10.1 数字类型 173
9.10.2 日期和时间类型 174
9.10.3 字符串类型 174
9.11 进一步学习 176
9.12 下一章 176
第10章 使用MySQL数据库 177
10.1 SQL是什么 177
10.2 在数据库中插入数据 177
10.3 从数据库中获取数据 179
10.3.1 获取满足特定条件的数据 181
10.3.2 从多个表中获取数据 182
10.3.3 以特定的顺序获取数据 186
10.3.4 分组与合计数据 186
10.3.5 选择要返回的行 188
10.3.6 使用子查询 188
10.4 更新数据库记录 190
10.5 创建后修改表 191
10.6 删除数据库中的记录 193
10.7 表的删除 193
10.8 删除整个数据库 193
10.9 进一步学习 194
10.10 下一章 194
第11章 使用PHP从Web访问MySQL数据库 195
11.1 Web数据库架构的工作原理 195
11.2 从Web查询数据库的基本步骤 198
11.3 检查与过滤用户输入数据 198
11.4 建立一个连接 199
11.5 选择使用的数据库 200
11.6 查询数据库 200
11.7 检索查询结果 201
11.8 从数据库断开连接 202
11.9 将新信息放入数据库 202
11.10 使用Prepared语句 205
11.11 使用PHP与数据库交互的其他接口 206
11.12 使用常规的数据库接口:PEAR DB 206
11.13 进一步学习 209
11.14 下一章 209
第12章 MySQL高级管理 210
12.1 深入理解权限系统 210
12.1.1 user表 211
12.1.2 db表和host表 212
12.1.3 tables_priv表和columns_priv表 212
12.1.4 访问控制:MySQL如何使用Grant表 213
12.1.5 更新权限:修改什么时候生效 213
12.2 提高MySQL数据库的安全性 214
12.2.1 从操作系统角度来保护MySQL 214
12.2.2 密码 214
12.2.3 用户权限 215
12.2.4 Web问题 215
12.3 获取更多关于数据库的信息 216
12.3.1 使用SHOW获取信息 216
12.3.2 使用DESCRIBE获取关于列的信息 218
12.3.3 用EXPLAIN理解查询操作的工作过程 218
12.4 使用索引提高查询速度 221
12.5 优化数据库 221
12.5.1 设计优化 222
12.5.2 权限 222
12.5.3 表的优化 222
12.5.4 使用索引 222
12.5.5 使用默认值 222
12.5.6 其他技巧 222
12.6 备份MySQL数据库 222
12.7 恢复MySQL数据库 223
12.8 实现复制 223
12.8.1 设置主服务器 224
12.8.2 执行初始的数据传输 224
12.8.3 设置一个/多个从服务器 225
12.9 进一步学习 225
12.10 下一章 225
第13章 MySQL高级编程 226
13.1 LOAD DATA INFILE语句 226
13.2 存储引擎 226
13.3 事务 227
13.3.1 理解事务的定义 227
13.3.2 通过InnoDB使用事务 228
13.4 外键 229
13.5 存储过程 230
13.5.1 基本示例 230
13.5.2 局部变量 232
13.5.3 游标和控制结构 233
13.6 进一步学习 236
13.7 下一章 236
第三篇 电子商务与安全性
第14章 运营一个电子商务网站 237
14.1 我们要实现什么目标 237
14.2 考虑电子商务网站的类型 237
14.2.1 使用在线说明书公布信息 238
14.2.2 接收产品或服务的订单 240
14.2.3 提供服务和数字产品 243
14.2.4 为产品或服务增值 243
14.2.5 减少成本 243
14.3 理解风险和威胁 244
14.3.1 网络黑客 244
14.3.2 不能招揽足够的生意 245
14.3.3 计算机硬件故障 245
14.3.4 电力、通信、网络或运输故障 245
14.3.5 广泛的竞争 245
14.3.6 软件错误 245
14.3.7 不断变化的政府政策和税收 246
14.3.8 系统容量限制 246
14.4 基于策略作决定 246
14.5 下一章 246
第15章 电子商务的安全问题 247
15.1 信息的重要程度 247
15.2 安全威胁 248
15.2.1 机密数据的泄露 248
15.2.2 数据丢失和数据破坏 249
15.2.3 数据修改 250
15.2.4 拒绝服务 251
15.2.5 软件错误 251
15.2.6 否认 252
15.3 易用性,性能、成本和安全性 253
15.4 建立一个安全政策 253
15.5 身份验证原则 254
15.6 使用身份验证 254
15.7 加密技术基础 255
15.8 私有密钥加密 256
15.9 公有密钥加密 256
15.10 数字签名 256
15.11 数字证书 257
15.12 安全的Web服务器 258
15.13 审计与日志记录 259
15.14 防火墙 259
15.15 备份数据 259
15.15.1 备份常规文件 260
15.15.2 备份与恢复MySQL数据库 260
15.16 自然环境安全 260
15.17 下一章 261
第16章 使用PHP和MySQL实现身份验证 262
16.1 识别访问者 262
16.2 实现访问控制 263
16.2.1 保存密码 265
16.2.2 密码的加密 267
16.2.3 保护多个网页 268
16.3 使用基本身份验证 269
16.4 在PHP中使用基本身份验证 270
16.5 在Apache的.htaccess文件中使用基本身份验证 271
16.6 在IIS上使用基本身份验证 274
16.7 使用mod_auth_mysql身份验证 276
16.7.1 安装mod_auth_mysql 276
16.7.2 检查是否正常工作 276
16.7.3 使用mod_auth_mysql 277
16.8 创建自定义身份验证 277
16.9 进一步学习 278
16.10 下一章 278
第17章 使用PHP和MySQL实现安全事务 279
17.1 提供安全的事务处理 279
17.1.1 用户机器 280
17.1.2 Internet 281
17.1.3 我们的系统 281
17.2 使用加密套接字层(SSL) 282
17.3 屏蔽用户的输入 284
17.4 提供安全存储 284
17.5 确定是否需要存储信用卡号码 285
17.6 在PHP中使用加密技术 286
17.6.1 安装GPG 286
17.6.2 测试GPG 288
17.7 进一步学习 293
17.8 下一章 293
第四篇 PHP的高级技术
第18章 与文件系统和服务器的交互 295
18.1 文件上载 295
18.1.1 文件上载的HTML 296
18.1.2 关于安全性的提示 296
18.1.3 编写处理文件的PHP 297
18.1.4 常见问题 300
18.2 使用目录函数 300
18.2.1 从目录读取 300
18.2.2 获得当前目录的信息 302
18.2.3 创建和删除目录 302
18.3 与文件系统的交互 302
18.3.1 获取文件信息 302
18.3.2 更改文件属性 304
18.3.3 创建、删除和移动文件 305
18.4 使用程序执行函数 305
18.5 与环境变量交互:getenv()和putenv() 308
18.6 进一步学习 308
18.7 下一章 308
第19章 使用网络函数和协议函数 309
19.1 了解可供使用的协议 309
19.2 发送和读取电子邮件 309
19.3 使用其他Web站点 310
19.4 使用网络查找函数 312
19.5 使用FTP 316
19.5.1 使用FTP备份或镜像一个文件 316
19.5.2 上传文件 321
19.5.3 避免超时 321
19.5.4 使用其他的FTP函数 322
19.6 进一步学习 322
19.7 下一章 323
第20章 日期和时间的管理 324
20.1 在PHP中获取日期和时间 324
20.1.1 使用date()函数 324
20.1.2 使用UNIX时间戳 325
20.1.3 使用getdate()函数 326
20.1.4 检验日期有效性 327
20.2 在PHP日期格式和MySQL日期格式之间进行转换 327
20.3 在PHP中计算日期 329
20.4 在MySQL中计算日期 329
20.5 使用微秒 331
20.6 使用日历函数 331
20.7 进一步学习 332
20.8 下一章 332
第21章 创建图像 333
21.1 在PHP中设定图像支持 333
21.2 理解图像格式 334
21.2.1 JPEG 334
21.2.2 PNG 334
21.2.3 WBMP 335
21.2.4 GIF 335
21.3 创建图像 335
21.3.1 创建一个背景图像 336
21.3.2 在图像上绘图或打印文本 337
21.3.3 输出最终图形 338
21.3.4 清理 339
21.4 在其他页面中使用自动生成的图像 339
21.5 使用文本和字体创建图像 339
21.5.1 创建基本画布 342
21.5.2 将文本调整到适合按钮 342
21.5.3 放置文本 345
21.5.4 将文本写到按钮上 345
21.5.5 完成 345
21.6 绘制图像与用图表描绘数据 346
21.7 使用其他的图像函数 352
21.8 进一步学习 352
21.9 下一章 353
第22章 在PHP中使用会话控制 354
22.1 什么是会话控制 354
22.2 理解基本的会话功能 354
22.2.1 什么是cookie 354
22.2.2 通过PHP设置cookie 355
22.2.3 在会话中使用cookie 355
22.2.4 存储会话 ID 356
22.3 实现简单的会话 356
22.3.1 开始一个会话 356
22.3.2 注册一个会话变量 356
22.3.3 使用会话变量 357
22.3.4 注销变量与销毁会话 357
22.4 创建一个简单的会话例子 357
22.5 配置会话控制 359
22.6 通过会话控制实现身份验证 360
22.7 进一步学习 365
22.8 下一章 365
第23章 其他有用的特性 366
23.1 使用魔术引用 366
23.2 使用eval()函数对字符串求值 367
23.3 中断执行:die和exit 367
23.4 序列化变量和对象 368
23.5 获取PHP环境信息 369
23.5.1 找到所加载的PHP扩展部件 369
23.5.2 识别脚本所有者 370
23.5.3 确定脚本最近修改时间 370
23.6 动态加载扩展部件 370
23.7 暂时改变运行时环境 370
23.8 源代码加亮 371
23.9 在命令行中使用PHP 372
23.10 下一章 372
第五篇 创建实用的PHP和MySQL项目
第24章 在大型项目中使用PHP和MySQL 373
24.1 在Web开发中应用软件工程 374
24.2 规划和运行Web应用程序项目 374
24.3 重用代码 375
24.4 编写可维护代码 375
24.4.1 编码标准 375
24.4.2 分解代码 378
24.4.3 使用标准的目录结构 378
24.4.4 文档化和共享内部函数 378
24.5 实现版本控制 379
24.6 选择一个开发环境 380
24.7 项目的文档化 380
24.8 建立原型 381
24.9 将逻辑和内容分离 381
24.10 优化代码 382
24.10.1 使用简单优化 382
24.10.2 使用Zend产品 382
24.11 测试 383
24.12 进一步学习 383
24.13 下一章 384
第25章 调试 385
25.1 编程错误 385
25.1.1 语法错误 385
25.1.2 运行时错误 386
25.1.3 逻辑错误 391
25.2 使用变量帮助调试 392
25.3 错误报告级别 393
25.4 改变错误报告设置 394
25.5 触发自定义错误 395
25.6 巧妙地处理错误 396
25.7 下一章 398
第26章 建立用户身份验证机制和个性化设置 399
26.1 问题所在 399
26.2 解决方案的组成 399
26.2.1 用户识别和个性化设置 399
26.2.2 保存书签 400
26.2.3 推荐书签 400
26.3 解决方案概述 400
26.4 实现数据库 402
26.5 实现基本的网站 403
26.6 实现用户身份验证 405
26.6.1 注册 405
26.6.2 登录 410
26.6.3 登出 413
26.6.4 修改密码 414
26.6.5 重设遗忘的密码 416
26.7 实现书签的存储和检索 420
26.7.1 添加书签 420
26.7.2 显示书签 422
26.7.3 删除书签 422
26.8 实现书签推荐 424
26.9 封装和可能的扩展 427
26.10 下一章 427
第27章 创建一个购物车 428
27.1 问题所在 428
27.2 解决方案的组成 428
27.2.1 创建一个在线目录 428
27.2.2 在用户购买商品的时候记录购买行为 429
27.2.3 实现一个付款系统 429
27.2.4 创建一个管理界面 429
27.3 解决方案概述 429
27.4 实现数据库 432
27.5 实现在线目录 434
27.5.1 列出目录 434
27.5.2 列出一个目录中的所有图书 437
27.5.3 显示图书详细信息 438
27.6 实现购物车 440
27.6.1 使用show_cart.php脚本 440
27.6.2 浏览购物车 442
27.6.3 将物品添加到购物库 444
27.6.4 保存更新后的购物车 446
27.6.5 打印标题栏摘要 447
27.6.6 结账 447
27.7 实现付款 452
27.8 实现一个管理界面 454
27.9 扩展该项目 460
27.10 使用一个已有系统 461
27.11 下一章 461
第28章 创建一个内容管理系统 462
28.1 问题所在 462
28.2 解决方案的需求 462
28.3 已有系统 462
28.4 编辑内容 463
28.4.1 使内容进入系统 463
28.4.2 数据库与文件存储的对比 463
28.4.3 文档结构 464
28.5 使用元数据 464
28.6 格式化输出 465
28.7 解决方案的设计/概述 465
28.8 设计数据库 466
28.9 实现CMS 467
28.9.1 前台 467
28.9.2 图像处理 471
28.9.3 后台 473
28.9.4 搜索 480
28.9.5 编辑页面 483
28.10 扩展该项目 485
28.11 下一章 485
第29章 创建一个基于Web的电子邮件服务系统 486
29.1 问题所在 486
29.2 解决方案的组成 486
29.3 解决方案概述 488
29.4 建立数据库 489
29.5 了解脚本架构 490
29.6 登录与登出 495
29.7 建立账户 498
29.7.1 创建一个新账户 499
29.7.2 修改已有账户 501
29.7.3 删除账户 501
29.8 阅读邮件 502
29.8.1 选择账户 502
29.8.2 查看邮箱内容 504
29.8.3 阅读邮件消息 507
29.8.4 查看消息标题 509
29.8.5 删除邮件 509
29.9 发送邮件 510
29.9.1 发送一则新消息 510
29.9.2 回复或转发邮件 512
29.10 扩展这个项目 514
29.11 下一章 514
第30章 创建一个邮件列表管理器 515
30.1 问题所在 515
30.2 解决方案的组成 515
30.2.1 建立列表和订阅者数据库 516
30.2.2 使用文件上载 516
30.2.3 发送带附件的邮件 516
30.3 解决方案概述 516
30.4 建立数据库 518
30.5 定义脚本架构 520
30.6 实现登录 526
30.6.1 新账户的创建 527
30.6.2 登录 529
30.7 用户函数的实现 531
30.7.1 查看列表 531
30.7.2 查看邮件列表信息 535
30.7.3 查看邮件列表存档 536
30.7.4 订阅与取消订阅 538
30.7.5 更改账户设置 539
30.7.6 更改密码 539
30.7.7 登出 540
30.8 管理功能的实现 541
30.8.1 创建新的邮件列表 541
30.8.2 上载新的新闻信件 543
30.8.3 多文件上载的处理 545
30.8.4 预览新闻信件 549
30.8.5 发送邮件 550
30.9 扩展这个项目 555
30.10 下一章 555
第31章 创建一个Web论坛 556
31.1 问题所在 556
31.2 解决方案的组成 556
31.3 解决方案概述 557
31.4 数据库的设计 558
31.5 查看文章的树型结构 560
31.5.1 展开和折叠 561
31.5.2 显示文章 564
31.5.3 使用treenode类 564
31.6 查看单个的文章 570
31.7 添加新文章 572
31.8 添加扩充 578
31.9 使用一个已有的系统 578
31.10 下一章 578
第32章 生成PDF格式的个性化文档 579
32.1 问题所在 579
32.2 评估文档格式 579
32.2.1 纸张 580
32.2.2 ASCII 580
32.2.3 HTML 580
32.2.4 字处理器格式 580
32.2.5 RTF格式 581
32.2.6 PostScript 581
32.2.7 可移植文档格式(PDF) 582
32.3 解决方案的组成 582
32.3.1 问题与回答系统 583
32.3.2 文档生成软件 583
32.4 解决方案概述 585
32.4.1 提问 585
32.4.2 给答题评分 587
32.4.3 生成RTF证书 589
32.4.4 从模板生成PDF证书 591
32.4.5 使用PDFlib生成PDF文档 595
32.4.6 使用PDFlib的一个“Hello World”程序 595
32.4.7 用PDFlib生成证书 598
32.5 处理标题的问题 605
32.6 扩展该项目 605
32.7 进一步学习 606
32.8 下一章 606
第33章 使用XML和SOAP来连接Web服务 607
33.1 问题所在 607
33.2 理解XML 608
33.3 理解Web服务 611
33.3.1 SOAP 611
33.3.2 WSDL 612
33.4 解决方案的组成 612
33.4.1 创建购物车 613
33.4.2 使用Amazon的Web服务接口 613
33.4.3 XML的解析 613
33.4.4 在PHP中使用SOAP 614
33.4.5 缓存 614
33.5 解决方案概述 614
33.5.1 核心应用程序 618
33.5.2 显示特定种类的图书 623
33.5.3 获得一个AmazonResultSet类 624
33.5.4 使用基于HTTP的REST/XML 631
33.5.5 使用SOAP 635
33.5.6 缓存数据 636
33.5.7 创建购物车 639
33.5.8 到Amazon付账 642
33.6 安装项目代码 642
33.7 扩展这个项目 643
33.8 进一步学习 643
第六篇 附 录
附录A 安装PHP及MySQL 645
附录B Web资源 664
· · · · · · (收起)
丛书信息
· · · · · ·
开发人员专业技术丛书(共28册),
这套丛书还有
《OpenGL编程指南(原书第7版)》《Mashup模式》《SQL编程基础》《软件项目管理与敏捷方法》《PHP应用程序安全编程》
等
。
喜欢读"PHP和MySQL Web开发"的人也喜欢的电子书 · · · · · ·
支持 Web、iPhone、iPad、Android 阅读器
喜欢读"PHP和MySQL Web开发"的人也喜欢 · · · · · ·
PHP和MySQL Web开发的书评 · · · · · · ( 全部 41 条 )
> 更多书评 41篇
论坛 · · · · · ·
创业公司招技术合伙人! | 来自沐十三 | 2017-10-11 11:23:42 | |
招募PHP开发了。。 | 来自小雨滴 | 2012-02-15 11:23:52 | |
很适合入门的书籍 | 来自blueeon | 2010-11-05 11:03:50 | |
入门适合,提升就不太行了 | 来自alljill | 2010-06-17 19:28:47 | |
Very Good!!! | 来自geekgao | 2010-03-19 21:21:54 |
> 浏览更多话题
这本书的其他版本 · · · · · · ( 全部8 )
-
机械工业出版社 (2009)8.4分 826人读过
-
Sams (July 25, 2007)8.8分 29人读过
-
机械工业出版社 (2018)6.8分 14人读过
-
Sams (2004)暂无评分 13人读过
在哪儿借这本书 · · · · · ·
以下书单推荐 · · · · · · ( 全部 )
- 交互设计师养成书单 (LimboMinaïss)
- 读书 (wolfman)
- 我的豆列 (XIN)
- 也得懂一点点编程... (锟斤拷)
- WEB开发 (匿名)
谁读这本书? · · · · · ·
二手市场
· · · · · ·
订阅关于PHP和MySQL Web开发的评论:
feed: rss 2.0
0 有用 Keeper 2008-03-16 21:49:10
思想性的东西较少,就是入门级的手册
0 有用 夸父 2008-06-14 14:09:40
其实有英文电子版的,英语好的同学可省下这笔钱了
4 有用 AlphaDiao 2012-01-11 11:12:09
据说是PHP圣经。据说作者是最强的PHP程序员。据说翻译太烂。很不幸最后一条是看完中文版才听说的。英文版的再看一遍吧。
0 有用 肆水流年 2008-10-05 23:38:59
不错的PHP入门书籍!我发现我看这种东西越来越快了,难道是传说中的触类旁通么?
0 有用 sevear 2006-06-01 11:37:15
是php的非常好的入门书
0 有用 y的小公举 2018-07-13 20:19:04
本书有比较丰富的实例,而且是互联网上常见的场景,对开发人员学习非常有帮助,我以为一本PHP手册可以供查询使用,真正的学习是需要一个真实项目的环境,投入到项目中才能快速掌握,本书提供的正式这样一个604474355环境
0 有用 王鑫 2015-12-18 10:35:44
入门圣经
1 有用 太阳 2014-10-01 22:08:24
谁说他讲得清楚了,例子都没有……圣经级别的都应该要很多例子来讲解
0 有用 迷失の罗瑞恩 2014-07-05 20:33:28
深入浅出 nice啊
0 有用 吃不下筷子咽不下碗 2014-01-03 11:24:16
前半部分像php函数速查手册,适合小有php基础之后速读一遍以开眼界,也便于以后速查。后半部分的所谓实用程序基本就是学生课堂作业的水平