当前位置:知识百科 > 正文

php入门教程_php入门教程.pdf

更新时间:2025-01-05 21:03 阅读量:56388

零基础学习PHP如何入门?

其实学习PHP只要把握好学习路线,能够在极短的时间里完成从新手到熟练的过程.今天这一节,小编为大家整理出了学习PHP的路线和具体的课程.

入门:新人必看的PHP基础知识视频教程

可掌握PHP基础知识,了解PHP的基本语法、数组、函数、表单验证、图像处理,以及MySQL数据库等PHP开发过程中所遇到的知识点和基本操作.

进阶:PHP如何操作MySQL数据库视频教程

利用PHP操作MySQL数据库教程,MySQL是PHP最合适的搭配,MYSQL开源、跨平台,PHP扩展包对MySQL的支持比较完善.本课程讲解MySQL数据库的基础知识,以及如何利用PHP来操作MySQL数据库,实现对数据的调用和修改.

实战:PHP项目实战_多用户留言系统视频教程

利用PHP基础课程中的知识,在本课程中创建多用户留言系统,包括用户界面设计,注册,验证,帖子的写入、修改等留言系统的必备功能.

进阶:PHP进阶之面向对象相关视频教程

学习和了解开发独立的模板引擎技术,学习三层架构及分层思想和原理,然后通过后面的CMS内容管理系统等课程的实践来掌握以上知识点.

进阶:PHP进阶之CMS内容管理系统

CMS内容管理系统具有许多基于模板的优秀设计,可以加快网站开发速度和开发成本,同时易于使用,可开发性强,可分布式管理,CMS的功能并不只限于文本处理,它也可以处理图片、Flash动画、声像流、图像、甚至电子邮件档案等.

ThinkPHP框架讲解视频教程

作为一个新手,学习PHP语言需要有学习一门新语言的心态,注意不骄不躁,步步为营,按照方法和步骤去学习,由浅入深的接触.

php新手如何入门

PHP的背景恐怕就不用赘言了,我相信大家选择一种语言,并不是看它的背景和悠久历史,更重要的是看它的实用性,华而不实的语言哪怕是再辉煌的历史,也毕将步向没落,可喜的是PHP经受住了考验,也所以呢,它确实是一种值得学习的语言.

一直是听从别人的经验长大的,也所以呢在前辈们的经验里让少走了许多的弯路,更快的步入了正规,在此向那些我至尽不知道其名字的前辈们道声谢谢,在的眼里, 帮助不分大小,只要是帮助,总会让的心里暖融融的,我想,前辈们帮助我,并不是为了得到我的一句谢谢,更多的是出于一种责任感和对的期望,所以我想,只有 学好PHP,才能对得起前辈们的汗水.

正如我所说的,也终于感觉到了一种责任感,不知道自己的经验到底能帮助新手多少,但是明白,现在到了履行责任的时候了,我有必要把自己的经验告诉给所有希望学好PHP的人,只有这样才能让中国的PHP不断的进步,不断的发展,在世界上占据一席之地.

学习PHP的这段期间,感觉国内的PHP环境越来越成熟,规范也在逐渐的健全,PHPCHINA的成立,标志着与官方直接挂钩的PHP机构在中国正式落户了,在此献上迟到的掌声!

好的,切入正题:

我想在讲述自己的学习方式前,对那些期望能从我的文章中获得有用信息的人说一句心里话:

的文章不会对您的学习起到实质性的作用,您能否成功,还得靠自己的,坚持,坚持,再坚持,就是步入成功的不二法门.

我先把我自己学习PHP的过程做一下概括:

(1)熟悉HTML/CSS/JS等网页基本元素,完成阶段可自行制作完整的网页,对元素属性达到熟悉程度

我的这套线路可能跟许多学习PHP的爱好者不谋而合,这也算是一个循序渐进的学习过程,不过新手不要看到上面的概括就以为学习蛮简单的,在此不得不对您稍微泼一下冷水,任何东西其实都不简单,即使是小吃部的烧饼也不是一下子就会做成的.

我先解释一下我的学习思路.

首先,理解网站这一概念之后不难看出,任何网站都是由网页组成的,也就是说想完成网站,必须先学会做网页,所以呢必须要掌握了HTML,才能为今后制作网站打下基础.

在学习HTML中我想边学边做是最有效的方式,当然这一方式对于学习PHP同样是最有效的.

