新浪微博 登陆  注册   设为首页 加入收藏

学PHP >> 图书推荐 >> PHP和MySQL开发

PHP和MySQL开发

查看次数14903 发表时间2010-06-21 23:56:09

内容提要:本书将PHP开发与MySQL应用相结合,分别对PHP和MySQL做了深入浅出的分析,不仅介绍PHP和MySQL的一般概念,而且对PHP和MySQL的Web应用做了较全面的阐述,并包括几个经典且实用的例子。 本书是第4版,经过了全面的更新、重写和扩展,包括PHP 5.3最新改进的特性(例如,更好的错误和异常处理),MySQL的存储过程和存储引擎,Ajax技术与Web 2.0以及Web应用需要注意的安全问题。


【内容简介】
       本书将PHP开发MySQL应用相结合,分别对PHP和MySQL做了深入浅出的分析,不仅介绍PHP和MySQL的一般概念,而且对PHP和MySQL的Web应用做了较全面的阐述,并包括几个经典且实用的例子。
       本书是第4版,经过了全面的更新、重写和扩展,包括PHP 5.3最新改进的特性(例如,更好的错误和异常处理),MySQL的存储过程和存储引擎,Ajax技术与Web 2.0以及Web应用需要注意的安全问题。


【作者简介】
       Laura Thomson是Mozilla公司的高级软件工程师。之前,她是OmniTI公司和Tangled Web Design公司的合伙人。此外,Laura曾经在RMIT大学和波士顿顾问集团工作过。她获得了应用科学(计算机科学)的学士学位和工程学(计算机系统工程)学士学位。在她的空闲时间,她非常喜欢骑马,讨论免费软件和开源软件以及睡觉。
       Luke Welling是OmniTI公司的一位Web架构师,他经常在一些国际会议(例如,OSCON, ZendCon, MySQLUC,HPCon,OSDC以及LinuxTag)中就开源和Web开发的话题发表演讲。在加入OmniTI公司之前,他曾作为数据库提供商的Web分析师为Hitwise.com公司工作。此外,他还是Tangled Web Design公司的独立顾问。他还在澳大利亚墨尔本的RMIT大学教授计算机科学课程。他获得了应用科学(计算机科学)的学士学位。在他的空闲时间,他希望治好他的失眠症。

