《PHP自学视频教程》PDF下载

  • 购买积分:16 如何计算积分?
  • 作  者:软件开发技术联盟编著
  • 出 版 社:北京:清华大学出版社
  • 出版年份:2014
  • ISBN:9787302371076
  • 页数:529 页
图书介绍:本书从初学者角度出发,通过通俗易懂的语言、丰富多彩的实例,详细介绍了使用PHP进行网络开发应该掌握的各方面技术。全书共分4篇25章,包括初识PHP、PHP环境搭建和开发工具、PHP语言基础、流程控制语句、字符串操作、正则表达式、PHP数组、PHP与Web页面交互、PHP与JavaScript交互、日期和时间、Cookie与Session、图形图像处理技术、文件系统、面向对象、PHP加密技术、MySQL数据库基础等。

第1篇 入门篇 2

第1章 了解PHP 2

1.1 什么是PHP 3

1.2 PHP语言的优势 3

1.3 PHP版本 4

1.4 如何学好PHP 5

1.5 准备PHP的开发条件 6

1.5.1 下载PHP及相关软件 6

1.5.2 代码编辑工具 7

1.5.3 下载PHP用户手册 8

1.6 本章小结 9

第2章 PHP开发环境搭建 10

2.1 AppServ——Windows版PHP集成安装包 11

2.1.1 在Windows下搭建PHP开发环境 11

2.1.2 测试AppServ是否安装成功 13

2.2 XAMPP——Linux版PHP集成安装包 14

2.2.1 在Linux下搭建PHP开发环境 14

2.2.2 在Linux下启动、停止XAMPP 15

2.2.3 设置MySQL数据库root用户的密码 16

2.2.4 在Linux下编写第一个PHP程序 16

2.3 PHP开发环境的关键配置 17

2.3.1 Apache服务器的基本配置 17

2.3.2 php.ini文件的基本配置 18

2.4 Dreamweaver开发工具简介 19

2.4.1 Dreamweaver中编码格式的选择 19

2.4.2 Dreamweaver创建站点 20

2.4.3 Dreamweaver创建表格 22

2.4.4 Dreamweaver创建表单 24

2.5 综合应用 26

2.5.1 编写第一个PHP程序 26

2.5.2 输出一张漂亮的图片 27

2.6 本章常见错误 28

2.6.1 AppServ不能安装 28

2.6.2 Apache服务器端口冲突 28

2.7 本章小结 28

2.8 跟我上机 28

第3章 PHP开发基础 29

3.1 PHP工作原理 30

3.2 PHP语法基础 30

3.2.1 PHP标记符 30

3.2.2 PHP的注释 32

3.3 PHP的数据类型 33

3.3.1 标量数据类型 33

3.3.2 复合数据类型 37

3.3.3 特殊数据类型 38

3.3.4 转换数据类型 39

3.3.5 检测数据类型 40

3.4 PHP常量 41

3.4.1 定义和使用常量 41

3.4.2 预定义常量 42

3.5 PHP变量 43

3.5.1 什么是变量 44

3.5.2 定义和使用变量 44

3.5.3 变量的作用域 45

3.5.4 可变变量 47

3.6 PHP运算符 48

3.6.1 算术运算符 48

3.6.2 字符串运算符 49

3.6.3 赋值运算符 49

3.6.4 位运算符 50

3.6.5 递增或递减运算符 50

3.6.6 逻辑运算符 51

3.6.7 比较运算符 52

3.6.8 三元运算符 54

3.6.9 运算符的使用规则 54

3.7 PHP表达式 55

3.8 综合应用 55

3.8.1 输出姚明个人信息 55

3.8.2 计算长方形的面积 56

3.9 本章常见错误 57

3.9.1 定界符的结束标识符之前有空格 57

3.9.2 表达式末尾未写分号 57

3.10 本章小结 57

3.11 跟我上机 57

第4章 PHP流程控制语句 58

4.1 程序的3种结构 59

4.1.1 顺序结构 59