HTML中的任何元素都要亲自实践,只有明白了什么元素会起到什么效果之后,你才会记忆深刻,而一味的啃书,绝对是不行的,我想大部分新手之所以觉得概念难学,大部分是一个字"懒",懒是阻止进步的最大敌人,所以克服掉懒的习惯,才能更快的学好一样东西.

也许您在学习PHP的时候只想尽快的开发一个网站,也就会想我做网站,干嘛要学什么网页这些小儿科?不难看出,眼高手低的新手不在少数,这种思想无疑于建造空中楼阁,你不建地基,何来的房顶呢?

OK,掌握静态网页的制作技术是学习开发网站的先决条件,这一点就讲到这里,因为这篇文章不是教程文章,也就不对技术进行深入的刨析了.

我假设你目前已经可以完成一个静态页面了,当然,做的好看难看是另外一说,的第一个网页也没好看到哪去,但是"孩子"再丑,咱们做"爹妈"的也不能嫌弃不是?这毕竟是咱的成果.

那么咱们就开始学习动态语言的概念吧,刚一接触动态语言,可能很多人都会蒙了,怎么这乱七八糟的东西,在网页里显示的时候却是另外一码事?其实这并不算乱 七八糟,你写的HTML代码不也一样是一堆堆的字符吗?毕竟,代码并不是作为直接输出的,而是经过处理的,说白了,HTML是经过HTML解析器,而 PHP当然也就通过PHP解析器了,跟学习HTML一样的道理,想让任何的解析器完成操作,就必须使用它们专用的语法结构,所以PHP长相奇怪也就不足为 奇了.

对于PHP的理解是新手最难迈过的一道门槛,不过你应该感到幸运的是PHP已经最大极限的为了新手而努力了,如果你学过其他的语言,也许会觉得PHP的确相当的简单,但是如果你之前什么都没学过,那么阿弥陀佛,硬着头皮琢磨吧.

书过三遍自然熟,这个简单的道理告诉我们,即使你理解不了PHP,但是也必须先跟它混个脸熟,看,一遍遍的看,看的同时一边琢磨,一边按照它所教的打代码,即使你搞不清楚那些代码到底是干嘛的,但是起码你应该找找感觉.

在一段挣扎之后,聪明的你,显然已经逐渐的开悟了,慢慢的理解了编程的概念,那么祝贺你,你已经迈出了成功的第一步.

搞清楚HTML和PHP的概念,那么PHP和HTML混合编程应该不成问题,在这期间,你完全可以让PHP给你算算一加一等于几,然后在浏览器输出,不要 觉得幼稚,这的确是跟阿波罗登月一样,你打的是一小段代码,但是对于你的编程之路,可是迈出了一大步啊!兴奋吧?但是不得不再给你泼点冷水,您还是菜鸟一 个.

高兴一段时间就必须继续努力了,此时此刻呢就是学习数据库了,MYSQL可算是PHP的黄金搭档了,不过,虽然话是这么说,你也可能恨不得把MYSQL给生吞活剥了,因为这一行一列的东东简直让自己头晕目眩.

头晕归头晕,目眩归目眩,你不可能吃饭的时候咬了自己一下舌头就从此不吃饭了不是?放下畏惧,继续努力,咱们是来征服它的,而不是被它征服的,振奋起来吧同志.

在一番搏斗之后,你终于理解了数据库的概念,而且让你兴奋不已的是你终于可以通过PHP来连接数据库了,这期间你是怎么学会的,我们不去考证了,但是事实证明,你已经可以了.

学会了PHP和数据库的你,无疑是左手拿着MOTOLOLA右手拿着NOKIA,要多潇洒,有多潇洒,哈哈,终于学会了,但是可能这个时候,又会有人不经意的拍拍肩膀对你说:哥们,别高兴的太早,你还是菜鸟,离学会还差着一大截呢!

等到你发奋努力的学会了用PHP成功的插入,删除,更新数据的时候,显然,你已经距离成功指日可待了.

这个时候的你也许是这种状态:

你会HTML吗?会,我能编好几个大表格排板的网页啦!

你会PHP吗?会,我会把一加一的运算写在函数里,然后调用啦!

你会MYSQL吗?会,我会把我的信息在数据库里插入删除啦

那,此时此刻呢你该怎么做呢?我觉得,小试一下身手,大概是没问题了,那么交给你个任务,做个留言本吧,这和HELLO WORLD有一比啊!^_^,同是新手面临的第一道关.

