2023-09-03

PHP 基础知识:PHP 编程简介


无可否认,我们的行业是一个极其困难的行业。曾经考虑过学习第二语言吗?嗯,五个怎么样?如果您想成为一名现代 Web 开发人员,这就是您所需要的。考虑到这一点,如果您不小心,很快您可能会发现自己不知所措,因为您盲目地盯着无数令人困惑的博客文章或技术书籍。

与任何事情一样,关键是一次迈出一步。

与任何事情一样,关键是一次迈出一步。你会因为一个月没有学会口语而责怪自己吗?当然不是。然后将同样水平的思维应用到您的编程之旅中。这些事情需要时间,但是,只要你继续前进,你很快就会到达那里。不要停下来!

第一步是 HTML。了解 <div> 的用途。了解如何使用语义标签构建内容。构建一个基本的、无样式的网页。

正如您可能已经猜到的那样,第二步是 CSS。了解如何设置页面上元素的样式。了解“关注点分离”的含义,以及它如何应用于 HTML 和 CSS。完成您的第一个简单网站。

第三步是开发人员开始分支到自己的专业领域。此时,您可以深入了解 JavaScript 的世界,它正在以前所未有的方式蓬勃发展。或者,您可以将精力集中在后端。

前端后端之间的区别感到困惑吗?将前端视为导致泰坦尼克号沉没的冰山一角。它是应用程序中对用户可见且可以与之交互的部分。另一方面,后端处理从持久性到验证到路由的所有事务。

出于本文的目的,我们假设您选择了后一个选项;服务器端,就是这样!

无可否认,PHP 在网络上占据主导地位。

不幸的是,你再次遇到了一些要走的路。您应该选择最流行的选项 – PHP?鲁比呢?如今,酷孩子们似乎更喜欢这样。话又说回来,如果你有胡子怎么办? Python 是正确的选择吗?但最重要的是,当你的经验为零时,你怎么可能做出选择?

在这种情况下 – 在作者看来 – 没有错误的选择。当然,没有什么可以阻止你改变方向。事实上,我们鼓励所有开发人员学习多种语言!然而,现在的关键是只选择一个,并学好它。

虽然 PHP 确实不是最美丽的语言,但不可否认的是它统治着网络。事实上,它是世界上最流行的脚本语言。这样做的好处是您可以放心,每个 PHP 问题都已经被提出、解决和记录。知道这一点让人感到安慰。尽管您正处于学习的最脆弱阶段,但一个庞大、友好的社区就在您家门口,随时准备为您提供帮助。更好的是,得益于 Composer 和 Laravel 等工具,PHP 正在经历前所未有的现代复兴。


什么是 PHP?

PHP 是 PHP:超文本预处理器 的缩写(是的,开发人员喜欢他们的递归笑话),是一种专门为 Web 构建的脚本语言。不过,很有可能这对您来说仍然毫无意义。脚本语言?啊?您什么时候会选择 PHP 而不是简单的 HTML?好吧,也许可以举个例子。假设您已成功安装 PHP,请在桌面上的新文件夹中创建 index.php 文件,并添加:

<?php

echo 'Hello world';
登录后复制

是的,这是无处不在的“hello world”示例,随着您的技能进步,您会变得非常熟悉。每种语言/框架/工具都有一个!

为了运行此代码,请使用 PHP 的内置服务器。切换到您最喜欢的命令行工具(终端,对于 Mac 用户), cd 到项目文件夹,并使用 php -S localhost:8888 启动服务器。此命令翻译为“运行服务器,并使其可通过浏览器在本地主机、端口 8888 进行访问”。快来尝试一下吧!打开Goog​​le Chrome,浏览到localhost:8888,你会在页面上看到“Hello world*”!漂亮! echo 是一种语言构造,除了输出给定值之外什么也不做。

提示:MAMP 和 WAMP 是出色的一键式解决方案,可用于在 Mac 或 PC 上安装 PHP、MySQL 和 Apache,而无需摸索命令行。它们在您学习的早期阶段可能是有用的选择。