【目录】
读者反馈
译者序
前言
作者简介
第一篇   使用PHP
第1章   PHP快速入门教程    1
1.1   开始之前:了解PHP 
1.2   创建一个示例应用:Bob汽车零部件商店    2
1.2.1   创建订单表单    2
1.2.2   表单处理    4
1.3   在HTML中嵌入PHP    4
1.3.1   使用PHP标记    5
1.3.2   PHP语句    6
1.3.3   空格    6
1.3.4   注释    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.7.1 PHP的数据类型
1.7.2 类型强度
1.7.3 类型转换
1.7.4 可变变量
1.8   声明和使用常量    13
1.9   理解变量的作用域    13
1.10   使用操作符    16
1.10.1   算术操作符    17
1.10.2   字符串操作符    17
1.10.3   赋值操作符    17
1.10.4   比较操作符    19
1.10.5   逻辑操作符    20
1.10.6   位操作符    21
1.10.7   其他操作符    21
1.11  计算表单总金额    23
1.12  理解操作符的优先级和结合性:
1.13   使用可变函数    25
1.13.1   测试和设置变量类型    26
1.13.2   测试变量状态    26
1.13.3   变量的重解释    27
1.14   根据条件进行决策    27
1.14.1   if语句    28
1.14.2   代码块    28
1.14.3   else语句    28
1.14.4   elseif语句    29
1.14.5   switch语句    30
1.14.6   比较不同的条件    31
1.15   通过迭代实现重复动作    32
1.15.1   while循环    33
1.15.2   for和foreach循环    34
1.15.3   do...while循环    35
1.16   从控制结构或脚本中跳出    35
1.17   使用可替换的控制结构语法    36
1.18   使用declare    36
1.19   下一章    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
第5章   代码重用与函数编写    94
5.1   代码重用的好处
5.1.1   成本    94
5.1.2   可靠性    94
5.1.3   一致性    95
5.2   使用require()和include()函数    95
5.2.1   文件扩展名和require()语句    96
5.2.2   使用require()制作Web站点的模版    96
5.2.3   使用auto_prepend_file和auto_append_file    101
5.3   在PHP中使用函数    101
5.3.1   调用函数    101
5.3.2   调用未定义的函数    103
5.3.3   理解字母大小写和函数名称    103
5.4   理解为什么要定义自己的函数    103
5.5   了解基本的函数结构    104
5.5.1 函数命名
5.6   使用参数    105
5.7   理解作用域    107
5.8   参数的引用传递和值传递    109
5.9  使用Return关键字    110
5.9.1   从函数返回一个值    111
5.10  实现递归    113
5.10.1 名称空间
5.11   进一步学习    114
5.12   下一章    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   使用Per-Class常量    135
6.10.2   实现静态方法    135
6.10.3   检查类的类型和类型提示    136
6.10.4   克隆对象    136
6.10.5   使用抽象类    137
6.10.6   使用__call()重载方法    137
6.10.7   使用__autoload()方法    138
6.10.8   实现迭代器和迭代    138
6.10.9   将类转换成字符串    140
6.10.10   使用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.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.2.1   检查与过滤用户输入数据    198
11.2.2   建立一个连接    199
11.2.3  选择使用的数据库    200
11.2.4   查询数据库    200
11.2.5   检索查询结果    201
11.2.6   从数据库断开连接    202
11.3   将新信息放入数据库    202
11.4   使用Prepared语句    205
11.5   使用PHP与数据库交互的其他接口    206
11.5.1   使用常规的数据库接口:PEAR MDB2     206
11.6   进一步学习    209
11.7   下一章    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表和procs_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.4.1   设计优化    222
12.4.2   权限    222
12.4.3   表的优化    222
12.4.4   使用索引    222
12.4.5   使用默认值    222
12.4.6   其他技巧    222
12.5   备份MySQL数据库    222
12.6   恢复MySQL数据库    223
12.7   实现复制    223
12.7.1   设置主服务器    224
12.7.2   执行初始的数据传输    224
12.7.3   设置一个/多个从服务器    225
12.8   进一步学习    225
12.9   下一章    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   加密技术基础    255
15.6.1   私有密钥加密    256
15.6.2  公有密钥加密    256
15.6.3   数字签名    256
15.7   数字证书    257
15.8   安全的Web服务器    258
15.9   审计与日志记录    259
15.10   防火墙    259
15.11   备份数据    259
15.11.1   备份常规文件    260
15.11.2   备份与恢复MySQL数据库    260
15.12   自然环境安全    260
15.13   下一章    261
第16章     Web应用的安全
16.1处理安全性问题的策略
16.1.1 以正确心态为开始
16.1.2 安全性和可用性之间的平衡
16.1.3 安全监视
16.1.4 基本方法
16.2 识别所面临的威胁
16.2.1 访问或修改敏感数据
16.2.2 数据丢失或破坏
16.2.3 拒绝服务
16.2.4 恶意代码注入
16.2.5 服务器被攻破
16.3了解与我们“打交道”的用户
16.3.1 破解人员
16.3.2 受影响机器的未知情用户
16.3.3 对公司不满的员工
16.3.4 硬件被盗
16.3.5 我们自身
16.4 代码的安全性
16.4.1 过滤用户输入
16.4.2 转义输出
16.4.3 代码组织
16.4.4 代码自身的问题
16.4.5 文件系统因素
16.4.6 代码稳定性和缺陷
16.4.7 执行引号和exec
16.5 Web服务器和PHP的安全性
16.5.1 保持软件的更新
16.5.2 查看php.ini文件
16.5.3  Web服务器配置
16.5.4 Web应用的商业主机服务
16.6 数据库服务器的安全性
16.6.1 用户和权限系统
16.6.2发送数据至服务器
16.6.3 连接服务器
16.6.4 运行服务器
16.7 保护网络
16.7.1 安装防火墙
16.7.2使用隔离区域(DMZ)
16.7.3应对DoS和DDoS攻击
16.8 计算机和操作系统的安全性
16.8.1 保持操作系统的更新
16.8.2只运行必须的软件
16.8.3 服务器的物理安全性
16.9 灾难计划
16.10 下一章

第17章   使用PHP和MySQL实现身份验证    262
17.1   识别访问者    262
17.2   实现访问控制    263
17.2.1   保存密码    265
17.2.2   密码的加密    267
17.2.3   保护多个网页    268
17.3   使用基本身份验证    269
17.4   在PHP中使用基本身份验证    270
17.5   在Apache的.htaccess文件中使用基本身份验证    271
17.6   使用mod_auth_mysql身份验证    276
17.6.1   安装mod_auth_mysql    276
17.6.2   使用mod_auth_mysql    277
17.7   创建自定义身份验证    277
17.8   进一步学习    278
17.9   下一章    278
第18章   使用PHP和MySQL实现安全事务    279
18.1   提供安全的事务处理    279
18.1.1   用户机器    280
18.1.2   Internet    281
18.1.3   我们的系统    281
18.2   使用加密套接字层(SSL)    282
18.3   屏蔽用户的输入    284
18.4   提供安全存储    284
18.5   存储信用卡号码    285
18.6   在PHP中使用加密技术    286
18.6.1   安装GPG    286
18.6.2   测试GPG    288
18.7   进一步学习    293
18.8   下一章    293
第四篇   PHP的高级技术
第19章   与文件系统和服务器的交互    295
19.1   文件上载    295
19.1.1   文件上载的HTML代码    296
19.1.2   编写处理%

(转发请注明转自:学PHP)    


  相关推荐



1楼 Donte说: 2016-12-22 01:20:32
I love these arisclet. How many words can a wordsmith smith?

  发表评论
昵称:
(不超过20个字符或10个汉字)
内容: