(理论篇)温故而知新_PHP入门基础教程

140次阅读
没有评论

共计 6506 个字符,预计需要花费 17 分钟才能阅读完成。

广告也是一种生活 平台需要你

阅读完文章后,望大家花个 5 秒的时间顺手点击一下底部的广告,无需仔细阅读,无需关注,只要点击一下就好。平台需要你,小编感谢你!!

更多学习视频 分享

想要领取整套学习视频教程(包括更多的 IT 学习视频)的同学,可以加 QQ2084533608, 加入时验证信息填:学习

为了能让大家在学习中劳逸结合,不觉得枯燥乏味,小编推出另一个微信公众号 笑一笑嘛 ,提供给大家搞笑小品,搞笑视频等,与大家共分享,同学们可以 长按识别二维码 关注一下,谢谢大家

PHP 自学中心微博:搜索 PHP 自学中心 有兴趣的可以关注一下

代码如下:

以下是 文章分享 1 群 由于群人数已超过 300,不能扫码进群,这个任务呢,就由小篇来拉你们进群了,扫描下面二维码,加小篇好友~

简单的回顾一下基础知识

1、嵌入方法:

类似 ASP 的 <%,PHP 可以是,当然您也可以自己指定。

2、引用文件:

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

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

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

3、注释方法:

echo"这是第一种例子。\n";// 本例是 C++ 语法的注释(PHP 的注释跟 C 差不多!)/* 本例采用多行的  注释方式 */echo"这是第二种例子。\n";echo"这是第三种例子。\n";  本例使用 UNIX Shell 语法注释?>

4、变量类型:

$mystring = “ 我是字符串 ” ;

$NewLine = “ 换行了 \n” ;

$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 为符合条件的执行部分程序,若程序只有一行,可以省略大括号 {}。

范例:本例省略大括号。

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

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

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

if($state==1) {echo"哈哈 ;echo"<br>";}?>

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

if (expr) {statement1} else {statement2} 范例:上面的例子来修改成更完整的处理。其中的 else 由于只有一行执行的指令,因此不用加上大括号。

if($state==1) {echo"哈哈";echo"
"
;}else{echo"呵呵";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 循环时,请小心使用,因为太多层的循环容易使设计的逻辑出问题,或者少打了大括号等,都会造成程序出现莫名其妙的问题。

2、for 循环就单纯只有一种,没有变化,它的语法如下

for (expr1; expr2; expr3) {statement}

其中的 expr1 为条件的初始值。expr2 为判断的条件,通常都是用逻辑运算符号 (logical operators) 当判断的条件。expr3 为执行 statement 后要执行的部份,用来改变条件,供下次的循环判断,如加一.. 等等。而 statement 为符合条件的执行部分程序,若程序只有一行,可以省略大括号 {}。

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

for($i=1; $i<=10; $i++) {echo"这是第".$i."次循环
"
;}?>

3、switch 循环,通常处理复合式的条件判断,每个子条件,都是 case 指令部分。在实作上若使用许多类似的 if 指令,可以将它综合成 switch 循环。

语法如下

switch (expr) {case expr1: statement1; break; case expr2: statement2; break; default: statementN; break;}

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

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

  此处含有隐藏内容,需要正确输入密码后可见!

); 返回值: 整数

本函数建立与 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."
"
;}?>当然,表 user 中有一个 username 的字段,这就类似 asp 中的<%exec="select * from user"setrs=server.createobject("adodb.recordset")rs.open exec,conn,1,1do while not rs.eofresponse.write"username:"&rs("username")&"
"
rs.movenextloop%>

当然先要连接数据库,一般我们 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 变量传递,如果表单中的一个

表单以 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。p 副标题 e

下面综合一下前面所说的我们来看一个登陆程序,判断用户名密码是否正确。

登陆表单是这样:login.php

width="100%"height="100%"border="0"align="center"cellpadding="0"cellspacing="0">action="checklogin.php"method="post">align="center"valign="middle">width="400"border="0"cellpadding="5"cellspacing="1"class="tablebg">class="tdbg">colspan="2">align="center">Administrators Loginclass="tdbg">align="center">Usernamealign="center">name="username"type="text"id="username">class="tdbg">align="center">Passwordalign="center">name="password"type="password"id="password">class="tdbg">colspan="2">align="center">type="submit"name="Submit"value="Submit">type="reset"name="Submit2"value="Clear">

处理文件是这样

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"";}}else{echo"";}}else{echo"";}?>

conn.php 是这样:

$conn=mysql_connect ("127.0.0.1","","");mysql_select_db("shop");?>

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

session_start();if($_SESSION[adminname]==){echo"";}?>

做一个分页显示

关键就是用到了 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 记录的

最后我们需要做的就是几个连接:

href="xxx.php?page=0">FirstPagehref="xxx.php?page=">PrevPagehref="xxx.php?page=">NextPagehref="xxx.php?page=">LastPage

注意事项

1、注意不要漏了分号

2、注意不要漏了变量前的 $

3、使用 SESSION 的时候注意不要遗漏 session_start();

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

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

2、如果是变量为空,大多是没有传递到位,输出变量检查一下,检查一下表单的 id 和 name

3、如果是数据库连接出错,检查是否正确打开 MY SQL 和是否遗漏了连接语句

4、注意缩进,排除括号不区配的错误

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

学会用 PHP 上传文件和发邮件

上传文件表单必须加上 enctype=”multipart/form-data”

下面看一下代码:

$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: 发件人 \r\nReply-to: 发件人的地址 ”);

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

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

学会 PHP 说到这里了,想告诉大家的是 PHP 入门可以是十天,但是精通决不是十天啊,还需要大家自己去研究,多参考别人的代码,去理解不是抄袭。

点击上面微信号关注我 关注我哟

小编   隔天 推送 php 教程php 技巧php 视频教程MySQL 笔试题 等诸多优质内容,最接地气 重服务 的本地微信平台!关注我们妥妥没错!

(广告合作联系 QQ:2230304070

广告也是一种生活 平台需要你

阅读完文章后,望大家花个 5 秒的时间顺手点击一下底部的广告,无需仔细阅读,无需关注,只要点击一下就好。平台需要你,小编感谢你!!

正文完
 0
评论(没有评论)