PHP 基础知识:PHP 编程简介

诚然,这并不是世界上最令人兴奋的事情。事实上,您可能会想,“为什么我不能将“Hello world”直接写入 HTML 页面,从而完全不需要 PHP?”这是真的;对于这个例子来说,它没有任何作用。然而,当输出本质上是动态的时,像 PHP 这样的脚本语言就变得特别有用。如果您希望问候语引用通过 URL 的查询字符串(地址栏中问号后面的文本)传递的值,而不是 world,该怎么办?这是一个更新的示例,它就实现了这一点!

<?php

echo 'Hello, ' . $_GET['person'];
登录后复制

啊,这引入了一些新技术。首先,分隔 Hello 字符串和令人困惑的 $_GET 的单个句点允许您连接(或分组)值。在本例中,我们希望打印“Hello, *”,然后打印 $_GET['person'] 表示的值。这就是我们所说的超全局数组。为了简单起见,可以将其视为从 URL 的查询字符串*获取值的一种方法。

通过加载 localhost:8888/?person=Joe 来测试这一点。如果配置正确,网页现在应该显示“Hello, Joe”。通过将 Joe 替换为您自己的名称来尝试一下。请注意每次刷新页面时输出如何更新?这对于静态 HTML 来说根本不可能实现。

成熟编程的关键之一是考虑代码中每一个可能的路径。例如,如果没有 person 密钥可用怎么办?也许查询字符串被完全省略了。在这种情况下,肯定会抛出错误,因为 person 键不存在。解决办法是什么?虽然这确实只是一个简单的例子,但考虑所有可能的结果仍然很重要。让我们提供一个默认值。

<?php

if (isset($_GET['person'])) {
    $person = $_GET['person'];
} else {
    $person = 'Joe';
}

echo 'Hello, ' . $person;
登录后复制

尽管有更简化的方法可以实现这一点,但上面的示例是一个很好的起点。这也是您对条件语句的第一次介绍。以与处理现实生活中的场景相同的方式处理代码。例如,“如果我们没有牛奶,就去商店。否则,就呆在家里。”这种思路可以使用以下逻辑转换为 PHP:

$outOfMilk = true;

if ($outOfMilk) {
    echo 'Going out to the store.';
} else {
    echo 'Breakfast is served.'
}
登录后复制

在这段代码中,只会将一行文本打印到屏幕上。变量值(动态值)$outOfMilk 将确定控制流。

提示:要在 PHP 中声明变量,请在任何名称前添加美元符号。作为最佳实践,选择可读的变量名称而不是神秘的替代名称。

回到前面的例子,只要设置了 $_GET['person'] (可以将其视为“可用”的伪名),然后创建一个新的 $person 变量 equal到它的价值。否则,应用默认值。如果您返回到浏览器,它现在应该可以正常运行,无论查询字符串中是否存在 person 键。

安全

不幸的是,我们仍然没有回家。一个关键的编程最佳实践是将安全性置于每项操作的最前沿。即使有了这个令人难以置信的基本示例,我们也为网络上最普遍的安全问题之一打开了大门:XSS(跨站脚本)。对此的真正理解绝对超出了本入门课程的范围(整本书都写过它),但是,这里有一个基本说明:如果 $_GET['person'] 等于而不是字符串怎么办,但是一个脚本?

http://localhost:8888/?person=<script>alert('ATTACK!')</script>
登录后复制

由于该值尚未被清理,因此在执行时,在某些浏览器中会显示警告框。

基于 Webkit 的浏览器(例如 Chrome 和 Safari)现在可以提供针对此类攻击的保护。然而,情况并非总是如此,并且在 Firefox 和 Internet Explorer 中仍然如此。

PHP 基础知识:PHP 编程简介

哎呀!我们不能这样。虽然现代社会表明一个人在被证明有罪之前是无辜的,但对于编程世界来说却并非如此。所有用户输入在经过净化之前都是有罪的!这是一个更新的示例,它执行此操作:

<?php

if (isset($_GET['person'])) {
    $person = $_GET['person'];
} else {
    $person = 'Joe';
}

echo 'Hello, ' . htmlspecialchars($person, ENT_QUOTES);
登录后复制

通过此修改,如果有人尝试 XSS 攻击,我们将做好准备! htmlspecialchars 是一个本机 PHP 函数,可将各种符号转换为其实体对应部分。 & 变为 & 变为 等。这使其成为提供额外安全性的完美工具。 如果在执行前转换为 则没有任何意义。用户将简单地看到:

Hello, <script>alert('ATTACK!')</script>
登录后复制

太棒了;没有造成任何伤害!


函数

虽然 PHP 附带了大量本机函数,但有时您肯定需要自己的函数。幸运的是,编写它们很容易。

将函数视为可重用的逻辑片段,可以将其抽象出来,以便可以使用可读的名称来识别和调用它。

也许您经营一家夜总会(如果您正在阅读本文,则不太可能!),并且需要一种简单的方法来接受一个人的出生日期,并计算他或她是否至少有 21 岁。自定义函数将是完成此任务的绝佳方法。

第一步是定义一个新函数,名为 isAdult。函数可以接受外部输入,然后可以对其进行操作。这允许函数返回的数据是动态的。在这种情况下,要确定一个人是否是成年人,我们需要知道他们的出生年份。最后一步是返回 truefalse,具体取决于当前年份减去该人的出生日期是否至少为二十一。

function isAdult($yob) {
    $currentYear = 2013;

    return $currentYear - $yob >= 21;
}
登录后复制

其实很简单!现在,我们只需要将其传递给保镖即可。可以通过引用其名称并后跟一组括号来触发或调用函数:isAdult()。但是,如果函数需要参数,那么您可以在这些括号内指定它,如下所示:

if (isAdult(1985)) {
    echo 'Come on in!';
} else {
    echo 'Please leave now, before I call your mother.';
}
登录后复制

这个 isAdult 函数有一个明显的问题。当前年份已被硬编码。当然,它会在整个 2013 年有效,但明年呢?看来这个值也需要是动态的。 PHP提供了一个date函数,可以用来计算当前年份。因此,该功能可能会更新为:

function isAdult($yob) {
    $currentYear = date('Y');

    return $currentYear - $yob >= 21;
}
登录后复制

数组

几个月过去了,现在夜总会的生意比以往任何时候都好。事实上,它做得太好了,以至于保镖无法跟上。如果他可以一次筛选一组人,他的工作可能会更容易。

将数组视为相关数据的容器。您甚至可以将其称为列表:推文列表、一组家庭成员、一组出生日期。

最新版本的 PHP (5.4) 中的数组可以使用括号内的逗号分隔列表来定义,如下所示:

$group = [1985, 1990, 1992, 1997];
登录后复制

这个单个 $group 变量现在包含多个出生日期。可以通过指定索引来访问其中的值,例如 $group[0]。数组就是我们所说的从零开始的数组。在翻译中,这意味着数组中的第一项或键的索引为零。因此,要访问 1992 年的值,您可以引用 $group[2]

现在,保镖可以快速过滤这些出生日期,并计算是否允许该人进入或拒绝他们。 foreach 语句可用于此类过滤。

$group = [1985, 1990, 1992, 1997];
foreach($group as $yob) {
    if (isAdult($yob)) {
        echo 'Come on in!';
    } else {
        echo 'Please leave now, before I call your mother.';
    }
}
登录后复制

注意保镖如何声明 group 中的出生年份 foreach 人应包含在变量 $yob 中。接下来,正如他之前所做的那样,他将该值传递给 isAdult 函数,并相应地继续。

不过,当保镖无法确定此人的出生年份和姓名之间的联系时,他可能会感到困惑。 PHP 还允许关联数组,它提供了将给定值与键关联起来所需的功能。这是一个例子:

$group = [
    'John'  => 1985,
    'Susan' => 1990,
    'Joe'   => 1992,
    'Sara'  => 1997
];
登录后复制

这样更好。作为额外的好处,保镖现在知道了这个人的名字,可以对这个人更加友好一点。

$group = [
    'John'  => 1985,
    'Susan' => 1990,
    'Joe'   => 1992,
    'Sara'  => 1997
];

foreach($group as $name => $yob) {
    if (isAdult($yob)) {
        echo "Come on in, $name!";
    } else {
        echo "Please leave now, $name, before I call your mother.";
    }
}
登录后复制

在双引号内存储字符串时,您可以嵌套变量而不是使用连接。这可以提供更具可读性的语法。


课程

面向对象的编程远远超出了本教程的范围,但是,类仍然值得一提。现在,将它们视为相关属性和方法的简单容器。例如,代表单个人的类可能如下所示:

class Person {
    public $name;
    public $age;

    public function __construct($name, $age)
    {
        $this->name = $name;
        $this->age = $age;
    }
}
登录后复制

注意到 __construct() 方法了吗?这被称为魔术方法,实例化后会立即触发。当此方法触发时,它将接受名称和年龄,然后将其附加到对象。

要使用此类,请尝试:

$me = new Person('Jeffrey', 28);
登录后复制

这将创建 Person 类的新实例。该实例存储在 $me 变量中,可以称为对象。现在,没有什么可以阻止您创建此类的多个实例 – 事实上,在现实世界的项目中,您会这样做!该类只是一个蓝图。

但此时,该类还没有太大用处。让我们添加一个方法或函数来指定一个人的配偶。

class Person {
    public $name;
    public $age;
    public $spouse;

    public function __construct($name, $age)
    {
        $this->name = $name;
        $this->age = $age;
    }

    public function marry(Person $spouse)
    {
        $this->spouse = $spouse;
    }
}

$me = new Person('Jeff', 28);
$her = new Person('Allison', 28);
$me->marry($her);
登录后复制

此修改后的代码现在包含一个 marry() 方法,该方法将更新对象上的 $spouse 属性。现在,两个人之间有了直接联系。

如果方法参数前面有一个类名(Person $spouse),称为类型提示,则表明该参数必须是给定类的实例,否则将引发错误。 p>

要获取我配偶的名字,您可以这样写:

echo $me->spouse->name; // Allison
登录后复制

面向对象编程的概念比这更深入,但现在保持简单。它有助于将类视为单数名词:推文、用户、客户或文件。

对这种模式的真正欣赏只会随着时间的推移而出现。

动手实践

测试您新发现的技能。您如何在页面上为用户注册和显示推文?好吧,第一步可能是定义一个代表单个 Tweet 的类。此类应存储推文正文的属性及其发布日期。此外,还应确保推文正文不超过 140 个字符。这是此类课程的第一次尝试:

class Tweet {
    public $body;
    public $pubDate;

    public function __construct($body)
    {
        $this->setBody($body);
        $this->setPubDate(new DateTime);
    }

    public function setBody($body)
    {
        if (strlen($body) > 140) {
            throw new InvalidArgumentException;
        }

        $this->body = $body;
    }

    public function setPubDate(DateTime $date)
    {
        $this->pubDate = $date->format('Y/m/d H:i:s');
    }
}
登录后复制

虽然一开始看起来可能令人不知所措,但请稍微研究一下这段代码,并尝试了解每一步发生的情况。您可能会发现它非常可读!

一个有趣的新功能源于 setBody 方法。如果提供的文本超过 140 个字符(我们可以使用 PHP 的 strlen 函数计算),那么我们应该对此表示反对,因为它违反了推文的规则。可以使用语法 throw new ExceptionType 抛出异常。

现在我们有了一个足够合适的推文容器,我们可以创建几条推文,将它们存储在一个数组中,然后最终使用 foreach 语句将它们呈现在页面上。

$tweets = [];

# add two new tweets to the array
$tweets[] = new Tweet('Going to the store.');
$tweets[] = new Tweet('Back from the store!');