4.1.2 选择结构 59

4.1.3 循环结构 59

4.2 条件控制语句 60

4.2.1 if条件控制语句 60

4.2.2 switch多分支语句 62

4.3 循环控制语句 64

4.3.1 while循环语句 64

4.3.2 do…while循环语句 65

4.3.3 for循环语句 66

4.3.4 foreach循环语句 67

4.4 跳转语句 69

4.4.1 break跳转语句 69

4.4.2 continue跳转语句 71

4.5 综合应用 72

4.5.1 利用continue语句计算100以内奇数的和 72

4.5.2 应用switch语句设计网站主页 73

4.6 本章常见错误 74

4.6.1 条件语句中缺少小括号 74

4.6.2 应用break语句跳出的循环次数不正确 75

4.7 本章小结 75

4.8 跟我上机 75

第5章 函数 76

5.1 自定义函数 77

5.1.1 函数的命名规则 77

5.1.2 自定义函数格式 77

5.1.3 自定义函数的调用 78

5.1.4 函数的参数 78

5.1.5 函数的返回值 80

5.1.6 函数的嵌套调用 81

5.1.7 函数的递归调用 81

5.2 内建函数 82

5.3 输出语句 82

5.3.1 应用print语句输出字符 82

5.3.2 应用echo语句输出字符 84

5.3.3 应用printf语句格式化输出字符 85

5.3.4 应用sprintf语句格式化输出字符 86

5.4 引用文件 87

5.4.1 应用include语句引用文件 87

5.4.2 应用require语句引用文件 88

5.4.3 应用include_once语句引用文件 89

5.4.4 应用require_once语句引用文件 90

5.4.5 include语句和require语句的使用区别 91

5.4.6 include_once语句和require_once语句的使用区别 91

5.5 综合应用 91

5.5.1 自定义一个为数字取绝对值的函数 91

5.5.2 应用include语句构建在线音乐网站主页 92

5.6 本章常见错误 93

5.6.1 使用PHP保留关键字作为函数名 93

5.6.2 自定义函数后没有调用 94

5.6.3 echo语句结束处未写分号 94

5.7 本章小结 94

5.8 跟我上机 94

第6章 字符串操作 95

6.1 字符串简介 96

6.2 单引号与双引号 96

6.3 转义、还原字符串 97

6.3.1 手动转义、还原字符串 97

6.3.2 自动转义、还原字符串 98

6.4 获取字符串长度 100

6.5 截取字符串 102

6.6 比较字符串 103

6.6.1 按字节比较 103

6.6.2 按自然排序法比较 104

6.6.3 指定从源字符串的位置比较 105

6.7 检索字符串 106

6.7.1 strstr()函数 106

6.7.2 substr_count()函数 107

6.8 替换字符串 107

6.8.1 str_ireplace()函数 107

6.8.2 substr replace()函数 109

6.9 去掉字符串首尾空格和特殊字符 110

6.9.1 ltrim()函数 110

6.9.2 rtrim()函数 111

6.9.3 trim()函数 111

6.10 格式化字符串 112

6.11 分割、合成字符串 113

6.11.1 explode()函数 113

6.11.2 implode()函数 114

6.12 字符串与HTML转换 115

6.13 综合应用 116

6.13.1 用substr()函数截取中文字符串 116

6.13.2 对关键字进行高亮显示 117

6.14 本章常见错误 118

6.14.1 截取含有中文的字符串时出现乱码 118

6.14.2 特殊字符插入数据库时未转义 118

6.14.3 explode()函数的分割符为空字符串 118

6.15 本章小结 118

6.16 跟我上机 119

第7章 正则表达式 120

7.1 什么是正则表达式 121

7.2 正则表达式的语法规则 122

7.2.1 行定位符(∧和$) 122

7.2.2 单词定界符(\b、\B) 122

7.2.3 字符类([]) 123

7.2.4 选择字符(|) 123

7.2.5 连字符(-) 124

7.2.6 排除字符([∧]) 124

7.2.7 限定符(?+{n,m}) 124

7.2.8 点号字符(.) 125

7.2.9 转义字符(\) 125

7.2.10 反斜线(\) 126

7.2.11 括号字符(()) 127

7.2.12 整合实用的正则表达式 127

7.3 PCRE兼容正则表达式函数 129

7.3.1 查找字符串 129

7.3.2 替换字符串 130

7.4 综合应用 131

7.4.1 通过JavaScript脚本和正则表达式验证用户注册信息 131

7.4.2 通过正则表达式函数preg_match()验证注册信息 134

7.5 本章常见错误 136

7.5.1 定义正则表达式时未使用定界符“/” 136

7.5.2 匹配特殊字符时未使用转义字符(\) 136

7.6 本章小结 136

7.7 跟我上机 136

第8章 PHP数组 138

8.1 数组概述 139

8.2 数组类型 139

8.2.1 数字索引数组 139

8.2.2 关联数组 139

8.3 声明数组 140

8.3.1 数组命名规则 140

8.3.2 用户创建数组 140

8.3.3 应用函数创建数组 141

8.3.4 创建二维数组 142

8.4 遍历与输出数组 143

8.4.1 遍历数组 143

8.4.2 输出数组元素 146

8.5 PHP的数组函数 146

8.5.1 合并数组 146

8.5.2 统计数组元素个数 147

8.5.3 添加数组元素 147

8.5.4 获取最后一个元素 148

8.5.5 删除重复元素 148

8.5.6 获取指定元素的键名 149

8.5.7 字符串与数组的转换 150

8.5.8 数组排序 150

8.6 PHP全局数组 153

8.6.1 $_SERVER[]全局数组 154

8.6.2 $_GET[]和$_POST[]全局数组 155

8.6.3 $COOKIE[]全局数组 155

8.6.4 $ENV[]全局数组 155

8.6.5 $_REQUEST[]全局数组 155

8.6.6 $_SESSION[]全局数组 155

8.6.7 $FILES[]全局数组 156

8.7 综合应用 156

8.7.1 生成在线考试题 156

8.7.2 向投票系统添加投票选项 157

8.8 本章常见错误 158

8.8.1 数组元素之间用分号进行分隔 158

8.8.2 数组名和已存在的变量重名 158

8.9 本章小结 158

8.10 跟我上机 159

第9章 PHP与Web页面交互 160

9.1 表单概述 161

9.1.1 创建表单 161

9.1.2 认识表单元素 162

9.1.3 定义表单数据提交方法 167

9.2 在Web页中嵌入PHP脚本 169

9.2.1 在HTML标记中嵌入PHP脚本 169

9.2.2 为表单元素赋值 170

9.3 应用PHP全局变量获取表单数据 170

9.3.1 $POST[]全局变量 171

9.3.2 $_GET[]全局变量 172

9.3.3 $_SESSION[]全局变量 173

9.4 对URL传递的参数进行编/解码 173

9.4.1 对URL传递的参数进行编码 173

9.4.2 对URL编码的字符串进行解码 174

9.5 综合应用 175

9.5.1 发布和查看公告信息 175

9.5.2 获取用户的个人信息 177

9.6 本章常见错误 179

9.6.1 全局变量中的表单元素名称与创建表单元素时设置的名称不一致 179

9.6.2 在表单中添加复选框和列表时命名不正确 180

9.7 本章小结 180

9.8 跟我上机 180

第10章 日期和时间 182

10.1 PHP的时区设置 183

10.1.1 在配置文件php.ini中设置时区 183

10.1.2 通过date_default_timezone_set()函数设置时区 183

10.2 UNIX时间戳 184

10.2.1 获取任意日期、时间的时间戳 184

10.2.2 获取当前时间的时间戳 185

10.2.3 将英文文本的日期时间转换为UNIX时间戳 185

10.3 日期和时间的处理 186

10.3.1 对日期和时间进行格式化 187

10.3.2 获取日期和时间信息 189

10.3.3 获取本地化的日期和时间 190

10.3.4 检验日期和时间的有效性 192

10.4 综合应用 193

10.4.1 倒计时 193

10.4.2 计算程序的运行时间 194

10.4.3 网页闹钟 195

10.5 本章常见错误 195

10.5.1 通过strftime()函数对本地时间格式化输出时出现乱码 195

10.5.2 检验日期和时间有效性时参数的顺序不正确 196

10.6 本章小结 196

10.7 跟我上机 196

第2篇 提高篇 198

第11章 MySQL数据库设计 198

11.1 MySQL简介 199

11.1.1 什么是MySQL 199

11.1.2 MySQL特点 199

11.1.3 MySQL 5支持的特性 200

11.2 启动和关闭MySQL服务器 200

11.2.1 启动MySQL服务器 200

11.2.2 连接和断开MySQL服务器 201

11.2.3 关闭MySQL服务器 202

11.3 操作MySQL数据库 203

11.3.1 创建数据库 203

11.3.2 选择数据库 203

11.3.3 删除数据库 204

11.4 MySQL数据类型 204

11.4.1 数字类型 204

11.4.2 字符串类型 205

11.4.3 日期和时间类型 206

11.5 操作MySQL数据表 207

11.5.1 创建数据表 207

11.5.2 查看表结构 208

11.5.3 修改表结构 209

11.5.4 重命名数据表 210

11.5.5 删除数据表 210

11.6 操作MySQL数据 211

11.6.1 插入记录 211

11.6.2 浏览数据库记录 212

11.6.3 修改记录 215

11.6.4 删除记录 215

11.7 phpMyAdmin图形管理工具 216

11.7.1 管理数据库 216

11.7.2 管理数据表 217

11.7.3 管理数据记录 219

11.7.4 导入/导出数据 221

11.8 综合应用 223

11.8.1 管理MySQL数据库及数据表 223

11.8.2 在phpMyAdmin中重置MySQL服务器登录密码 224

11.9 本章常见错误 224

11.9.1 执行修改和删除操作时未指定where条件语句 224

11.9.2 数据库恢复时不存在一个同名的空数据库 225

11.10 本章小结 225

11.11 跟我上机 225

第12章 PHP操作MySQL数据库 226

12.1 PHP操作MySQL数据库的步骤 227

12.2 PHP操作MySQL数据库的方法 228

12.2.1 连接MySQL服务器 228

12.2.2 选择MySQL数据库 229

12.2.3 执行SQL语句 230

12.2.4 将结果集返回到数组中 231

12.2.5 从结果集中获取一行作为对象 233

12.2.6 从结果集中获取一行作为枚举数组 234

12.2.7 获取查询结果集中的记录数 235

12.2.8 释放内存 235

12.2.9 关闭连接 236

12.3 管理MySQL数据库中的数据 236

12.3.1 添加数据 237

12.3.2 编辑数据 238

12.3.3 删除数据 240

12.3.4 批量数据操作 241

12.4 综合应用 242

12.4.1 通用查询 242

12.4.2 高级查询 243

12.4.3 对查询结果分页显示 245

12.5 本章常见错误 248

12.5.1 数据库导致的错误 248

12.5.2 刷新页面重复提交 248

12.6 本章小结 248

12.7 跟我上机 249

第13章 Cookie和Session 251

13.1 Cookie的操作 252

13.1.1 创建Cookie 253

13.1.2 读取Cookie 254

13.1.3 删除Cookie 255

13.2 Session的操作 256

13.2.1 启动Session 257

13.2.2 注册Session 258

13.2.3 使用Session 258

13.2.4 删除Session 259

13.3 Cookie与Session的比较 260

13.4 综合应用 260

13.4.1 通过Session控制页面访问权限 260

13.4.2 Cookie自动登录 262

13.4.3 应用Session控制用户登录时间 264

13.5 本章常见错误 266

13.5.1 在setcookie()函数之前有内容输出 266

