⑴ 怎么自学php
php编程比较难,自学的话不容易,除非你能找到自学的方法。
……………………………………………………………………
怎样学习php,我刚才看到一篇很不错的文章,是一个专科生介绍自己如何自学php,并找到php的工作,里面介绍了他的学习方法和学习过程,希望对你有帮助。
先做个自我介绍,我07年考上一所很烂专科民办的学校,学的是生物专业,具体的学校名称我就不说出来献丑了。09年我就辍学了,我在那样的学校,一年学费要1万多,但是根本没有人学习,我实在看不到希望,我就退学了。
退学后我也迷茫,大专都没有毕业,我真的不知道我能干什么,我在纠结着我能做什么。所以辍学后我一段时间,我想去找工作,因为我比较沉默寡言,不是很会说话,我不适合去应聘做业务。我想应聘做技术的,可是处处碰壁。
一次偶然的机会,我才听到php这个行业。那天我去新华书店,在计算机分类那边想找本书学习。后来有个女孩子走过来,问我是不是读计算机的,有没有兴趣学习php,然后给我介绍了一下php现在的火热情况,告诉我学php多么的有前景,给我了一份传单,php培训的广告。听了她的介绍,我心里痒痒的,确实我很想去学会一门自己的技术,靠自己的双手吃饭。
回家后,我就上网查了下php,确实是当今比较热门的行业,也是比较好找工作的,工资也是相对比较高。我就下决心想学php了。于是我去找php培训的相关信息,说真的,我也很迷茫,我不知道培训是否真的能像他们宣传的那样好,所以我就想了解一段时间再做打算。
后来,我在网络知道看到一篇让我很鼓舞的文章是一个php高手介绍没有基础的朋友怎么自学入门学php,文章写的很好,包含了如何学习,该怎么学习。他提到一个方法就是看视频,因为看书实在太枯燥和费解的,很多我们也看不懂。这点我真的很认同,我自己看书往往看不了几页。
我在想,为什么别人都能自学成才,我也可以的!我要相信自己,所以我就想自学,如果实在学不会我再去培训。
主意一定,我就去搜索php的视频,虽然零星找到一些php的视频,但是都不系统,我是想找一个能够告诉我该怎么学的视频,一套从入门到精通的视频,一个比较完整的资料,最好能有老师教,不懂可以请教的。
后来我又找到一份很好的视频,是在IT学习联盟推出的一份视频《零基础php就业班》。里面的教程还不错,很完整,还赠送10个顶级企业项目。
下面介绍下我的学习流程,希望对和我一样完全没有基础的朋友有所帮助。
收到他们寄过来的光盘后,我就开始学习了,由于我没有什么基础,我就从最简单的Html/css/javascript视频教程学起,话说简单,其实我还是很多不懂的,只要重复多看几遍,就能看懂。Html/css/javascript我差不多学了一个礼拜,接下来我就学了PHP基础和Mysql数据库,差不多也就三个礼拜。我每天都在不停的写一些简单的代码,这样一月后我基本掌握了php的全部基础。
接下来开始学习php高级课程,老师幽默风趣而又轻松的课堂教课,使我发现原来学习php并不是一件很难的事情。之前我把php基础学得还不错,到了到了php高级部分,我觉不又不是很难,可能老师太牛了,他能把复杂的问题讲的比较通俗易懂,有些难点的地方我还是连续看了五六次,把他弄懂。每天下午6点下班后,吃了饭,马上跑回家。看视频,买了几本笔记本。当时,为了编程还花几百元了台二手的台式电脑,配置一般,但编程是足够的。一边看视频,一边记笔记,把重点都记下来,还一边跟着老师敲代码,为了能尽早学会php。每天都坚持学5-6个小时。经常学到晚上一点多才睡觉。星期六,日不用上班,每天7点多起床,学到晚上11,12点。那段时间特别辛苦,特别累。在学习php的三个多月里,除了吃饭睡觉工作,剩余的时间都在学习,因为我知道自己的计算机基础不是很好,也没有学过什么计算机,相对于那些科班的人来说我要比他们付出更多的努力。我只能咬紧牙关,坚持下去,我不能放弃,我要完成我的梦想,我要让我的家人过上好日子。终于三个多月后我把php教程里的内容和项目都学完了,在学项目的过程中我发现项目特别重要,他能把你学过的知识全部联系起来,能更好的理解你所学的知识。还有学习过程中,动手很重要,要经常跟着老师动手敲,动手吧,跟着做,一行一行的跟着敲,再试着加一些自己的功能,按照自己的思路敲一些代码,收获远比干听大的多。 如果遇到暂时对于一些思路不能理解的,动手写,先写代码,慢慢你就会懂了。这套视频还赠送了10个顶级企业项目,对于我没有任何经验的人来说,这个太重要了,还有在学习项目是提升能力最快的方法。项目能把所有的知识点全都连到一起了,不再是分散的,而是形成一个整体了。那种感觉是仅仅深入钻研知识点而不写真实项目的人所不能体会的。一个项目就是一根绳子可以把大片的知识串到一起。 就这样,我用了两个月也把项目给学完了。其实学完教程差不错就达到就业水平,但是我可能觉得自己学历低还是把那10个顶级企业项目才去找工作。
于是我就到51job疯狂的投简历,因为我学历的问题,专科没有毕业,说真的,大公司没有人会要我,所以我投的都是民营的小公司,我希望自己的努力有所回报。没有想过几天过后,就有面试了,但是第一次面试我失败了,虽然我自认为笔试很好,因为我之前做了准备,但是他们的要求比较严格,需要有一年的项目经验,所以我没有被选中。
后来陆续面试了几家公司,终于功夫不负有心人。我终于面试上的,是在闵行的一家民营的企业,公司规模比较小,我的职务是php开发程序员,但我也比较满足,开的工资是3500一个月,虽然我知道在上海3500只能过温饱的生活,但是我想我足够了。我至少不用每天都要靠父母养,我自己也能养活自己的。我想只要我继续努力,我工资一定会翻倍的。
把本文写出来,希望能让和我一样的没有基础的朋友有信心,其实我们没有必要自卑,我们不比别人笨,只要我们肯努力,我们一样会成功。
…………………………………………………………………………
希望你未来成为出色的php工程师。
⑵ PHP+MySQL锷ㄦ佺绣椤佃捐$紪杈戞帹钻
鍒樼嬭强鍜屽垬涔︿鸡钖堣宪镄勚奥eb缂栫▼鎶链钬斺摈HP+MySQL锷ㄦ佺绣椤佃捐°嬫槸涓链璇﹀敖镄勬暀绋嬶纴鍒嗕负10涓绔犺妭銆傞7绔犳兜鐩栦简Web绋嫔簭璁捐$殑锘虹鐭ヨ瘑锛屽傚备綍鏋勫缓PHP锷ㄦ乄eb鐜澧冿纴PHP绋嫔簭璁捐″熀纭锛孧ySQL鏁版嵁搴撶殑鍏ラ棬锛屼互鍙娄汉链轰氦浜掑拰浼氲瘽鎶链銆傝繖浜涚珷鑺备互瀛︾敓阃夎剧郴缁熶负渚嬶纴浣胯昏呰兘澶熸繁鍏ョ悊瑙i夎剧郴缁熷紑鍙戠殑鍏ㄨ繃绋嫔拰璁捐$悊蹇碉纴阃氲繃瀹炶返鎺屾彙鍏抽敭鎶鑳姐
绗8镊10绔犲垯杞钖戞洿瀹为檯镄勫簲鐢锛屽寘𨰾缃戠珯璁℃暟鍣ㄧ殑鍒朵綔锛屽姩镐佺绣椤典笌鏂伴椈鍙戝竷绯荤粺镄勭粨钖堬纴浠ュ强缃戠粶钥冭瘯绯荤粺镄勫紑鍙戯纴杩欎簺閮芥槸鐩鍓岖绣绔栾捐′腑甯歌佺殑锷熻兘銆傝繖浜涘疄渚嬬揣瀵嗙粨钖埚︾敓镄勫疄闄呴渶姹傦纴鏄扑簬鐞呜В鍜屽疄璺碉纴链夊姪浜庢彁鍗囧疄闄呴”鐩寮鍙戣兘锷涖
⑶ PHP学习手册的目 录
第一篇 基础篇
第1章 了解PHP 18
1.1 什么是PHP 19
1.2 选择PHP的理由 19
1.3 如何学好编程 22
1.4 准备PHP的开发条件 24
1.4.1 下载PHP及相关软件 24
1.4.2 代码编辑工具 24
1.4.3 下载PHP用户手册 26
1.5 本章小结 26
第2章 准备开发PHP的条件 27
2.1 AppServ—Windows版PHP集成化安装包 28
2.1.1 用AppServ搭建PHP开发环境 28
2.1.2 测试AppServ是否安装成功 30
2.2 XAMPP—Linux版PHP集成化安装包 31
2.2.1 用XAMPP搭建PHP开发环境 32
2.2.2 在Linux操作系统下启动、停止XAMPP 33
2.2.3 设置Linux版XAMPP中MySQL数据库root用户的密码 33
2.2.4 在Linux操作系统下编写第一个PHP程序 33
2.3 PHP开发环境的关键配置信息 34
2.3.1 Apache服务器的基本配置 34
2.3.2 PHP.INI文件的基本配置 35
2.4 解决PHP的常见配置问题 36
2.4.1 解决Apache服务器端口冲突 36
2.4.2 更改Apache服务器
默认存储的文件路径 36
2.4.3 在PHP.INI文件中更改上传文件的大小 37
2.4.4 增加PHP扩展模块 37
2.4.5 检测PHP是否支持MySQL数据库 38
2.5 Dreamweaver开发工具 38
2.5.1 情景应用一——Dreamweaver中编码格式的选择 38
2.5.2 情景应用二——Dreamweaver创建表格 39
2.5.3 情景应用三——Dreamweaver创建表单 43
2.5.4 情景应用四——Dreamweaver创建站点 45
2.5.5 情景应用五——Dreamweaver创建第一个PHP程序 46
2.6 本章小结 47
第3章 了解Web页面的设计 48
3.1 XHTML基础 49
3.1.1 XHTML语言的语法 49
3.1.2 XHTML文件的结构 51
3.1.3 编辑文字版面 53
3.1.4 插入图像与链接 55
3.1.5 编写XHTML表格 57
3.1.6 设计XHTML表单 58
3.1.7 情景应用一——编写用户注册信息页 61
3.1.8 情景应用二:文件域上传文件 62
3.2 CSS样式应用 63
3.2.1 将CSS样式嵌入到HTML中 63
3.2.2 CSS选择符 65
3.2.3 常见的CSS样式属性 67
3.2.4 情景应用——打造经典的导航栏 72
3.3 设计页面布局 74
3.3.1 <div>和<span>标记 74
3.3.2 区块模型 74
3.3.3 区块浮动 75
3.3.4 情景应用——设置一行两列浮动布局 77
3.4 实战练习 78
3.4.1 CSS+DIV设计网站首页 78
3.4.2 DIV标签设计论坛后台管理页面 79
3.5 本章小结 81
第4章 PHP开发基础 82
4.1 PHP的工作原理 83
4.2 学习运用代码注释 83
4.2.1 使用PHP注释 84
4.2.2 使用HTML注释 84
4.2.3 有效使用注释 85
4.3 PHP的常量应用 85
4.3.1 声明和使用常量 85
4.3.2 预定义常量 87
4.4 PHP的变量应用 88
4.4.1 理解变量 88
4.4.2 声明变量 88
4.4.3 变量作用域 89
4.4.4 可变变量 91
4.5 PHP的数据类型 92
4.5.1 标量数据类型 92
4.5.2 复合数据类型 96
4.5.3 特殊数据类型 97
4.5.4 转换数据类型 98
4.5.5 检测数据类型 100
4.6 PHP的运算符 101
4.6.1 算术运算符 101
4.6.2 字符串运算符 102
4.6.3 赋值运算符 102
4.6.4 位运算符 103
4.6.5 递增或递减运算符 103
4.6.6 逻辑运算符 104
4.6.7 比较运算符 105
4.6.8 三元运算符 105
4.6.9 运算符的使用规则 106
4.7 PHP的自定义函数 107
4.7.1 定义和调用函数 108
4.7.2 在函数间传递参数 109
4.7.3 函数的返回值 110
4.8 实战练习 111
4.8.1 网站中最新动态模块的中文字符串截取 111
4.8.2 论坛发布内容模块中对内容的格式化输出 112
4.9 本章小结 113
第5章 PHP流程控制语句 115
5.1 程序三种控制结构 116
5.1.1 顺序结构 116
5.1.2 选择(分支)结构 116
5.1.3 循环结构 116
5.2 条件控制语句 117
5.2.1 if条件控制语句 117
5.2.2 switch多分支语句 119
5.2.3 情景应用一——if语句判断美女征婚条件 121
5.2.4 情景应用二——switch网页框架 122
5.3 循环控制语句 123
5.3.1 while循环语句 124
5.3.2 do...while循环语句 124
5.3.3 for循环语句 125
5.3.4 foreach循环语句 127
5.3.5 情景应用一——while语句循环读取数据库中数据 128
5.3.6 情景应用二——for循环语句开发一个乘法口诀表 129
5.4 跳转语句 130
5.4.1 break跳转语句 130
5.4.2 continue跳转语句 131
5.4.3 return跳转语句 132
5.5 包含语句 133
5.5.1 include()语句 133
5.5.2 require()语句 134
5.5.3 include_once()语句 135
5.5.4 require_once()语句 135
5.5.5 include()语句和require()语句的区别 136
5.5.6 include_once()语句和require_once()语句的区别 138
5.6 实战练习 138
5.6.1 删除数据库中指定的数据表 138
5.6.2 for循环语句实现多图片上传 139
5.7 本章小结 140
第6章 字符串操作 141
6.1 初识字符串 142
6.2 转义、还原字符串 142
6.3 截取字符串 143
6.4 分割、合成字符串 145
6.5 替换字符串 146
6.5.1 str_ireplace()函数 146
6.5.2 substr_replace()函数 148
6.6 检索字符串 148
6.6.1 strstr()函数 148
6.6.2 substr_count()函数 149
6.7 去掉字符串首尾空格和特殊字符 150
6.7.1 ltrim()函数 150
6.7.2 rtrim()函数 151
6.7.3 trim()函数 152
6.8 字符串与HTML转换 152
6.9 情景应用 154
6.9.1 超长文本的分页输出 154
6.9.2 查询关键字描红 155
6.9.3 购物车中数据的读取 156
6.10 实战练习 157
6.10.1 PHP 5新型字符串输出XML数据信息 157
6.10.2 图像验证码的相关操作 158
6.11 本章小结 159
第7章 正则表达式 160
7.1 什么是正则表达式 161
7.2 正则表达式的语法规则 162
7.2.1 行定位符(^和$) 162
7.2.2 单词定界符(、B) 162
7.2.3 字符类([ ]) 163
7.2.4 选择字符(|) 163
7.2.5 连字符(-) 163
7.2.6 排除字符([^]) 164
7.2.7 限定符(? * + {n,m}) 164
7.2.8 点号字符(.) 164
7.2.9 转义字符() 165
7.2.10 反斜线() 165
7.2.11 括号字符(()) 166
7.2.12 情景应用一——整合实用的正则表达式 166
7.2.13 情景应用二——调用正则表达式验证中文 168
7.3 PCRE兼容正则表达式函数 169
7.3.1 字符串的匹配与查找 169
7.3.2 情景应用一——应用正则表达式匹配电话号码格式 170
7.3.3 字符串的替换 172
7.3.4 情景应用二——应用正则表达式实现UBB使用帮助 173
7.3.5 字符串的分割 173
7.4 实战练习 174
7.4.1 正则表达式验证用户
7.4.1 注册信息的合理性 174
7.4.2 正则表达式验证提交的
7.4.1 购买数量是否是正整数 176
7.5 本章小结 177
第8章 初探数组 178
8.1 数组概述 179
8.2 数组类型 179
8.3 声明数组 180
8.3.1 用户创建数组 180
8.3.2 函数创建数组 181
8.3.3 创建二维数组 181
8.4 遍历、输出数组 182
8.4.1 遍历数组 183
8.4.2 输出数组元素 184
8.5 PHP的数组函数 185
8.5.1 统计数组元素个数 185
8.5.2 向数组中添加元素 185
8.5.3 获取数组中最后一个元素 186
8.5.4 删除数组中重复元素 186
8.5.5 获取数组中指定元素的键名 186
8.5.6 字符串与数组的转换 187
8.5.7 情景应用——读取网上调查中的数据 188
8.6 PHP的全局数组 189
8.6.1 $_SERVER[ ]全局数组 189
8.6.2 $_GET[ ]和$_POST[ ]全局数组 190
8.6.3 $_COOKIE全局数组 190
8.6.4 $_ENV[ ]全局数组 191
8.6.5 $_REQUEST[ ]全局数组 191
8.6.6 $_SESSION[ ]全局数组 191
8.6.7 $_FILES[ ]全局数组 191
8.6.8 情景应用——$_FILES[ ]全局数组在文件上传中的应用 191
8.7 实战练习 193
8.7.1 生成在线考试题 193
8.7.2 通过获取客户端IP地址限制投票次数 193
8.8 本章小结 195
第9章 日期与时间 196
9.1 PHP的时间观念 197
9.1.1 在PHP.INI文件中设置时区 197
9.1.2 通过date_default_timezone_set函数设置时区 197
9.2 UNIX时间戳 198
9.2.1 获取任意日期、时间的时间戳 198
9.2.2 获取当前时间戳 199
9.2.3 日期、时间转换为UNIX时间戳 199
9.3 日期和时间处理 201
9.3.1 格式化日期和时间 201
9.3.2 获取日期和时间信息 202
9.3.3 检验日期和时间的有效性 203
9.4 情景应用 204
9.4.1 获取系统当前时间和时间戳 204
9.4.2 比较两个时间的大小 204
9.4.3 倒计时 205
9.5 实战练习 205
9.5.1 计算程序的运行时间 205
9.5.2 网页闹钟 206
9.6 本章小结 207
第二篇 核心篇
第10章 文件和目录处理技术 210
10.1 基本的文件处理技术 211
10.1.1 打开一个文件 211
10.1.2 读取文件内容 214
10.1.3 向文件中写入数据 218
10.1.4 关闭文件指针 220
10.2 目录操作技术 220
10.2.1 打开指定目录 220
10.2.2 读取目录结构 221
10.2.3 关闭目录指针 222
10.3 文件的上传技术 223
10.3.1 开启文件上传功能 223
10.3.2 全局变量$_FILES应用 224
10.3.3 将上传文件移动到指定目录 225
10.3.4 文件下载技术 226
10.4 情景应用 227
10.4.1 通过文本文件统计网站访问量 227
10.4.2 规范化的文件上传 229
10.5 实战练习 231
10.5.1 从文本文件中读取注册服务条款 231
10.5.2 规范化的多文件上传 232
10.6 本章小结 233
第11章 图形图像处理技术 234
11.1 了解GD2函数库 235
11.2 设置GD2函数库 235
11.3 学习常用的图像处理技术 235
11.3.1 创建画布 236
11.3.2 颜色处理 237
11.3.3 绘制文字 237
11.3.4 输出图像 239
11.3.5 销毁图像 240
11.3.6 情景应用一——在照片上书写文字 240
11.3.7 情景应用二——GD2函数生成图像验证码 241
11.4 运用Jpgraph类库绘制图像 242
11.4.1 Jpgraph类库简介 242
11.4.2 Jpgraph的安装 242
11.4.3 情景应用一——柱状图展示2010年第一季度编程词典销量 243
11.4.4 情景应用二——折线图分析2010年公司销售额 245
11.4.5 情景应用三——多饼形图分析2010年图书销量 246
11.5 实战练习 248
11.5.1 GD2函数生成带有干扰线的图像验证码 248
11.5.2 Jpgraph创建折线图分析图书销售走势 249
11.5.3 Jpgraph创建3D饼形图展示部门业绩比较 250
11.6 本章小结 251
第12章 Cookie和会话控制 252
12.1 会话的操作 253
12.1.1 创建会话 253
12.1.2 配置PHP的会话 255
12.2 会话的高级应用 259
12.2.1 SESSION临时文件 259
12.2.2 SESSION缓存 259
12.2.3 SESSION数据库存储 261
12.3 Cookie的操作 263
12.3.1 设置Cookie 264
12.3.2 访问Cookie 265
12.3.3 删除Cookie 266
12.4 情景应用 267
12.4.1 登录验证 267
12.4.2 Cookie自动登录 269
12.5 实战练习 270
12.5.1 防止页面刷新 270
12.5.2 控制客户端Cookie 271
12.6 本章小结 272
第13章 面向对象 273
13.1 一切皆是对象 274
13.1.1 什么是类 274
13.1.2 对象的由来 274
13.1.3 面向对象的特点 275
13.2 类的声明 275
13.2.1 类的定义 275
13.2.2 成员属性 276
13.2.3 成员方法 277
13.3 类的实例化 277
13.3.1 创建对象 278
13.3.2 访问类中成员 278
13.3.3 特殊的访问方法——“$this”和“::” 279
13.3.4 构造方法和析构方法 280
13.4 面向对象的封装特性 281
13.4.1 public(公共成员) 282
13.4.2 private(私有成员) 282
13.4.3 protected(保护成员) 283
13.5 面向对象的继承特性 283
13.5.1 类的继承——extends关键字 283
13.5.2 类的继承——parent::关键字 284
13.5.3 覆盖父类方法 285
13.6 抽象类和接口 286
13.6.1 抽象类 286
13.6.2 接口 287
13.7 面向对象的多态性 289
13.7.1 通过继承实现多态 289
13.7.2 通过接口实现多态 290
13.8 面向对象的关键字 290
13.8.1 final关键字 291
13.8.2 static关键字——声明静态类成员 291
13.8.3 clone关键字——克隆对象 292
13.8.4 对象比较 293
13.8.5 instanceof关键字——对象类型检测 293
13.9 面向对象的魔术方法 293
13.9.1 _set()和_get()方法 294
13.9.2 _isset()和_unset()方法 294
13.9.3 _call()方法 294
12.9.4 _toString()方法 295
13.9.5 _autoload()方法 295
13.9.6 情景应用一——封装一个数据库连接类 296
13.9.7 情景应用二——封装一个数据库操作类 297
13.10 实战练习 298
13.10.1 分页类 299
13.10.2 万用表格 300
13.11 本章小结 301
第14章 MySQL数据库设计 302
14.1 MySQL概述 303
14.1.1 MySQL的特点 303
14.1.2 SQL和MySQL 303
14.2 MySQL服务器的启动和关闭 304
14.2.1 启动MySQL服务器 304
14.2.2 连接MySQL服务器 305
14.2.3 关闭MySQL服务器 305
14.3 操作MySQL数据库 306
14.3.1 创建新数据库 306
14.3.2 选择指定数据库 306
14.3.3 删除指定数据库 306
14.4 操作MySQL数据表 307
14.4.1 创建一个表 307
14.4.2 查看数据表结构 308
14.4.3 修改数据表结构 309
14.4.4 重命名数据表 310
14.4.5 删除指定数据表 310
14.5 操作MySQL数据 311
14.5.1 向数据表中添加数据(INSERT) 311
14.5.2 更新数据表中数据(UPDATE) 312
14.5.3 删除数据表中数据(DELETE) 312
14.5.4 查询数据表中数据 313
14.5.5 情景应用一——数据排序 316
14.5.6 情景应用二——limit控制输出数据的开始位置和记录数 316
14.6 MySQL数据类型 316
14.6.1 数字类型 317
14.6.2 字符串类型 317
14.6.3 日期和时间数据类型 319
14.7 用phpMyAdmin管理MySQL数据库 319
14.7.1 管理数据库 319
14.7.2 管理数据表 320
14.7.3 管理数据记录 322
14.7.4 导入/导出数据 324
14.8 实战练习 325
14.8.1 批量添加记录(LOAD DATA和MYSQLIMPORT) 325
14.8.2 在phpMyAdmin中重置MySQL服务器登录密码 326
14.9 本章小结 326
第15章 数据库编程技术 327
15.1 PHP操作MySQL数据库的步骤 328
15.2 PHP操作MySQL数据库的方法 329
15.2.1 mysql_connect()函数连接MySQL服务器 329
15.2.2 mysql_select_db()函数选择MySQL数据库 330
15.2.3 mysql_query()函数执行SQL语句 330
15.2.4 mysql_fetch_array()函数将结果集返回到数组中 331
15.2.5 mysql_fetch_row()函数从结果集中获取一行作为枚举数组 333
15.2.6 mysql_num_rows()函数获取查询结果集中的记录数 333
15.3 管理MySQL数据库中的数据 334
15.3.1 向数据库中添加数据 334
15.3.2 编辑数据库数据 335
15.3.3 从数据库中删除数据 336
15.3.4 批量数据操作 336
15.4 情景应用 337
15.4.1 通用查询 337
15.4.2 分组统计 338
15.4.3 对查询结果分页显示 339
15.4.4 站内搜索 340
15.5 实战练习 341
15.5.1 对查询结果进行跳转分页显示 341
15.5.2 高级查询 341
15.6 本章小结 342
第三篇 高级篇
第16章 PDO数据库抽象层 346
16.1 什么是PDO 347
16.1.1 PDO概述 347
16.1.2 PDO特点 347
16.1.3 安装PDO 347
16.2 PDO连接数据库 348
16.2.1 PDO构造函数 348
16.2.2 情景应用一——连接MySQL数据库 348
16.2.3 情景应用二——连接MS SQL Server数据库 349
16.2.4 情景应用三——连接Oracle数据库 350
16.3 PDO中执行SQL语句 350
16.3.1 exec()方法 351
16.3.2 query()方法 351
16.3.3 预处理语句——prepare()和execute() 352
16.3.4 情景应用一——通过PDO向数据库中添加数据 353
16.3.5 情景应用二——通过PDO更新数据库中数据 354
16.4 PDO中获取结果集 355
16.4.1 fetch()方法 355
16.4.2 fetchAll()方法 357
16.4.3 fetchColumn()方法 358
16.5 PDO中捕获SQL语句中的错误 359
16.5.1 使用默认模式——PDO::ERRMODE_SILENT 359
16.5.2 使用警告模式——PDO::ERRMODE_WARNING 360
16.5.3 使用异常模式——PDO::ERRMODE_EXCEPTION 361
16.6 PDO中错误处理 362
16.6.1 errorCode()方法 362
16.6.2 errorInfo()方法 363
16.7 PDO中事务处理 364
16.8 PDO中存储过程 366
16.9 实战练习 367
16.9.1 PDO读取MS SQL Server数据库中数据 367
16.9.2 PDO读取Oracle数据库中数据 368
16.10 本章小结 369
第17章 ADODB数据库抽象层 370
17.1 ADODB概述 371
17.1.1 ADODB的优点与缺点 371
17.1.2 ADODB的安装与操作流程 371
17.2 连接数据库系统和数据库 372
17.2.1 连接数据库系统——ADONewConnection()函数 372
17.2.2 数据库持久化连接——PConnect()函数 372
17.2.3 数据库非持久化连接——Connect()函数 372
17.2.4 情景应用一——ADODB连接MySQL数据库 373
17.2.5 情景应用二——ADODB连接Access数据库 374
17.2.6 情景应用三——ADODB连接MS SQL Server数据库 374
17.2.7 情景应用四——ADODB连接Oracle数据库 375
17.3 通过公共变量控制数据的存取方式 376
17.4 ADODB执行SQL语句 377
17.4.1 执行SQL语句——execute()函数 377
17.4.2 控制SELECT查询语句的起始位置——SelectLimit()函数 378
17.4.3 添加、更新数据——GetInsertSQL()、GetUpdateSQL()函数 379
17.4.4 操作SQL语句的其他方法 380
17.5 ADODB控制结果集 380
17.5.1 控制指针的方法 381
17.5.2 控制结果集内容的方法 382
17.5.3 日期格式和数据类型的转换 383
17.6 ADODB中的分页 384
17.6.1 ADODB分页函数 384
17.6.2 一个小巧的分页函数——ADODB_Pager()函数 385
17.7 ADODB中的错误处理 386
17.7.1 ADODB中的错误处理函数 386
17.7.2 ADODB中自定义的错误处理机制 387
17.7.3 情景应用——通过日志文件存储错误信息 388
17.8 ADODB中的事务处理 389
17.9 实战练习 390
17.9.1 封装ADODB连接数据库类 390
17.9.2 封装ADODB操作数据库类 391
17.9.3 封装ADODB分页类 392
17.9.4 通过事务处理机制保证数据转换的顺利完成 393
17.10 本章小结 395
第18章 PHP的字符编码 396
18.1 了解网页字符编码 397
18.1.1 ASCII 字符集 397
18.1.2 ISO 8859 字符集 397
18.1.3 GB2312与GBK编码 398
18.1.4 Unicode字符集 398
18.1.5 UTF-8编码 398
18.2 PHP网页的字符编码 399
18.2.1 设置编码格式 399
18.2.2 转换编码格式 400
18.2.3 检测字符串的编码 402
18.3 PHP开发中的乱码问题 403
18.3.1 解决页面中的乱码问题 403
18.3.2 数据库中的字符集编码问题 405
18.3.3 避免截取中文字符串时出现乱码 406
18.4 PHP区域化设置 407
18.4.1 PHP网页的区域化 407
18.4.2 使用setlocale()函数设置区域化 408
18.5 实战练习 409
18.5.1 避免截取超长文本时出现乱码 409
18.5.2 了解PHP编码规则 410
18.5.3 了解PHP编码风格 410
18.6 本章小结 412
第19章 程序调试与错误处理 413
19.1 基本调试策略 414
19.2 常见错误分析 414
19.2.1 语法错误 414
19.2.2 定义错误 417
19.2.3 逻辑错误 418
19.2.4 运行错误 419
19.2.5 环境错误 421
19.3 PHP.INI中的错误处理机制 422
19.3.1 控制错误显示及显示方式 423
19.3.2 控制错误的级别 423
19.4 程序调试方法 424
19.4.1 应用DIE语句调试 424
19.4.2 应用mysql_error()语句输出错误信息 425
19.4.3 应用try{}catch{}M语句抛出并捕获异常 425
19.5 错误处理技巧 427
19.5.1 隐藏错误 427
19.5.2 自定义错误页面 427
19.5.3 延长服务器执行时间——处理超时错误 428
19.6 情景应用 429
19.6.1 如何分析、解决PHP与MySQL连接错误 429
19.6.2 解决数据库乱码问题 431
19.7 实战练习 432
19.7.1 封装属于自己的异常处理类 432
19.7.2 使用错误处理器记录日志 433
19.8 本章小结 434
第20章 Smarty模板技术 435
20.1 走进Smarty模板引擎 436
20.1.1 Smarty模板引擎下载 437
20.1.2 Smarty模板引擎安装 437
20.1.3 Smarty模板引擎配置 437
20.1.4 情景应用一——走进Smarty模板引擎 439
20.1.5 情景应用二——封装Smarty模板的配置方法 440
20.2 Smarty模板设计——静态页处理 442
20.2.1 基本语法(注释、函数和属性) 442
20.2.2 Smarty模板设计变量 443
20.2.3 变量调节器 444
20.2.4 情景应用一——Smarty模板中日期、时间的格式化输出 445
20.2.5 情景应用二——通过组合修改器分隔多个变量调节器 445
20.2.6 内建函数(动态文件、模板文件的包含和流程控制语句) 446
20.2.7 情景应用三——Smarty模板创建网页框架 448
20.2.8 情景应用四——section语句循环输出数据库中的数据 450
20.2.9 自定义函数 451
20.2.10 配置文件 454
20.3 Smarty程序设计——动态文件操作 455
20.3.1 SMARTY_PATH常量 455
20.3.2 Smarty程序设计变量 455
20.3.3 Smarty方法 456
20.3.4 Smarty缓存 456
20.3.5 情景应用——开启网站注册页面的缓存 458
20.4 实战练习 460
20.4.1 Smarty+ADODB完成数据的分页输出 460
20.4.2 Smarty中通过truncate方法截取字符串 461
20.4.3 用Register_Function方法注册模板函数 462
20.4.4 Smarty模板中的关键字描红 464
20.5 本章小结 464
第四篇 实战篇
第21章 企业网站开发模板 466
21.1 明日企业网概述 467
21.2 开发背景 467
21.3 需求分析 467
21.4 功能结构 468
21.5 数据库设计 469
21.5.1 数据库概念设计 469
21.5.2 创建数据库及数据表 470
21.6 技术攻关 471
21.6.1 Smarty模板 471
21.6.2 最简单的网页框架 473
21.6.3 ADODB类库 473
21.6.4 封装分页类 474
21.7 首页设计 475
21.7.1 首页概述 475
21.7.2 首页技术分析 476
21.7.3 首页的实现过程 476
21.8 产品展示设计 478
21.8.1 产品展示概述 478
21.8.2 产品展示技术分析 478
21.8.3 产品展示实现过程 479
21.9 后台管理系统设计 480
21.9.1 后台管理系统概述 481
21.9.2 后台管理系统技术分析 481
21.9.3 后台管理系统实现过程 482
21.10 程序调试与错误处理 486
21.10.1 SQL语句的返回机制 486
21.10.2 错误处理 487
21.11 开发总结 488
附录 专业术语表 489
⑷ 用php开发网站的步骤是什么
想要制作一个PHP开发的网站,那么你就必须熟肢猛晌练掌握了PHP、HTML、数据库各方面知识,以及JavaScript事件处理和开发步骤。
PHP网站开发步骤:
(1)尽量完整的需求方案,具体到功能上:
(2)建模结构UML
(3)建立数据库
1、建立的表名、字段名要与他的功能有关系。
2、根据结构建立数据库表,原则是不定项内容一定要分表。
3、字段类型要考虑内容是否够用就够就好,选择适合的类型INTVarcharDate
(4)设计HTML文件和脚本的实现
根据模和数据库来设计页面是个很科学的方法,当然有的时候有人喜欢根据模型设计页面,数据库基于页面设计,都是可以的。
设计页面时要考虑到每个细节,包括提示消息页知前面,错误页面。
(5)PHP网站源码的书写
1、先建立底层结构和文件夹(如果是大型的网站同样设计一个文件UMML)
2、历锋基础功能分类关联,以便今后代码引用。
3、代码的书写,注意简洁性和函数的使用,内部函数能实现的尽量使用内部函数。
4、在部分关键位置加以代码注释。
(6)程序的测试和修正
1、对于发现的BUG不能就解决BUG而解决,要处于完整程序考虑。避免收之东隅收之桑榆。
2、对于解决过的BUG已经要详细记录,以便日后更新。
PHP是一种非常流行的网站开发语言,至少从取得广泛应用这方面看是这样的。肯定有某种原因让它如此流行,再者,PHP入门比较快,功能较之其他语言不遑多让。想参加PHP培训学习在这里推荐教程视频为主的六星教育,知识点对应案例教学,零基础PHP入门到精通全栈视频教程。
⑸ PHP 新手该如何学习使用开发框架,有案例吗
关于PHP 新手该如何学习使用开发框架,有案例吗,我有下面的观点。
掌握基本的WEB开发思想和技术,以及设计模式,为日后学习php打下坚实的基础!
知识:本课程分为两部分,第一部分介绍了JSON的基本知识,第二部分通过两个真实案例加深对JSON的理解,并在实际场景中使用JSON演示。
处理电子商务网站的后台开发:
知识:本系统由web电子商务系统需求分析、数据表设计、后台模块实现、如何设置电子商务系统。
⑹ PHP入门基础教程
PHP入门基础教程大全
PHP于1994年由Rasmus Lerdorf创建,刚刚开始是Rasmus Lerdorf为了要维护个人网页而制作的一个简单的用Perl语言编写的程序。这些工具程序用来显示 Rasmus Lerdorf 的个人履历,以及统计网页流量。后来又用C语言重新编写,包括可以访问数据库。他将这些程序和一些表单直译器整合起来,称为 PHP/FI。PHP/FI 可以和数据库连接,产生简单的动态网页程序。为帮助大家入门学习php,我为大家分享PHP入门知识教程如下:
1、嵌入方法:
类似ASP的<%,PHP可以是<?php或者是<?,结束符号是?>,当然您也可以自己指定。
2、引用文件:
引用文件的方法有两种:require 及 include。
require 的使用方法如 require("MyRequireFile.php"); 。这个函数通常放在 PHP 程序的最前面,PHP 程序在执行前,就会先读入 require 所指定引入的文件,使它变成 PHP 程序网页的一部份。常用的函数,亦可以这个方法将它引入网页中。
include 使用方法如 include("MyIncludeFile.php"); 。这个函数一般是放在流程控制的处理部分中。PHP 程序网页在读到 include 的文件时,才将它读进来。这种方式,可以把程序执行时的流程简单化。
3、注释方法:
<?php
echo "这是第一种例子。 " ; // 本例是 C++ 语法的注释 (PHP的注释跟C差不多!)
/* 本例采用多行的
注释方式 */
echo "这是第二种例子。 " ;
echo "这是第三种例子。 " ; # 本例使用 UNIX Shell 语法注释
?>
4、变量类型:
$mystring = "我是字符串" ;
$NewLine = "换行了 " ;
$int1 = 38 ;
$float1 = 1.732 ;
$float2 = 1.4E+2 ;
$MyArray1 = array( "子" , "丑" , "寅" , "卯" );
这里引出两个问题,首先PHP变量以$开头,第二PHP语句以;结尾,可能ASP程序员会不适应。这两个遗漏也是程序上大多错误所在。
5、运算符号:
数**非法字眼已被屏蔽**算:
符号 意义
+ 加法运算
- 减法运算
* 乘法运算
/ 除法运算
% 取余数
++ 累加
-- 递减
字符串运算:
运算符号只有一个,就是英文的句号。它可以将字符串连接起来,变成合并的新字符串。类似ASP中的&
<?
$a = "PHP 4" ;
$b = "功能强大" ;
echo $a.$b;
?>
这里也引出两个问题,首先PHP中输出语句是echo,第二类似ASP中的<%=变量%>,PHP中也可以<?=变量?>。
逻辑运算:
符号 意义
< 小于
> 大于
<= 小于或等于
>= 大于或等于
== 等于
!= 不等于
&& 而且 (And)
and 而且 (And)
或者 (Or)
or 或者 (Or)
xor 异或 (Xor)
! 不 (Not)
学习目的:掌握php的流程控制
1、if..else 循环有三种结构
第一种是只有用到 if 条件,当作单纯的判断。解释成 "若发生了某事则怎样处理"。语法如下:
if (expr) { statement }
其中的 expr 为判断的条件,通常都是用逻辑运算符号当判断的条件。而 statement 为符合条件的执行部分程序,若程序只有一行,可以省略大括号 {}。
范例:本例省略大括号。
<?php
if ($state==1)echo "哈哈" ;
?>
这里特别注意的是,判断是否相等是==而不是=,ASP程序员可能常犯这个错误,= 是赋值。
范例:本例的执行部分有三行,不可省略大括号。
<?php
if ($state==1) {
echo "哈哈 ;
echo "<br>" ;
}
?>
第两种是除了 if 之外,加上了 else 的条件,可解释成 "若发生了某事则怎样处理,否则该如何解决"。语法如下
if (expr) { statement1 } else { statement2 } 范例:上面的例子来修改成更完整的处理。其中的 else 由于只有一行执行的指令,因此不用加上大括号。
<?php
if ($state==1) {
echo "哈哈" ;
echo "<br>";
}
else{
echo "呵呵";
echo "<br>";
}
?>
第三种就是递归的 if..else 循环,通常用在多种决策判断时。它将数个 if..else 拿来合并运用处理。
直接看下面的例子
<?php
if ( $a > $b ) {
echo "a 比 b 大" ;
} elseif ( $a == $b ) {
echo "a 等于 b" ;
} else {
echo "a 比 b 小" ;
}
?>
上例只用二层的 if..else 循环,用来比较 a 和 b 两个变量。实际要使用这种递归 if..else 循环时,请小心使用,因为太多层的循环容易使设计的逻辑出问题,或者少打了大括号等,都会造成程序出现莫名其妙的问题。
2、 for 循环就单纯只有一种,没有变化,它的语法如下
for (expr1; expr2; expr3) { statement }
其中的 expr1 为条件的`初始值。expr2 为判断的条件,通常都是用逻辑运算符号 (logical operators) 当判断的条件。expr3 为执行 statement 后要执行的部份,用来改变条件,供下次的循环判断,如加一..等等。而 statement 为符合条件的执行部分程序,若程序只有一行,可以省略大括号 {}。
下例是用 for 循环写的的例子。
<?php
for ( $i = 1 ; $i <= 10 ; $i ++) {
echo "这是第".$i."次循环<br>" ;
}
?>
3、 switch 循环,通常处理复合式的条件判断,每个子条件,都是 case 指令部分。在实作上若使用许多类似的 if 指令,可以将它综合成 switch 循环。
语法如下
switch (expr) { case expr1: statement1; break; case expr2: statement2; break; default: statementN; break; }
其中的 expr 条件,通常为变量名称。而 case 后的 exprN,通常表示变量值。冒号后则为符合该条件要执行的部分。注意要用 break 跳离循环。
<?php
switch ( date ( "D" )) {
case "Mon" :
echo "今天星期一" ;
break;
case "Tue" :
echo "今天星期二" ;
break;
case "Wed" :
echo "今天星期三" ;
break;
case "Thu" :
echo "今天星期四" ;
break;
case "Fri" :
echo "今天星期五" ;
break;
default:
echo "今天放假" ;
break;
}
?>
这里需要注意的是break;别遗漏了,default,省略是可以的。
很明显的,上述的例子用 if 循环就很麻烦了。当然在设计时,要将出现机率最大的条件放在最前面,最少出现的条件放在最后面,可以增加程序的执行效率。上例由于每天出现的机率相同,所以不用注意条件的顺序。
学会构建数据库
在PHP中,MY SQL的命令行编辑可能会令初学者感到很麻烦,不要紧,你下载一个PHPMYADMIN安装一下,以后建立编辑数据库可以靠它了。
下面说一下它的使用。
进入了phpmyadmin后,我们首先需要建立一个数据库,
Language (*) 这里选择中文简体,然后在左边的 创建一个新的数据库 这里填写数据库名字,点击创建即可。
然后在左边下拉菜单中选择那个已经创建的数据库。在下面的
在数据库 shop 中创建一个新表 :
名字 :
字段数 :
中填写表名字和大致你认为的字段数(不够或者多了都不要紧,以后可以再添加或者缺省),按执行。
然后就可以开始建立表了。
第一栏是字段的名字;第二栏选择字段类型:
我们常用的是以下几个:
1)VARCHAR,文本类型
2)INT,整数类型
3)FLOAT,浮点数类型
4)DATE,日期型
5)大家或许会问,自动添加的ID在哪里?这个只要选择INT类型,在后面的额外中选择 auto_increment 就可以了。
建立了表以后,可以在左边看到你建立的表,点击以后,你可以:
1)按右边的结构:查看修改表结构
2)按右边的浏览:查看表中的数据
3)按右边的SQL:运行SQL语句
4)按右边的插入:插入一行记录
5)按右边的清空:删除表中所有记录
6)按右边的删除:删除表
还有一个很重要的功能就是导入和导出,当我们本机做好了程序和数据库的时候,需要在服务器上也有一个本地镜像,如果是ASP的ACCESS简单了,直接上传MDB文件即可,如果是SQL SERVER也可以连接远端服务器进行导入。那么MY SQL中你可以导出所有的SQL语句,到了远端服务器的PHPMYADMIN上,创建数据库后按SQL,粘帖你刚才复制下来的所有本级生成的SQL语句即可。
学会连接数据库
PHP简直就是一个函数库,丰富的函数使PHP的某些地方相当简单。建议大家down一本PHP的函数手册,总用的到。
我这里就简单说一下连接MYSQL数据库。
1、mysql_connect
打开 MySQL 服务器连接。
语法: int mysql_connect(string [hostname] [:port], string [username], string [password]); 返回值: 整数
本函数建立与 MySQL 服务器的连接。其中所有的参数都可省略。当使用本函数却不加任何参数时,参数 hostname 的默认值为 localhost、参数 username 的默认值为 PHP 执行行程的拥有者、参数 password 则为空字符串 (即没有密码)。而参数 hostname 后面可以加冒号与端口号,代表使用哪个端口与 MySQL 连接。当然在使用数据库时,早点使用 mysql_close() 将连接关掉可以节省资源。
2、 mysql_select_db
选择一个数据库。
语法: int mysql_select_db(string database_name, int [link_identifier]); 返回值: 整数
本函数选择 MySQL 服务器中的数据库以供之后的资料查询作业 (query) 处理。成功返回 true,失败则返回 false。
最简单的例子就是:
$conn=mysql_connect ("127.0.0.1", "", "");
mysql_select_db("shop");
连接机MY SQL数据库,打开SHOP数据库。在实际应用中应当加强点错误判断。
学会读取数据
先看两个函数:
1、mysql_query
送出一个 query 字符串。 语法: int mysql_query(string query, int [link_identifier]); 返回值: 整数
本函数送出 query 字符串供 MySQL 做相关的处理或者执行。若没有指定 link_identifier 参数,则程序会自动寻找最近打开的 ID。当 query 查询字符串是 UPDATE、INSERT 及 DELETE 时,返回的可能是 true 或者 false;查询的字符串是 SELECT 则返回新的 ID 值,当返回 false 时,并不是执行成功但无返回值,而是查询的字符串有错误。
2、mysql_fetch_object 返回类资料。 语法: object mysql_fetch_object(int result, int [result_typ]); 返回值: 类
本函数用来将查询结果 result 拆到类变量中。若 result 没有资料,则返回 false 值。
看一个简单的例子:
<?
$exec="select * from user";
$result=mysql_query($exec);
while($rs=mysql_fetch_object($result))
{
echo "username:".$rs->username."<br>";
}
?>
当然,表user中有一个username的字段,这就类似asp中的
<%
exec="select * from user"
set rs=server.createobject("adodb.recordset")
rs.open exec,conn,1,1
do while not rs.eof
response.write "username:"&rs("username")&"<br>"
rs.movenext
loop
%>
当然先要连接数据库,一般我们 require_once('conn.php');而conn.php里面就是上一次说的连接数据库的代码。
小小的两条命令可以完成读取数据的工作了
学会添加删除修改数据
mysql_query($exec);
单这个语句就可以执行所有的操作了,不同的就是$exec这个sql语句
添加:$exec="insert into tablename (item1,item2) values ('".$_POST['item1']."',".$_POST['item1'].")";
删除:$exec="delete from tablename where...";
修改:$exec="update tablename set item1='".$_POST['item1']."' where ...";
说到这里就要说一下表单和php变量传递,如果表单中的一个 <input name="item1" type="text" id="item1">
表单以POST提交的,那么处理表单文件就可以用$_POST['item1']得到变量值,同样以GET提交的就是$_GET['item1']
是不是很简单?但是通常$exec会有问题,因为可能您的SQL语句会很长,您会遗漏.连接符,或者'来包围字符型字段。
我们可以注释mysql_query($exec);语句用echo $exec;代替来输出$exec以检查正确性。如果您还不能察觉$exec有什么错误的话,可以复制这个sql语句到phpmyadmin中执行,看看它的出错信息。还有需要注意的是,我们不要使用一些敏感的字符串作为字段名字,否则很可能会出现问题,比如说date什么的。变量的命名,字段的命名遵循一点规律有的时候对自己是一种好处,初学者并不可忽视其重要性。
学会SESSION的使用
SESSION的作用很多,最多用的就是站点内页面间变量传递。
在页面开始我们要session_start();开启SESSION;
然后就可以使用SESSION变量了,比如说要赋值就是:$_SESSION['item']="item1";要得到值就是$item1=$_SESSION['item'];,很简单吧。这里我们可能会使用到一些函数,比如说判断是不是某SESSION变量为空,可以这么写:empty($_SESSION['inum'])返回true or false。
下面综合一下前面所说的我们来看一个登陆程序,判断用户名密码是否正确。
登陆表单是这样:login.php
<table width="100%" height="100%" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<form action="checklogin.php" method="post"><td align="center" valign="middle"><table width="400" border="0" cellpadding="5" cellspacing="1" class="tablebg">
<tr class="tdbg">
<td colspan="2"><p align="center">Administrators Login</p></td>
</tr>
<tr class="tdbg">
<td><p align="center">Username</p></td>
<td><p align="center">
<input name="username" type="text" id="username">
</p></td>
</tr>
<tr class="tdbg">
<td><p align="center">Password</p></td>
<td><p align="center">
<input name="password" type="password" id="password">
</p></td>
</tr>
<tr class="tdbg">
<td colspan="2"><p align="center">
<input type="submit" name="Submit" value="Submit">
<input type="reset" name="Submit2" value="Clear">
</p></td>
</tr>
</table></td></form>
</tr>
</table>
处理文件是这样
<?php
require_once('conn.php');
session_start();
$username=$_POST['username'];
$password=$_POST['password'];
$exec="select * from admin where username='".$username."'";
if($result=mysql_query($exec))
{
if($rs=mysql_fetch_object($result))
{
if($rs->password==$password)
{
$_SESSION['adminname']=$username;
header("location:index.php");
}
else
{
echo "<script>alert('Password Check Error!');location.href='login.php';</script>";
}
}
else
{
echo "<script>alert('Username Check Error!');location.href='login.php';</script>";
}
}
else
{
echo "<script>alert('Database Connection Error!');location.href='login.php';</script>";
}
?>
conn.php是这样:
<?php
$conn=mysql_connect ("127.0.0.1", "", "");
mysql_select_db("shop");
?>
由于 $_SESSION['adminname']=$username;我们可以这样写验证是否登陆语句的文件:checkadmin.php
<?php
session_start();
if($_SESSION['adminname']=='')
{
echo "<script>alert('Please Login First');location.href='login.php';</script>";
}
?>
做一个分页显示
关键就是用到了SQL语句中的limit来限定显示的记录从几到几。我们需要一个记录当前页的变量$page,还需要总共的记录数$num
对于$page如果没有我们就让它=0,如果有<0就让它也=0,如果超过了总的页数就让他=总的页数。
$execc="select count(*) from tablename ";
$resultc=mysql_query($execc);
$rsc=mysql_fetch_array($resultc);
$num=$rsc[0];
这样可以得到记录总数
ceil($num/10))如果一页10记录的话,这个就是总的页数
所以可以这么写
if(empty($_GET['page']))
{
$page=0;
}
else
{
$page=$_GET['page'];
if($page<0)$page=0;
if($page>=ceil($num/10))$page=ceil($num/10)-1;//因为page是从0开始的,所以要-1
}
这样$exec可以这么写 $exec="select * from tablename limit ".($page*10).",10";
//一页是10记录的
最后我们需要做的就是几个连接:
<a href="xxx.php?page=0">FirstPage</a>
<a href="xxx.php?page=<?=($page-1)?>">PrevPage</a>
<a href="xxx.php?page=<?=($page+1)?>">NextPage</a>
<a href="xxx.php?page=<?=ceil($num/10)-1?>">LastPage</a>
注意事项
1、注意不要漏了分号
2、注意不要漏了变量前的$
3、使用SESSION的时候注意不要遗漏session_start();
如果发生错误的时候,可以采用以下方法:
1、如果是SQL语句出错,就注释了然后输出SQL语句,注意也要注释调后续的执行SQL语句
2、如果是变量为空,大多是没有传递到位,输出变量检查一下,检查一下表单的id和name
3、如果是数据库连接出错,检查是否正确打开MY SQL和是否遗漏了连接语句
4、注意缩进,排除括号不区配的错误
在做大网站的时候,我的思路是先构建数据库,确定每一个字段的作用,和表之间的关系。然后设计后台界面,从添加数据开始做起,因为添加是否成功可以直接到数据库里面验证,做好了添加再做显示的页面,最后才是两者的结合。一般来说后台就包括添加删除修改和显示,后台没有问题了,前台也没有什么大问题。前台还需要注意安全性和容错还有就是输出格式。
学会用PHP上传文件和发邮件
上传文件表单必须加上 enctype="multipart/form-data"
和 <input type="file" name="file">
下面看一下代码:
$f=&$HTTP_POST_FILES['file'];
$dest_dir='uploads';//设定上传目录
$dest=$dest_dir.'/'.date("ymd")."_".$f['name'];//我这里设置文件名为日期加上文件名避免重复
$r=move_uploaded_file($f['tmp_name'],$dest);
chmod($dest, 0755);//设定上传的文件的属性
上传的文件名为date("ymd")."_".$f['name'] ,可以在以后插入到数据库的时候用到,PHP实际上是把你上传的文件从临时目录移动到指定目录。move_uploaded_file($f['tmp_name'],$dest);这是关键
至于发邮件就更加简单,可以使用mail()函数
mail("收件人地址","主题","正文","From:发件人 Reply-to:发件人的地址");
不过mail()需要服务器的支持,在WINDOWS下还需要配置SMTP服务器,一般来说外面的LINUX空间都行。
好像上传文件和发邮件比ASP简单很多,只要调用函数就可以了。ASP还需要用到服务器的不同组件比如FSO、JMAIL什么的。
;