# Filter through, and display on page.
foreach($tweets as $tweet) {
    echo "<h2>{$tweet->body}</h2>";
    echo "<p>Posted on: {$tweet->pubDate}</p>";
}
登录后复制

在浏览器中查看输出后,您应该看到类似以下内容的内容:

PHP 基础知识:PHP 编程简介

很好,但是我们如何保存这些推文?


存储

到目前为止,您已经学习了基础知识:变量、条件、函数、数组、类。还有更多内容需要介绍,但您应该根据需要自行研究。学习的下一步就是坚持。例如,您如何保留所有推文的日志?不记住推文的推文服务是一个糟糕的服务!这就是数据库的想法发挥作用的时候。

将数据库表视为 Excel 电子表格。它可以包含任意数量的字段,例如人员的姓名、年龄或邮寄地址。然而,PHP 本身并不提供这种存储。相反,最常见的选择是 MySQL,它是世界上最流行的开源数据库。

安装 MySQL 不属于本教程的范围。相反,请参阅 Nettuts+ 上的本教程以获取完整的演练。

下面是一个简化的示例,可帮助您开始从数据库表中安全地获取行。如果它看起来势不可挡,请不要担心。 MySQL 是您要学习的第二门新语言。 PHP 的 PDO API 以及查询语言本身需要时间学习。

首先,您需要一种连接数据库的方法。

function connect() {
    $conn = new PDO(
        'mysql:host=localhost;dbname=DB_NAME',
        'USERNAME',
        'PASSWORD'
    );

    $conn->setAttribute(
        PDO::ATTR_ERRMODE,
        PDO::ERRMODE_EXCEPTION
    );

    return $conn;
}
登录后复制

PDO 是 PHP 用于连接 MySQL 数据库的三个可用 API 之一。

接下来,我们将添加一个辅助函数来从 tweets 表中获取所有记录。请密切注意 query 方法的参数 SELECT * FROM tweets。这是一种用于查询数据库的特殊语言。在本例中,我们使用 * 符号来引用所有行。因此,我们从表中选择所有行,名为 tweets

此函数准备查询,然后获取完整的结果集。

function fetchTweets($conn) {
    $stmt = $conn->query('SELECT * FROM tweets');

    return $stmt->fetchAll(PDO::FETCH_OBJ);
}
登录后复制

现在,阶段设置完毕,我们只需要相应地调用函数即可。

# Connect to the DB
$conn = connect();

# Fetch all rows from attendees table
var_dump(fetchTweets($conn));
登录后复制

转储变量内容的一个简单方法是使用 var_dump 函数。如果将 fetchTweets($conn) 的输出传递给此函数,在浏览器中查看它时,您将看到类似以下内容的内容:

PHP 基础知识:PHP 编程简介

var_dump 对于调试很有帮助,但出于生产目的,最好过滤结果,并将它们正确呈现在页面上。您已经熟悉的 foreach 语句将很好地处理这项工作!

$tweets = fetchTweets($conn);

foreach($tweets as $tweet) {
    echo "<h2>{$tweet->body}</h2>";
    echo "<p>{$tweet->pubDate}</p>";
}
登录后复制

结论

与任何技能一样,编写流利的 PHP 只需要您的时间。可能需要数百个小时才能完全理解,但这没关系。这很有趣,对吧?应该是这样!

最好的学习方法就是实践。构建废弃的项目,就像它们已经过时一样!本教程中概述的技术将带您完成第一阶段,但是,随着您技能的进步,您肯定会继续学习更高级的主题,例如 PHP 框架、设计模式和测试驱动开发。玩得开心!

建议的 Tuts+ 优质资源

  • 现代 PHP 开发人员
  • PHP 基础知识
  • SQL 要点

以上就是PHP 基础知识:PHP 编程简介的详细内容,更多请关注php中文网其它相关文章!

https://www.php.cn/faq/601535.html

发表回复

Your email address will not be published. Required fields are marked *