图书介绍

PHP和MySQL Web开发 第3版pdf电子书版本下载

PHP和MySQL Web开发  第3版
  • (澳)Luke Welling,(澳)Laura Thomson著;武欣,邵煜等译 著
  • 出版社: 北京:机械工业出版社
  • ISBN:7111154703
  • 出版时间:2005
  • 标注页数:666页
  • 文件大小:56MB
  • 文件页数:692页
  • 主题词:PHP语言-程序设计;关系数据库-数据库管理系统,MySQL

PDF下载


点此进入-本书在线PDF格式电子书下载【推荐-云解压-方便快捷】直接下载PDF格式图书。移动端-PC端通用
下载压缩包 [复制下载地址] 温馨提示:(请使用BT下载软件FDM进行下载)软件下载地址页

下载说明

PHP和MySQL Web开发 第3版PDF格式电子书版下载

下载的文件为RAR压缩包。需要使用解压软件进行解压得到PDF格式图书。

建议使用BT下载工具Free Download Manager进行下载,简称FDM(免费,没有广告,支持多平台)。本站资源全部打包为BT种子。所以需要使用专业的BT下载软件进行下载。如 BitComet qBittorrent uTorrent等BT下载工具。迅雷目前由于本站不是热门资源。不推荐使用!后期资源热门了。安装了迅雷也可以迅雷进行下载!

(文件页数 要大于 标注页数,上中下等多册电子书除外)

注意:本站所有压缩包均有解压码: 点击下载压缩包解压工具

图书目录

目录读者反馈译者序前言作者简介第一篇 使用PHP第1章 PHP快速入门教程 1

1.2.1 创建订单表单 2

1.2 创建一个示例应用:Bob's Auto Parts(Bob汽车零部件商店) 2

1.1 使用PHP 2

1.3 在HTML中嵌入PHP 4

1.2.2 表单处理 4

1.3.2 PHP标记风格 5

1.3.1 使用PHP标记 5

1.3.4 空格 6

1.3.3 PHP语句 6

1.3.5 注释 7

1.4.1 调用函数 8

1.4 添加动态内容 8

1.5.1 表单变量 9

1.5 访问表单变量 9

1.4.2 使用date()函数 9

1.5.2 字符串的连接 11

1.5.3 变量和文本 12

1.9.1 PHP的数据类型 13

1.9 检查变量的类型 13

1.6 理解标识符 13

1.7 创建用户声明的变量 13

1.8 给变量赋值 13

1.9.4 可变变量 14

1.9.3 类型转换 14

1.9.2 类型强度 14

1.10 声明和使用常量 15

1.12 使用操作符 16

1.11 理解变量的作用域 16

1.12.3 赋值操作符 17

1.12.2 字符串操作符 17

1.12.1 算术操作符 17

1.12.4 比较操作符 19

1.12.5 逻辑操作符 20

1.12.7 其他操作符 21

1.12.6 位操作符 21

1.13 使用操作符:计算表单总金额 23

1.14 理解操作符的优先级和结合性:表达式求值 24

1.15 使用可变函数 25

1.15.2 测试变量状态 26

1.15.1 测试和设置变量类型 26

1.17 根据条件进行判断 27

1.16 实现控制结构 27

1.15.3 变量的重解释 27

1.17.3 else语句 28

1.17.2 代码块 28

1.17.1 if语句 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.19 从控制结构或脚本中跳出 35

1.18.3 do...while循环 35

1.21 使用declare 36

1.20 使用可替换的控制结构语法 36

1.22 下一章:保存客户的订单 37

2.2 存储和检索Bob的订单 38

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

第2章 数据的存储与检索 38

2.3 文件处理 39

2.4.2 使用fopen()打开文件 40

2.4.1 选择文件模式 40

2.4 打开文件 40

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

2.4.3 通过FTP或HTTP打开文件 42

2.5.1 fwrite()的参数 44

2.5 写文件 44

2.6 关闭文件 45

2.5.2 文件格式 45

2.7 读文件 47

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

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

2.7.4 读取整个文件:readfile()、fpassthru()和file() 49

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

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

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

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

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