13.5.2 应用Session之前没有启动Session 267

13.6 本章小结 267

13.7 跟我上机 267

第14章 图形图像处理技术 268

14.1 GD2函数库简介 269

14.2 激活GD2函数库 269

14.3 常用的图像处理技术 270

14.3.1 创建画布 270

14.3.2 颜色处理 271

14.3.3 输出图像 271

14.3.4 绘制文字 272

14.3.5 绘制直线 274

14.3.6 销毁图像 275

14.4 应用Jpgraph类库绘制图像 275

14.4.1 Jpgraph类库简介 275

14.4.2 Jpgraph类库的安装 275

14.4.3 Jpgraph创建折线图统计图书销售走势 276

14.5 综合应用 278

14.5.1 应用GD2函数在图像上添加文字 278

14.5.2 应用图像处理技术生成验证码 278

14.5.3 Jpgraph创建3D饼形图展示部门业绩比较 280

14.6 本章常见错误 281

14.6.1 应用GD2函数库时代码段上端有HTML输出 281

14.6.2 通过imagettftext()函数不能正常输出中文 281

14.7 本章小结 282

14.8 跟我上机 282

第15章 文件和目录处理技术 283

15.1 基本的文件处理 284

15.1.1 打开文件 284

15.1.2 读取文件中的内容 285

15.1.3 向文件中写入数据 290

15.1.4 关闭文件 292

15.2 目录操作 292

15.2.1 打开目录 292

15.2.2 读取目录结构 292

15.2.3 关闭目录 293

15.3 文件的上传与下载 294

15.3.1 开启文件的上传功能 294

15.3.2 全局变量$FILES的应用 295

15.3.3 移动上传文件 296

15.3.4 文件下载技术 297

15.4 综合应用 298

15.4.1 通过文本文件统计网站访问量 298

15.4.2 规范化的文件上传 300

15.4.3 文本文件的分页输出 302

15.5 本章常见错误 304

15.5.1 在表单中未设置enctype属性 304

15.5.2 打开目录错误 304

15.6 本章小结 304

15.7 跟我上机 304

第16章 面向对象 305

16.1 面向对象的基本概念 306

16.1.1 类 306

16.1.2 对象 306

16.1.3 面向对象的特点 307

16.2 类的声明 307

16.2.1 定义类 308

16.2.2 成员属性 308

16.2.3 成员常量 309

16.2.4 成员方法 309

16.3 类的实例化 310

16.3.1 对象的创建 310

16.3.2 访问类中的成员 310

16.3.3 “$this”和“::” 311

16.3.4 构造方法和析构方法 312

16.4 面向对象的封装 314

16.4.1 公共成员关键字public 314

16.4.2 私有成员关键字private 314

16.4.3 保护成员关键字protected 315

16.5 面向对象的继承 316

16.5.1 继承关键字extends 316

16.5.2 子类调用父类的成员方法 317

16.5.3 覆盖父类方法 318

16.6 抽象类和接口 319

16.6.1 抽象类 319

16.6.2 接口 321

16.7 面向对象实现多态 322

16.7.1 通过继承实现多态 323

16.7.2 通过接口实现多态 324

16.8 面向对象的关键字 324

16.8.1 final关键字 324

16.8.2 static关键字 325

16.8.3 clone关键字 326

16.8.4 对象比较 327

16.8.5 instanceof关键字 328

16.9 面向对象的常用魔术方法 328

16.9 _set()和_get()方法 328

16.9.2 isset()和unset()方法 328

16.9.3 call()方法 329

16.9.4 _toString()方法 329

16.9.5 _autoload()方法 330

16.10 综合应用 331

16.10.1 封装数据库连接类和操作类 331

16.10.2 用面向对象生成图像验证码 333

16.10.3 封装一个显示页码的分页类 334

16.11 本章常见错误 337

16.11.1 在类外直接调用私有变量 337

16.11.2 继承接口时方法没有全部重写 338

16.12 本章小结 338