花了一段时间,你终于学会把表单的数据插入数据库,然后显示出来了,应该说一个程序的雏形已经诞生了.

但是,你可能瞅瞅东,看看西,人家这个编论坛,那个CMS,还有那啥CRM,我啥时候写一个呢?

巩固了自己的知识,熟悉了PHP和MYSQL开发的要领之后,再回头看你写的那个留言本,你也许会怀疑那真的是你写的吗?当然,如果屋里还有鬼的话,也许是它写的-_-

这个时候,你的留言本应该加入注册以及分页功能了,而如果你更强的话,UI(用户界面)也可以加强,完成之后,感觉是不是特有成就感?不管怎么样,咱好歹 是写了一个动态网站程序了,放在自己的网站上耍耍吧,让好朋友来看看,嘿,看咱写的多棒,然后再在网上宣传一下.

几天之后你再打开留言本,哎?哇,一下弹出N多页面!很明显,你的留言本并没有做好安全防范,被人用JS代码小小的耍了一下,我很同情你这个时候的感受,但是没有别的办法了,继续努力吧!

你发奋努力,熟悉了安全方面的问题,然后又设计了一些程序,感觉还不错.

那么此时此刻呢,这就算学会啦?NO,NO,NO,还早呢,你至尽还没碰过OOP之类的吧?模板呢?

恩,学!加紧学呀学,学会了这些之后,你又学会了生成静态网页,现在你应该接触一下XML了,恩,XML也了解了,那么AJAX你也得接触接触吧?AJAX完了....然后...

都说到这里了大家应该明白,你绝对不会发现你全部都学会了,一些真正的强人总会搞出新玩意来丢给你,你不学就落后了,也印证了前人的经验,果然是学无止境啊!

我想通过我的一番YY,你也应该大致熟悉了一些学习过程,也许我的过程和你的有些出路,但是不管怎么样是殊途同归,我写这么多,也只是给大家一个借鉴的机会,至于好与不好,不敢打包票^0^

学东西,永远不要妄想有速成这一说,告诉你了一个方式,但是缺少努力这一环节,那也是白搭.

但是有一点我可以给你保证的就是,你学会了PHP,那么学其他的语言,肯定速成,反过来也一样,如果你之前学过其他的语言,那么学PHP肯定快.

不过语法好学,但是怎么用语法来实现每个人都有每个人的方式,几乎是各有千秋.然而借鉴别人成功的代码,绝对是有益无害,所以呢,多看那些经过千锤百炼凝出来的经典代码,是进阶的最好方法.

讲了这么多,无非是想说:学习PHP不仅要掌握方法,更多的是付出汗水,我不希望看到中途放弃的人,相信自己,相信自己的选择,更要相信自己的能力,如果 自己想放弃,暴力一点的话,就自己抽自己一个嘴巴,然后大吼:别人可以,我为什么就不可以?(是不是有点阎罗教练的味道,的确是电影看多了,抽嘴巴是会痛 的,各位其实明白这个道理了就行了)

另外要叮嘱各位的是,抵御诱惑,ASP/PHP/JSP/.NET的对比也许会让你无所适从,你也许学了一半PHP,又开始打C#的主意,或者有人说 JAVA很强,这个时候的你绝对不能动摇,哪怕你真想学,也得学会了PHP.然后再学,见异思迁是最不可取的,狗熊掰玉米就是这个道理,如果经常中途放 弃,只能是一无所获,还浪费了N多的时间和经历,得不偿失,最重要的是,你会被别人瞧不起,没有人会喜欢和见异思迁的人交朋友,因为这种人太不安分,太不 可靠,所以呢,你必须要强迫自己完成自己的目标,哪怕可能会很难受,也得坚持,毅力就是这么锻炼出来的.

PHP入门基础教程

PHP入门基础教程大全

①.、嵌入方法:

类似ASP的%,PHP可以是?php或者是?,结束符号是?,当然您也可以自己指定.

引用文件的方法有两种:require 及 include.

require 的使用方法如 require("MyRequireFile.php"); .这个函数通常放在 PHP 程序的最前面,PHP 程序在执行前,就会先读入 require 所指定引入的文件,使它变成 PHP 程序网页的一部份.常用的函数,亦可以这个方法将它引入网页中.