2.8 使用其他有用的文件函数 51

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

2.9 文件锁定 52

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

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

2.11 进一步学习 54

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

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

2.12 下一章 55

3.1 什么是数组 56

第3章 使用数组 56

3.2.2 访问数组的内容 57

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

3.2 数字索引数组 57

3.2.3 使用循环访问数组 58

3.3.3 使用循环语句 59

3.3.2 访问数组元素 59

3.3 使用不同索引的数组 59

3.3.1 初始化相关数组 59

3.4 数组操作符 60

3.5 多维数组 61

3.6.2 使用asort()函数和ksort()函数对相关数组排序 64

3.6.1 使用sort()函数 64

3.6 数组排序 64

3.7.1 用户定义排序 65

3.7 多维数组的排序 65

3.6.3 反向排序 65

3.7.2 反向用户排序 66

3.8.1 使用shuffle()函数 67

3.8 对数组进行重新排序 67

3.8.2 使用array-reverse()函数 68

3.9 从文件载入数组 69

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

3.10 执行其他的数组操作 71

3.10.2 对数组的每一个元素应用任何函数:array_walk() 72

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

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

3.12 下一章 75

3.11 进一步学习 75

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

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

4.2.2 格式化字符串以便显示 78

4.2.1 字符串的整理:chop()、ltrim()和trim() 78

4.2 字符串的格式化 78

4.2.3 格式化字符串以便存储:addslashes()和stripslashes() 81

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

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

4.3.3 使用substr()函数 83

4.3.2 使用strtok()函数 83

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

4.4 字符串的比较 84

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

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

4.4.2 使用strlen()函数测试字符串的长度 85

4.5.2 查找子字符串的位置:strpos()、strrpos() 86

4.5.3 替换子字符串:str_replace()、substr_replace() 87

4.6.2 字符集和类 88

4.6.1 基础知识 88

4.6 正则表达式的介绍 88

4.6.4 子表达式 89

4.6.3 重复 89

4.6.8 匹配特殊字符 90

4.6.7 分支 90

4.6.5 子表达式计数 90

4.6.6 定位到字符串的开始或末尾 90

4.6.10 在智能表单中应用 91

4.6.9 特殊字符一览 91

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

4.12 下一章 93

4.11 进一步学习 93

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

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

4.10 比较字符串函数和正则表达式函数 93

5.1.2 可靠性 94

5.1.1 成本 94

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

5.1 代码重用 94

5.2.1 require()函数 95

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

5.1.3 一致性 95

5.3 使用require()制作Web站点的模版 96

5.2.3 PHP标记和require()语句 96

5.2.2 文件扩展名和require()语句 96

5.3.2 使用require_once()和include_once() 100

5.3.1 使用include() 100

5.4.1 调用函数 101

5.4 在PHP中使用函数 101

5.3.3 使用auto_prepend_file和auto_append_file 101

5.5 理解为什么要定义自己的函数 103

5.4.3 理解字母大小写和函数名称 103

5.4.2 调用未定义的函数 103

5.6 了解基本的函数结构 104

5.7 使用参数 105

5.8 理解作用域 107

5.9 参数的引用传递和值传递 109

5.10 从函数中返回 110

5.11 从函数返回一个值 111

5.12 实现递归 113

5.14 下一章 114

5.13 进一步学习 114

6.1.1 类和对象 115

6.1 面向对象的概念 115

第6章 面向对象的PHP 115

6.1.2 多态性 116

6.2.1 类的结构 117

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

6.1.3 继承 117

6.3 类的实例化 118

6.2.3 析构函数 118

6.2.2 构造函数 118

6.4 使用类的属性 119

6.6 类操作的调用 121

6.5 使用private和public关键字控制访问 121

6.7 在PHP中实现继承 122

6.7.1 通过继承使用private和protected访问修饰符控制可见性 123

6.7.2 重载 124

6.7.3 使用final关键字禁止继承和重载 125

6.7.5 实现接口 126

6.7.4 理解多重继承 126

6.8 类的设计 127

6.9 编写类代码 128

6.10.3 实现静态方法 135

6.10.2 使用Per-Class常量 135