16.13 跟我上机 338

第17章 PDO数据库抽象层 340

17.1 PDO概述 341

17.1.1 什么是PDO 341

17.1.2 PDO的特点 341

17.1.3 PDO的加载 341

17.2 通过PDO连接数据库 342

17.2.1 PDO的构造函数 342

17.2.2 DSN详解 343

17.3 执行SQL语句 343

17.3.1 exec()方法 343

17.3.2 query()方法 344

17.3.3 预处理语句 345

17.4 获取结果集 346

17.4.1 fetch()方法 346

17.4.2 fetchAll()方法 348

17.4.3 fetchColumn()方法 349

17.5 捕获SQL语句中的错误 351

17.5.1 使用默认模式——PDO::ERRMODE_SILENT 351

17.5.2 使用警告模式——PDO::ERRMODE_WARNING 352

17.5.3 使用异常模式——PDO::ERRMODE_EXCEPTION 353

17.6 错误处理 355

17.6.1 errorCode()方法 355

17.6.2 errorInfo()方法 356

17.7 PDO中的事务处理和存储过程 357

17.7.1 PDO中的事务处理 357

17.7.2 PDO中的存储过程 358

17.8 综合应用 360

17.8.1 添加留言信息 360

17.8.2 修改商品信息 361

17.8.3 删除会员信息 366

17.9 本章常见错误 368

17.9.1 PDO类库未加载 368

17.9.2 未设置数据库编码格式 368

17.10 本章小结 368

17.11 跟我上机 369

第18章 程序调试与错误处理 370

18.1 程序调试的基本策略 371

18.2 常见错误类型 371

18.2.1 语法错误 371

18.2.2 语义错误 374

18.2.3 逻辑错误 374

18.2.4 注释错误 375

18.2.5 运行错误 375

18.3 错误处理机制 375

18.3.1 控制错误显示及显示方式 376

18.3.2 控制错误级别 376

18.4 常用程序调试方法 377

18.4.1 应用die语句进行调试 378

18.4.2 应用mysql_error()语句输出SQL语句的错误 378

18.4.3 应用try{}catch{}语句抛出并捕获异常 379

18.5 错误处理技巧 380

18.5.1 用“@”符号隐藏错误 380

18.5.2 自定义错误信息 381

18.6 综合应用 382

18.6.1 解决数据库乱码问题 382

18.6.2 封装异常处理类 383

18.7 本章常见错误 384

18.7.1 定义SQL语句时字段名不一致大小写不统一 384

18.7.2 全局变量register_globals的值设置为On 385

18.8 本章小结 385

18.9 跟我上机 385

第19章 Ajax技术 387

19.1 Ajax概述 388

19.1.1 什么是Ajax 388

19.1.2 Ajax的开发模式 388

19.1.3 Ajax的优点 388

19.2 Ajax技术的组成 389

19.2.1 JavaScript脚本语言 389

19.2.2 XMLHttpRequest对象 389

19.2.3 XML语言 393

19.2.4 DOM 393

19.2.5 CSS 394

19.3 Ajax与PHP的交互 394

19.3.1 通过GET方式与PHP进行交互 394

19.3.2 通过POST方式与PHP进行交互 396

19.4 Ajax开发注意事项 399

19.5 综合应用 400

19.5.1 在PHP中应用Ajax技术检测用户名 400

19.5.2 在PHP中应用Ajax技术实现博客文章类别添加 402

19.5.3 使用jQuery制作级联下拉列表框 404

19.6 本章常见错误 406

19.6.1 在应用Ajax过程中出现乱码 406

19.6.2 不能及时获取最新数据 407

19.7 本章小结 407

19.8 跟我上机 408

第20章 Smarty模板技术 410

20.1 Smarty简介 411

20.2 Smarty的安装配置 411

20.2.1 Smarty下载和安装 411

20.2.2 Smarty配置 412

20.2.3 第一个Smarty程序 413

20.3 Smarty模板设计 414