include 使用方法如 include("MyIncludeFile.php"); .这个函数一般是放在流程控制的处理部分中.PHP 程序网页在读到 include 的文件时,才将它读进来.这种方式,可以把程序执行时的流程简单化.

?php

echo "这是第一种例子.\n" ; // 本例是 C++ 语法的注释 (PHP的注释跟C差不多!)

/* 本例采用多行的

注释方式 */

echo "这是第二种例子.\n" ;

echo "这是第三种例子.\n" ; # 本例使用 UNIX Shell 语法注释

?

$mystring = "我是字符串" ;

$NewLine = "换行了\n" ;

$MyArray1 = array( "子" , "丑" , "寅" , "卯" );

这里引出两个问题,首先PHP变量以$开头,第二PHP语句以;结尾,可能ASP程序员会不适应.这两个遗漏也是程序上大多错误所在.

数**非法字眼已被屏蔽**算:

符号 ? ? 意义

+ ? ? ? 加法运算

- ? ? ? ?减法运算

* ? ? ? ?乘法运算

/ ? ? ? ?除法运算

% ? ? ?取余数

++ ? ? 累加

-- ? ? ? 递减

字符串运算:

运算符号只有一个,就是英文的句号.它可以将字符串连接起来,变成合并的新字符串.类似ASP中的

$b = "功能强大" ;

echo $a.$b;

这里也引出两个问题,首先PHP中输出语句是echo,第二类似ASP中的%=变量%,PHP中也可以?=变量?.

逻辑运算:

符号 意义

小于

大于

= 小于或等于

= 大于或等于

== 等于

!= 不等于

而且 (And)

and 而且 (And)

或者 (Or)

or 或者 (Or)

xor 异或 (Xor)

! 不 (Not)

学习目的:掌握php的流程控制

①.、if..else 循环有三种结构

第一种是只有用到 if 条件,当作单纯的判断.解释成 "若发生了某事则怎样处理".语法如下:

if (expr) { statement }

其中的 expr 为判断的条件,通常都是用逻辑运算符号当判断的条件.而 statement 为符合条件的执行部分程序,若程序只有一行,可以省略大括号 {}.

范例:本例省略大括号.

if ($state==1)echo "哈哈" ;

这里特别注意的是,判断是否相等是==而不是=,ASP程序员可能常犯这个错误,= 是赋值.

范例:本例的执行部分有三行,不可省略大括号.

if ($state==1) {

echo "哈哈 ;

echo "br" ;

}

第两种是除了 if 之外,加上了 else 的条件,可解释成 "若发生了某事则怎样处理,否则该如何解决".语法如下

echo "哈哈" ;

echo "br";