6.10 理解PHP面向对象新的高级功能 135

6.10.1 提示:PHP4和PHP5的比较 135

6.10.5 克隆对象 136

6.10.4 检查类的类型和类型提示 136

6.10.7 使用__call()重载方法 137

6.10.6 使用抽象类 137

6.10.9 实现迭代器和迭代 138

6.10.8 使用__autoload()方法 138

6.10.11 使用Reflection(反射)API 140

6.10.10 将类转换成字符串 140

6.11 下一章 141

7.1 异常处理的概念 142

第7章 异常处理 142

7.3 用户自定义异常 144

7.2 Exception类 144

7.4 Bob的汽车零部件商店应用程序的异常 146

7.7 下一章 150

7.6 进一步学习 150

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

第二篇 使用MySQL第8章 设计Web数据库 151

8.1.5 键 152

8.1.4 值 152

8.1 关系数据库的概念 152

8.1.1 表格 152

8.1.2 列 152

8.1.3 行 152

8.1.7 关系 153

8.1.6 模式 153

8.2.2 避免保存冗余数据 154

8.2.1 考虑要建模的实际对象 154

8.2 如何设计Web数据库 154

8.2.3 使用原子列值 155

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

8.2.5 考虑需要询问数据库的问题 156

8.2.4 选择有意义的键 156

8.3 Web数据库架构 157

8.2.7 表格类型的总结 157

8.5 下一章 158

8.4 进一步学习 158

第9章 创建Web数据库 159

9.2 登录到MySQL 160

9.1 使用MySQL监视程序 160

9.3 创建数据库和用户 161

9.5.2 创建用户:GRANT命令 162

9.5.1 最少权限原则 162

9.4 设置用户与权限 162

9.5 MySQL权限系统的介绍 162

9.5.3 权限的类型和级别 163

9.5.5 使用GRANT和REVOKE的例子 165

9.5.4 REVOKE命令 165

9.7 使用正确的数据库 166

9.6 创建一个Web用户 166

9.8 创建数据库表 167

9.8.1 理解其他关键字的意思 168

9.8.2 理解列的类型 169

9.8.3 用SHOW和DESCRIBE来查看数据库 170

9.9 理解MySQL的标识符 171

9.8.5 表格类型的提示 171

9.8.4 创建索引 171

9.10 选择列数据类型 172

9.10.1 数字类型 173

9.10.3 字符串类型 174

9.10.2 日期和时间类型 174

9.12 下一章 176

9.11 进一步学习 176

10.2 在数据库中插入数据 177

10.1 SQL是什么 177

第10章 使用MySQL数据库 177

10.3 从数据库中获取数据 179

10.3.1 获取满足特定条件的数据 181

10.3.2 从多个表中获取数据 182

10.3.4 分组与合计数据 186

10.3.3 以特定的顺序获取数据 186

10.3.6 使用子查询 188

10.3.5 选择要返回的行 188

10.4 更新数据库记录 190

10.5 创建后修改表 191

10.8 删除整个数据库 193

10.7 表的删除 193

10.6 删除数据库中的记录 193

10.10 下一章 194

10.9 进一步学习 194

11.1 Web数据库架构的工作原理 195

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

11.3 检查与过滤用户输入数据 198

11.2 从Web查询数据库的基本步骤 198

11.4 建立一个连接 199

11.6 查询数据库 200

11.5 选择使用的数据库 200

11.7 检索查询结果 201

11.9 将新信息放入数据库 202

11.8 从数据库断开连接 202

11.10 使用Prepared语句 205

11.12 使用常规的数据库接口:PEAR DB 206

11.11 使用PHP与数据库交互的其他接口 206

11.14 下一章 209

11.13 进一步学习 209

12.1 深入理解权限系统 210

第12章 MySQL高级管理 210

12.1.1 user表 211

12.1.3 tables_priv表和columns_priv表 212

12.1.2 db表和host表 212

12.1.5 更新权限:修改什么时候生效 213

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

12.2.2 密码 214

12.2.1 从操作系统角度来保护MySQL 214

12.2 提高MySQL数据库的安全性 214

12.2.4 Web问题 215

