前言
本章节主要学习PHP概念、PHP环境搭建、基本语法、PHP函数、PHP文件管理、PHP操作MySQL数据库等知识点,收录于PHP基础系列。该系列主要讲解PHP相关知识点,欢迎童鞋们互相交流。觉得不错可以三连订阅喔。
目录
内容
一 概述
PHP(Hypertext Preprocessor)是一种广泛使用的开源服务器端脚本语言,尤其适用于Web开发。
PHP可以嵌入到HTML中,并与多种数据库集成,最常用的是MySQL。
其灵活性、易学性和强大的社区支持使得PHP成为开发动态网页和Web应用程序的首选语言之一。
PHP代码在服务器上执行,生成的HTML发送到客户端,从而实现网页的动态交互。
学习PHP需要先掌握HTML与CSS基础知识 ,没有基础的同学可以先学习《前端基础系列》:https://blog.csdn.net/weixin_55584739/category_12842027.html
二 环境搭建
1. 开发环境
开始学习之前还需要搭建PHP所需环境:PHP环境,Apache服务器。
对于初学者而言,建议使用集成工具,集成工具中包含了 PHP、Apache服务器、Mysql数据库等服务,免去了繁琐的配置环境过程。
常见的集成工具有很多: WampServer、XAMPP、PHPStudy等,这里推荐使用PHPStudy,下载地址:小皮面板(phpstudy) - 让天下没有难配的服务器环境!
下载安装步骤简单,根据提示安装即可:
2. 运行PHP程序
2.1 启动Apache服务器
2.2 打开根目录
2.3 创建php文件
2.4 打开浏览器,访问php程序即可
访问地址:域名+php程序名
3. 开发工具
选择一款顺手的开发工具,可以使我们的开发效率大大提升。
常见的PHP开发工具:Eclipse for PHP、PhpStorm、VSCode,建议初学者使用VSCode,轻量化,简单易上手,下载地址:vscode中文网 下载 Visual Studio Code
三 语法
完成以上准备工作,我们就开始正式学习PHP入门知识:基本语法。
1. 创建php文件
PHP 文件的默认文件扩展名是 .php。
PHP 文件可以包含 HTML 标签和一些 PHP 脚本代码。
2. 格式
PHP 脚本可以放在文件中的任何位置。
PHP 脚本以 <?php 开始,以 ?> 结束:
<?php
// PHP 代码
?>
3. 注释
<?php
// 这是 PHP 单行注释
/*
这是
PHP 多行
注释
*/
?>
4. HelloWord
<?php
echo "Hello World!";
?>
四 变量
变量是用于程序存储数据的"容器",所有编程语言中都有变量的概念。
语法:$变量名 = 变量值;
由于PHP属于弱类型语言,所以声明变量时不需要设置数据类型,变量的类型取决于值的类型。
注意规范:
命名需要有一定寓意,例如存储姓名:$name
遵守驼峰命名法,例如存储姓名:$myName
<?php
$a=5;
$b=6;
$c=$a+$b;
echo $c;
?>
五 数据类型
程序中的数据种类繁多,可以根据类型不同,分为几大类:
String(字符串)
Integer(整型)
Float(浮点型)
Boolean(布尔型)
Array(数组)
Object(对象)
NULL(空值)
Resour
1. 字符串
一个字符串是一串字符的序列,就像 "Hello world!"。
可以将任何文本放在单引号和双引号中:
<?php
$x = "Hello world!";
echo $x;
echo "<br>";
$x = 'Hello world!';
echo $x;
?>
2. 整数
整数是一个没有小数的数字。
<?php
$x = 1359;
$x = -345; // 负数
$x = 0x8C; // 十六进制数
$x = 047; // 八进制数
?>
3. 小数(浮点数)
浮点数是带小数部分的数字,或是指数形式。
var_dump() 函数返回变量的数据类型和值。
<?php
$x = 10.365;
var_dump($x);
echo "<br>";
$x = 2.4e3;
var_dump($x);
?>
4. 布尔
布尔型可以是 TRUE 或 FALSE,TRUE标识真,FALSE标识假。
<?php
$x=true;
$y=false;
?>
5. PHP 对象 (Object)
对象类型可以用于存储数据,使用class关键字声明类对象,类包含属性和方法。
<?php
//类名
class Car{
//属性
var $color;
//方法
function fun1() {
echo "方法1";
}
}
?>
6. null值
NULL 值表示变量没有值,NULL 是数据类型为 NULL 的值。
<?php
$x="Hello world!";
$x=null;
var_dump($x);
?>
六 运算符
PHP中的运算符与Java运算符基本相同,这里只描述特殊情况,其他相同的运算符可以参考《Java基础系列》中的《Java基础系列-第二章 变量,运算符与数据类型》。
1. 算数运算符
+ - * / %
2. 赋值运算符
= += -= *= /= %= .=
.= 连接两个字符串
<?php
$a = "Hello";
$b = $a . " world!";
echo $b; // 输出Hello world!
?>
3. 递增递减运算符
++x预递增 --x预递减 x++递增 x--递减
4. 比较运算符
>大于 >=大于等于 <小于 <=小于等于 ==相等 ===完全相等 !=非等 === 完全相等
<?php
$x=100;
$y="100";
//=== 判断两边数据的值和类型是否相同
var_dump($x === $y);
?>
5. 逻辑运算符
&&与 ||或 !非
七 流程控制语句
流程控制语句用来控制程序的执行流程,分为三种流程结构:
1. 顺序结构
2. 选择结构
3. 循环结构
与Java中的语法相同,参考《Java基础系列》中的《Java基础系列-第三章 流程控制语句》。
八 数组
数组指数据的组合,能够在单个变量中存储多个值。
可以将数组看作一个存储数据的盒子,盒子中有很多个格子,每个格子中都可存储一个数据。
数组名:盒子名
元素:格子中的数据
索引:格子的位置
长度:格子的数量
1. 创建数组并读取数据
通过索引读取数组中的元素 :$数组名[索引];
索引从0开始。即数组中的第一个元素索引为0,以此类推。
<?php
$cars=array("Volvo","BMW","Toyota");
//通过索引 读取数组中的所有元素 $数组名[索引];
echo "$cars[0].$cars[1].$cars[2]";
?>
2. 获取数组长度
count() 函数用于返回数组的长度。
<?php
$cars=array("Volvo","BMW","Toyota");
echo count($cars);
?>
3. 遍历数组
遍历指的是读取数组中的所有数据,使用 for 循环:
<?php
$cars=array("Volvo","BMW","Toyota");
$arrlength=count($cars);
for($x=0;$x<$arrlength;$x++){
echo $cars[$x];
echo "<br>";
}
?>
九 函数
函数又称方法,可以将功能代码进行封装,重复使用。
函数语法:function 函数名(参数){ 功能代码; 返回值; }
函数中的代码需要经过调用才会执行,不经调用函数无法执行。
1. 函数名
函数的名称
2. 参数
函数中可以使用的变量,调用者在调用时可以向参数中赋值,这个过程叫做参数传递(传参)。
3. 返回值
函数执行后返回给调用者的数据叫做返回值,可以用来传递数据。
<?php
// 没有参数,没有返回值的方法
function fun1(){
echo "没有参数,没有参会值的方法";
}
// 有参数,没有返回值的方法
function fun2($name){
echo "有参数,没有返回值的方法,参数是:$name";
}
// 有参数,有返回值的方法
function fun3($name){
$re = "返回值x";
return "有参数,有返回值的方法,返回值是:$re";
}
// 调用函数
fun1();
fun2("张三");
$x = fun3("admin");
echo $x;
/*
课堂练习:编写一个计算器方法,调用者传递两个整数,
计算器方法计算两个整数的积,并将结果返回给调用者
调用者接收数据,并输出到浏览器
*/
?>
十 PHP文件管理
使用php程序操作本地文件:php提供了一些函数,可以打开本地指定文件,给其添加数据、修改数据、删除数据、读取文件中的数据。
1. 打开文件
fopen("文件地址","打开方式");函数用于打开文件
打开方式有多种,分别为:
<?php
// 同级目录下创建test.txt文件
// 以只读模式打开文件
$fp = fopen('test.txt', "r");
//var_dump()操作一下$fp看看效果,查看输出结果,提示resource
var_dump($fp);
?>
2. 写入文件
fwrite($文件对像,"写入的数据");函数用于写入数据
<?php
$filename = 'test.txt';
// 打开文件 以写入的形式打开文件
$fp= fopen($filename, "w");
// 写入文件
$len = fwrite($fp, '模拟数据');
// 关闭文件对象
fclose($fp);
// 打印输出结果
print $len .'字节被写入了\n';
?>
3. 读取文件
3.1 fread() 返回所读取的字符串,如果出错返回 FALSE。
<?php
$filename = "test.txt";
$handle = fopen($filename, "r");//读取二进制文件时,需要将第二个参数设置成'rb'
// fread(文件对象,文件长度); 读取文件中的所有数据
// 通过filesize(文件对象); 函数获得文件大小,将整个文件一下子读到一个字符串中
$contents = fread($handle, filesize ($filename));
fclose($handle);
?>
如果读取的文件不是本地普通文件,而是远程文件或者流文件,就不能用以上方法。
因为filesize()函数不能获得这些文件的大小。
所以,需要通过feof()或者fread()的返回值判断是否已经读取到了文件的末尾。
feof()案例:
<?php
$handle = fopen('http://www.baidu.com', 'r');
$content = '';
while(!feof($handle)){
$content .= fread($handle, 8080);
}
echo $content;
fclose($handle);
?>
或者:
<?php
$handle = fopen('http://www.baidu.com', 'r');
$content = '';
while(false != ($a = fread($handle, 8080))){//返回false表示已经读取到文件末尾
$content .= $a;
}
echo $content;
fclose($handle);
?>
3.2 file读取数据到数组中
array file ( string $filename [, int $use_include_path [, resource $context ]] );
将文件内容读入一个数组中,数组的每一项对应文件中的一行,包括换行符在内。
<?php
$a = file('test.txt');
foreach($a as $line => $content){
echo 'line '.($line + 1).':'.$content;
}
?>
十一 PHP操作mysql数据库
php操作mysql数据库需要使用mysqli库
1. 新增数据
<?php
// 连接数据库,添加数据
// 步骤:1.创建连接 $db = new mysqli($数据库地址,$数据库账号,$数据库密码,$数据库名称);
// 2.编写sql语句 $sql = "insert into demo values($id,'$name',$age)";
// 3.执行sql语句 $rs = mysqli_query($db,$sql);
// 4.处理结果 if($rs){ echo "添加成功!";}
// 5.关闭连接对象 mysqli_close($db);
$dbservice = "localhost"; //ip地址
$dbusername = "root"; //账号
$dbpassword = "root"; //密码
$dbname = "school"; //数据库名称
// 1.创建数据库连接
$db = new mysqli($dbservice,$dbusername,$dbpassword,$dbname);
//模拟用户数据
$id = 1;
$name = "tom";
$age = 18;
// 2.编写sql语句
$sql = "insert into demo values($id,'$name',$age)";
// 3.执行sql语句 使用mysqli_query(数据库连接对象,sql语句)函数执行sql语句,获得执行结果
$rs = mysqli_query($db,$sql);
// 4.处理执行结果 判断是否执行成功
if($rs){
echo "添加成功!";
}else{
echo "添加失败!";
}
// 5.关闭连接对象
mysqli_close($db);;
?>
2. 修改数据
<?php
// 修改数据
// 创建连接
$conn = new mysqli("localhost","root","root","school");
// 编写sql语句
$sql = "update demo set id=2,name='jar',age=18 where id=1;";
// 执行sql语句
$rs = mysqli_query($conn,$sql);
if($rs){
echo "修改成功";
}else{
echo "修改失败";
}
// 关闭连接
mysqli_close($conn);
?>
3. 删除数据
<?php
// 删除数据
// 创建连接
$conn = new mysqli("localhost","root","root","school");
// 编写sql语句
$sql = "delete from demo where id=1";
// 执行sql语句 得到执行结果
$rs = mysqli_query($conn,$sql);
// 处理执行结果
if($rs){
echo "成功";
}else{
echo "失败";
}
// 关闭连接
mysqli_close($conn);
?>
4. 查询数据
4.1 查询是否成功
<?php
// 查询数据
$conn = new mysqli("localhost","root","root","school");
$sql = "select * from demo";
$rs = mysqli_query($conn,$sql);
if($rs){
echo "查询成功";
}else{
echo "查询失败";
}
?>
4.2 查询所有数据
<?php
// 查询数据,展示到网页
$conn = new mysqli("localhost","root","root","school");
$sql = "select * from demo";
// 执行sql语句,获得结果集
$rs = mysqli_query($conn,$sql);
// mysqli_fetch_array(结果集) 用于读取结果集,返回值为数组
// 遍历结果集
while($row = mysqli_fetch_array($rs)){
echo $row['id']. " " .$row['name']. " " .$row['age'];
echo "<br>";
}
?>
4.3 登录案例
<?php
// 管理员登录,跳转首页
// 获取请求表单中的用户数据
$username = $_POST["username"];
$password = $_POST["password"];
// 创建数据库连接
$con = new mysqli("localhost","root","root","crm");
// 编写sql
$sql = "select * from user where username='$username' and password='$password'";
// 执行sql
$rs = mysqli_query($con,$sql);
// 根据执行结果,跳转页面
if($rs){
// 登录成功,创建sessio,跳转首页
// 开启session
session_start();
// 将用户数据存入session会话对象
$_SESSION["username"] = $username;
$_SESSION["password"] = $password;
// 跳转
echo "<script language='javascript'>alert('登陆成功!');
location='welcome.php'</script>";
}else{
// 登陆失败,跳转登陆页面
echo "<script language='javascript'>alert('登陆失败!账号或密码错误,请重新输入。');
location='index.html'</script>";
}
?>
十二 小结
本文主要学习PHP入门知识、基础语法、操作文件、操作mysql数据库等知识点。
后续持续更新。