else{

echo "呵呵";

第三种就是递归的 if..else 循环,通常用在多种决策判断时.它将数个 if..else 拿来合并运用处理.

直接看下面的例子

if ( $a $b ) {

echo "a 比 b 大" ;

} elseif ( $a == $b ) {

echo "a 等于 b" ;

} else {

echo "a 比 b 小" ;

上例只用二层的 if..else 循环,用来比较 a 和 b 两个变量.实际要使用这种递归 if..else 循环时,请小心使用,因为太多层的循环容易使设计的逻辑出问题,或者少打了大括号等,都会造成程序出现莫名其妙的问题.

下例是用 for 循环写的的例子.

for ( $i = 1 ; $i = 10 ; $i ++) {

echo "这是第".$i."次循环br" ;

语法如下

其中的 expr 条件,通常为变量名称.而 case 后的 exprN,通常表示变量值.冒号后则为符合该条件要执行的部分.注意要用 break 跳离循环.

switch ( date ( "D" )) {

case "Mon" :

echo "今天星期一" ;

break;

case "Tue" :

echo "今天星期二" ;

case "Wed" :

echo "今天星期三" ;

case "Thu" :

echo "今天星期四" ;

case "Fri" :

echo "今天星期五" ;

default:

echo "今天放假" ;

这里需要注意的是break;别遗漏了,default,省略是可以的.

很明显的,上述的例子用 if 循环就很麻烦了.当然在设计时,要将出现机率最大的条件放在最前面,最少出现的条件放在最后面,可以增加程序的执行效率.上例由于每天出现的机率相同,所以不用注意条件的顺序.

学会构建数据库

下面说一下它的使用.

进入了phpmyadmin后,我们首先需要建立一个数据库,

然后在左边下拉菜单中选择那个已经创建的数据库.在下面的

在数据库 shop 中创建一个新表 :

名字 :

字段数 :

中填写表名字和大致你认为的字段数(不够或者多了都不要紧,以后可以再添加或者缺省),按执行.

然后就可以开始建立表了.

第一栏是字段的名字;第二栏选择字段类型:

我们常用的是以下几个:

①.)VARCHAR,文本类型

①.)按右边的结构:查看修改表结构

还有一个很重要的功能就是导入和导出,当我们本机做好了程序和数据库的时候,需要在服务器上也有一个本地镜像,如果是ASP的ACCESS简单了,直接上传MDB文件即可,如果是SQL SERVER也可以连接远端服务器进行导入.那么MY SQL中你可以导出所有的SQL语句,到了远端服务器的PHPMYADMIN上,创建数据库后按SQL,粘帖你刚才复制下来的所有本级生成的SQL语句即可.

学会连接数据库

PHP简直就是一个函数库,丰富的函数使PHP的某些地方相当简单.建议大家down一本PHP的函数手册,总用的到.

我这里就简单说一下连接MYSQL数据库.

①.、mysql_connect

打开 MySQL 服务器连接.

语法: int mysql_connect(string [hostname] [:port], string [username], string [password]); 返回值: 整数

本函数建立与 MySQL 服务器的连接.其中所有的参数都可省略.当使用本函数却不加任何参数时,参数 hostname 的默认值为 localhost、参数 username 的默认值为 PHP 执行行程的拥有者、参数 password 则为空字符串 (即没有密码).而参数 hostname 后面可以加冒号与端口号,代表使用哪个端口与 MySQL 连接.当然在使用数据库时,早点使用 mysql_close() 将连接关掉可以节省资源.

选择一个数据库.

语法: int mysql_select_db(string database_name, int [link_identifier]); 返回值: 整数

本函数选择 MySQL 服务器中的数据库以供之后的资料查询作业 (query) 处理.成功返回 true,失败则返回 false.

最简单的例子就是:

mysql_select_db("shop");

连接机MY SQL数据库,打开SHOP数据库.在实际应用中应当加强点错误判断.

学会读取数据

先看两个函数:

①.、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 时,并不是执行成功但无返回值,而是查询的字符串有错误.

本函数用来将查询结果 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="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

tr class="tdbg"

/tr

tdp align="center"Username/p/td

tdp align="center"

input name="username" type="text" id="username"

/p/td

tdp align="center"Password/p/td

input name="password" type="password" id="password"

input type="submit" name="Submit" value="Submit"

/table/td/form

/table

处理文件是这样

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 "scriptalert('Password Check Error!');location.href='login.php';/script";

echo "scriptalert('Username Check Error!');location.href='login.php';/script";

echo "scriptalert('Database Connection Error!');location.href='login.php';/script";

conn.php是这样:

由于 $_SESSION['adminname']=$username;我们可以这样写验证是否登陆语句的文件:checkadmin.php

if($_SESSION['adminname']=='')

echo "scriptalert('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;

$page=$_GET['page'];

if($page0)$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

注意事项

①.、注意不要漏了分号

如果发生错误的时候,可以采用以下方法:

①.、如果是SQL语句出错,就注释了然后输出SQL语句,注意也要注释调后续的执行SQL语句

在做大网站的时候,我的思路是先构建数据库,确定每一个字段的作用,和表之间的关系.然后设计后台界面,从添加数据开始做起,因为添加是否成功可以直接到数据库里面验证,做好了添加再做显示的页面,最后才是两者的结合.一般来说后台就包括添加删除修改和显示,后台没有问题了,前台也没有什么大问题.前台还需要注意安全性和容错还有就是输出格式.

学会用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);

上传的文件名为date("ymd")."_".$f['name'] ,可以在以后插入到数据库的时候用到,PHP实际上是把你上传的文件从临时目录移动到指定目录.move_uploaded_file($f['tmp_name'],$dest);这是关键

至于发邮件就更加简单,可以使用mail()函数

mail("收件人地址","主题","正文","From:发件人\r\nReply-to:发件人的地址");

不过mail()需要服务器的支持,在WINDOWS下还需要配置SMTP服务器,一般来说外面的LINUX空间都行.

好像上传文件和发邮件比ASP简单很多,只要调用函数就可以了.ASP还需要用到服务器的不同组件比如FSO、JMAIL什么的.

;