12.2.3 用户权限 215

12.3.1 使用SHOW获取信息 216

12.3 获取更多关于数据库的信息 216

12.3.3 用EXPLAIN理解查询操作的工作过程 218

12.3.2 使用DESCRIBE获取关于列的信息 218

12.5 优化数据库 221

12.4 使用索引提高查询速度 221

12.6 备份MySQL数据库 222

12.5.6 其他技巧 222

12.5.1 设计优化 222

12.5.2 权限 222

12.5.3 表的优化 222

12.5.4 使用索引 222

12.5.5 使用默认值 222

12.8 实现复制 223

12.7 恢复MySQL数据库 223

12.8.2 执行初始的数据传输 224

12.8.1 设置主服务器 224

12.10 下一章 225

12.9 进一步学习 225

12.8.3 设置一个/多个从服务器 225

13.2 存储引擎 226

13.1 LOAD DATA INFILE语句 226

第13章 MySQL高级编程 226

13.3.1 理解事务的定义 227

13.3 事务 227

13.3.2 通过InnoDB使用事务 228

13.4 外键 229

13.5.1 基本示例 230

13.5 存储过程 230

13.5.2 局部变量 232

13.5.3 游标和控制结构 233

13.7 下一章 236

13.6 进一步学习 236

14.2 考虑电子商务网站的类型 237

14.1 我们要实现什么目标 237

第三篇 电子商务与安全性第14章 运营一个电子商务网站 237

14.2.1 使用在线说明书公布信息 238

14.2.2 接收产品或服务的订单 240

14.2.5 减少成本 243

14.2.4 为产品或服务增值 243

14.2.3 提供服务和数字产品 243

14.3.1 网络黑客 244

14.3 理解风险和威胁 244

14.3.6 软件错误 245

14.3.5 广泛的竞争 245

14.3.2 不能招揽足够的生意 245

14.3.3 计算机硬件故障 245

14.3.4 电力、通信、网络或运输故障 245

14.5 下一章 246

14.4 基于策略作决定 246

14.3.7 不断变化的政府政策和税收 246

14.3.8 系统容量限制 246

15.1 信息的重要程度 247

第15章 电子商务的安全问题 247

15.2.1 机密数据的泄露 248

15.2 安全威胁 248

15.2.2 数据丢失和数据破坏 249

15.2.3 数据修改 250

15.2.5 软件错误 251

15.2.4 拒绝服务 251

15.2.6 否认 252

15.4 建立一个安全政策 253

15.3 易用性,性能、成本和安全性 253

15.6 使用身份验证 254

15.5 身份验证原则 254

15.7 加密技术基础 255

15.9 公有密钥加密 256

15.10 数字签名 256

15.8 私有密钥加密 256

15.11 数字证书 257

15.12 安全的Web服务器 258

15.15 备份数据 259

15.14 防火墙 259

15.13 审计与日志记录 259

15.16 自然环境安全 260

15.15.2 备份与恢复MySQL数据库 260

15.15.1 备份常规文件 260

15.17 下一章 261

16.1 识别访问者 262

第16章 使用PHP和MySQL实现身份验证 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.2 检查是否正常工作 276

16.7.1 安装mod_auth_mysql 276

16.7 使用mod_auth_mysql身份验证 276

16.8 创建自定义身份验证 277

16.7.3 使用mod_auth_mysql 277

16.10 下一章 278

16.9 进一步学习 278

17.1 提供安全的事务处理 279

第17章 使用PHP和MySQL实现安全事务 279

17.1.1 用户机器 280

17.1.3 我们的系统 281

17.1.2 Internet 281

17.2 使用加密套接字层(SSL) 282

17.4 提供安全存储 284

17.3 屏蔽用户的输入 284

17.5 确定是否需要存储信用卡号码 285

17.6.1 安装GPG 286

17.6 在PHP中使用加密技术 286

17.6.2 测试GPG 288

17.8 下一章 293

17.7 进一步学习 293

18.1 文件上载 295

第四篇 PHP的高级技术第18章 与文件系统和服务器的交互 295

18.1.2 关于安全性的提示 296

18.1.1 文件上载的HTML 296