20.3.1 Smarty模板文件 414

20.3.2 注释 415

20.3.3 变量 415

20.3.4 修饰变量 417

20.3.5 流程控制 419

20.3.6 内建函数 423

20.4 Smarty程序设计 425

20.4.1 Smarty中的常用方法 425

20.4.2 Smarty的配置变量 426

20.5 综合应用 426

20.5.1 Smarty模板创建网页框架 426

20.5.2 分页输出会员信息 428

20.6 本章常见错误 432

20.6.1 Smarty模板的配置错误 432

20.6.2 模板引擎的解析错误 432

20.7 本章小结 433

20.8 跟我上机 433

第3篇 实战篇 436

第21章 明日企业网 436

21.1 概述 437

21.2 开发背景 437

21.3 需求分析 437

21.4 功能结构 439

21.5 数据库设计 439

21.5.1 数据库概念设计 439

21.5.2 创建数据库及数据表 441

21.6 技术攻关 442

21.6.1 Smarty模板 442

21.6.2 最简单的网页框架 444

21.6.3 PDO数据库抽象层 444

21.6.4 封装分页类 445

21.7 首页设计 446

21.7.1 首页概述 447

21.7.2 首页技术分析 447

21.7.3 首页的实现过程 448

21.8 产品展示设计 450

21.8.1 产品展示概述 450

21.8.2 产品展示技术分析 450

21.8.3 产品展示实现过程 451

21.9 后台管理系统设计 453

21.9.1 后台管理系统概述 453

21.9.2 后台管理系统技术分析 453

21.9.3 后台管理系统实现过程 455

21.10 本章小结 460

第22章 应用Smarty模板开发电子商务平台 461

22.1 项目描述 462

22.2 系统分析 462

22.2.1 需求分析 462

22.2.2 编写项目计划书 462

22.3 系统设计 463

22.3.1 系统目标 463

22.3.2 系统功能结构 463

22.3.3 系统流程图 464

22.4 系统开发环境 465

22.5 搭建系统框架 465

22.6 数据库与数据表的设计 465

22.6.1 数据库分析 465

22.6.2 创建数据库和数据表 467

22.7 公共文件设计 468

22.7.1 数据库连接文件 469

22.7.2 Smarty配置文件 469

22.7.3 XMLHttpRequest对象文件 469

22.7.4 表单样式文件 470

22.8 前台首页设计 472

22.9 登录模块设计 474

22.9.1 用户注册 474

22.9.2 用户登录 480

22.9.3 找回密码 482

22.10 会员信息模块设计 487

22.10.1 会员中心 487

22.10.2 安全退出 490

22.11 商品展示模块设计 491

22.11.1 创建PHP页 491

22.11.2 创建模板页 492

22.11.3 js脚本页面 493

22.12 购物车模块设计 493

22.12.1 添加商品 493

22.12.2 显示购物车 496

22.12.3 更改商品数量 498

22.12.4 删除商品 498

22.12.5 保存购物车 501

22.13 收银台模块设计 503

22.13.1 显示订单 503

22.13.2 填写订单 504

22.13.3 处理订单 505

22.13.4 反馈订单 507

22.13.5 查询订单 508

22.14 后台首页设计 511

22.14.1 后台首页布局 511

22.14.2 DIV4+JavaScript+CSS实现树状菜单 512

22.15 类别管理模块设计 513

22.15.1 添加类别 513

22.15.2 查看类别 516

22.16 订单管理模块设计 520

22.17 开发过程中的常见问题 523

22.17.1 使用js脚本获取、输出标签内容 523

22.17.2 解决Ajax的乱码问题 524

22.17.3 禁用页面缓存 524

22.17.4 使用浮动框架做关联菜单 524

22.17.5 防止站外链接 525

22.17.6 在新窗口中使用Session 525

22.17.7 判断上传文件格式 526

22.18 错误分析 526

22.18.1 数据库导致的错误 526

22.18.2 Smarty模板的配置错误 527

22.19 本章小结 529