18.1.3 编写处理文件的PHP 297

18.2.1 从目录读取 300

18.2 使用目录函数 300

18.1.4 常见问题 300

18.3.1 获取文件信息 302

18.3 与文件系统的交互 302

18.2.2 获得当前目录的信息 302

18.2.3 创建和删除目录 302

18.3.2 更改文件属性 304

18.4 使用程序执行函数 305

18.3.3 创建、删除和移动文件 305

18.7 下一章 308

18.6 进一步学习 308

18.5 与环境变量交互:getenv()和putenv() 308

19.2 发送和读取电子邮件 309

19.1 了解可供使用的协议 309

第19章 使用网络函数和协议函数 309

19.3 使用其他Web站点 310

19.4 使用网络查找函数 312

19.5.1 使用FTP备份或镜像一个文件 316

19.5 使用FTP 316

19.5.3 避免超时 321

19.5.2 上传文件 321

19.6 进一步学习 322

19.5.4 使用其他的FTP函数 322

19.7 下一章 323

20.1.1 使用date()函数 324

20.1 在PHP中获取日期和时间 324

第20章 日期和时间的管理 324

20.1.2 使用UNIX时间戳 325

20.1.3 使用getdate()函数 326

20.2 在PHP日期格式和MySQL日期格式之间进行转换 327

20.1.4 检验日期有效性 327

20.4 在MySQL中计算日期 329

20.3 在PHP中计算日期 329

20.6 使用日历函数 331

20.5 使用微秒 331

20.8 下一章 332

20.7 进一步学习 332

21.1 在PHP中设定图像支持 333

第21章 创建图像 333

21.2.2 PNG 334

21.2.1 JPEG 334

21.2 理解图像格式 334

21.3 创建图像 335

21.2.4 GIF 335

21.2.3 WBMP 335

21.3.1 创建一个背景图像 336

21.3.2 在图像上绘图或打印文本 337

21.3.3 输出最终图形 338

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

21.4 在其他页面中使用自动生成的图像 339

21.3.4 清理 339

21.5.2 将文本调整到适合按钮 342

21.5.1 创建基本画布 342

21.5.5 完成 345

21.5.4 将文本写到按钮上 345

21.5.3 放置文本 345

21.6 绘制图像与用图表描绘数据 346

21.8 进一步学习 352

21.7 使用其他的图像函数 352

21.9 下一章 353

22.2.1 什么是cookie 354

22.2 理解基本的会话功能 354

第22章 在PHP中使用会话控制 354

22.1 什么是会话控制 354

22.2.3 在会话中使用cookie 355

22.2.2 通过PHP设置cookie 355

22.3.2 注册一个会话变量 356

22.3.1 开始一个会话 356

22.2.4 存储会话ID 356

22.3 实现简单的会话 356

22.4 创建一个简单的会话例子 357

22.3.4 注销变量与销毁会话 357

22.3.3 使用会话变量 357

22.5 配置会话控制 359

22.6 通过会话控制实现身份验证 360

22.8 下一章 365

22.7 进一步学习 365

23.1 使用魔术引用 366

第23章 其他有用的特性 366

23.3 中断执行:die和exit 367

23.2 使用eval()函数对字符串求值 367

23.4 序列化变量和对象 368

23.5.1 找到所加载的PHP扩展部件 369

23.5 获取PHP环境信息 369

23.7 暂时改变运行时环境 370

23.6 动态加载扩展部件 370

23.5.2 识别脚本所有者 370

23.5.3 确定脚本最近修改时间 370

23.8 源代码加亮 371

23.10 下一章 372

23.9 在命令行中使用PHP 372

第五篇 创建实用的PHP和MySQL项目第24章 在大型项目中使用PHP和MySQL 373

24.2 规划和运行Web应用程序项目 374

24.1 在Web开发中应用软件工程 374

24.4.1 编码标准 375

24.4 编写可维护代码 375

24.3 重用代码 375

24.4.4 文档化和共享内部函数 378

24.4.3 使用标准的目录结构 378

24.4.2 分解代码 378

24.5 实现版本控制 379

24.7 项目的文档化 380

24.6 选择一个开发环境 380

24.9 将逻辑和内容分离 381

24.8 建立原型 381

24.10.2 使用Zend产品 382

24.10.1 使用简单优化 382

24.10 优化代码 382

24.12 进一步学习 383

24.11 测试 383

24.13 下一章 384

25.1.1 语法错误 385

25.1 编程错误 385

第25章 调试 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.2.1 用户识别和个性化设置 399

26.2 解决方案的组成 399

第26章 建立用户身份验证机制和个性化设置 399

26.1 问题所在 399

26.3 解决方案概述 400

26.2.3 推荐书签 400

26.2.2 保存书签 400

26.4 实现数据库 402

26.5 实现基本的网站 403

26.6.1 注册 405

26.6 实现用户身份验证 405

26.6.2 登录 410

26.6.3 登出 413

26.6.4 修改密码 414

26.6.5 重设遗忘的密码 416

26.7.1 添加书签 420

26.7 实现书签的存储和检索 420

26.7.3 删除书签 422

26.7.2 显示书签 422

26.8 实现书签推荐 424

26.10 下一章 427

26.9 封装和可能的扩展 427

27.2.1 创建一个在线目录 428

27.2 解决方案的组成 428

第27章 创建一个购物车 428

27.1 问题所在 428

27.3 解决方案概述 429

27.2.4 创建一个管理界面 429

27.2.2 在用户购买商品的时候记录购买行为 429

27.2.3 实现一个付款系统 429

27.4 实现数据库 432

27.5.1 列出目录 434

27.5 实现在线目录 434

27.5.2 列出一个目录中的所有图书 437

27.5.3 显示图书详细信息 438

27.6.1 使用show_cart.php脚本 440

27.6 实现购物车 440

27.6.2 浏览购物车 442

27.6.3 将物品添加到购物库 444

27.6.4 保存更新后的购物车 446

27.6.6 结账 447

27.6.5 打印标题栏摘要 447

27.7 实现付款 452

27.8 实现一个管理界面 454

27.9 扩展该项目 460

27.11 下一章 461

27.10 使用一个已有系统 461

28.3 已有系统 462

28.2 解决方案的需求 462

第28章 创建一个内容管理系统 462

28.1 问题所在 462

28.4.2 数据库与文件存储的对比 463

28.4.1 使内容进入系统 463

28.4 编辑内容 463

28.5 使用元数据 464

28.4.3 文档结构 464

28.7 解决方案的设计/概述 465

28.6 格式化输出 465

28.8 设计数据库 466

28.9.1 前台 467

28.9 实现CMS 467

28.9.2 图像处理 471

28.9.3 后台 473

28.9.4 搜索 480

28.9.5 编辑页面 483

28.11 下一章 485

28.10 扩展该项目 485

29.2 解决方案的组成 486

29.1 问题所在 486

第29章 创建一个基于Web的电子邮件服务系统 486

29.3 解决方案概述 488

29.4 建立数据库 489

29.5 了解脚本架构 490

29.6 登录与登出 495

29.7 建立账户 498

29.7.1 创建一个新账户 499

29.7.3 删除账户 501

29.7.2 修改已有账户 501

29.8.1 选择账户 502

29.8 阅读邮件 502

29.8.2 查看邮箱内容 504

29.8.3 阅读邮件消息 507

29.8.5 删除邮件 509

29.8.4 查看消息标题 509

29.9.1 发送一则新消息 510

29.9 发送邮件 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.1 问题所在 556

31.2 解决方案的组成 556

第31章 创建一个Web论坛 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.9 使用一个已有的系统 578

31.10 下一章 578

31.8 添加扩充 578

32.1 问题所在 579

32.2 评估文档格式 579

第32章 生成PDF格式的个性化文档 579

32.2.3 HTML 580

32.2.2 ASCII 580

32.2.4 字处理器格式 580

32.2.1 纸张 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.2 使用Amazon的Web服务接口 613

33.4.3 XML的解析 613

33.4.1 创建购物车 613

33.4.5 缓存 614

33.5 解决方案概述 614

33.4.4 在PHP中使用SOAP 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

精品推荐