用 PHP 构建 Pokémon API:初学者指南

用 php 构建 pokémon api:初学者指南

在本指南中,我们将逐步完成创建一个基本 php 项目的步骤,该项目将 pokémon api 与 flight 框架以及 zebra_curl 和 latte 等附加包结合使用。我们将探索设置项目、添加路线和渲染视图。

tl;dr:在 flight 中制作一个简单的基于 api 的项目并不难。查看本指南中使用的代码。

第 1 步:设置环境

首先,我们需要设置一个新的项目文件夹。打开终端,导航到所需位置,然后运行以下命令来创建新目录并输入它。

mkdir flight-pokeapicd flight-pokeapi

第 2 步:安装 composer

在深入研究代码之前,我们需要确保 composer 已安装。 composer 是 php 的依赖管理器,它将帮助我们包含必要的库。

如果您没有安装 composer,您可以使用以下命令安装它:

php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"php composer-setup.phpphp -r "unlink('composer-setup.php');"

现在 composer 已安装在名为 ./composer.phar 的当前文件中,让我们管理我们的依赖项。

立即学习“PHP免费学习笔记(深入)”;

第三步:安装依赖项

要管理所需的包,我们只需要使用composer添加它们即可。

./composer.phar require flightphp/core stefangabos/zebra_curl latte/latte

这将安装:

flight php:一个轻量级的 php 框架。zebra_curl:处理 http 请求的 curl 包装器。latte:用于渲染视图的模板引擎。

第四步:设置index.php

接下来,让我们为应用程序创建入口点:public/index.php。该文件将设置我们的应用程序、配置路由并处理视图的渲染。

创建public目录和index.php文件:

mkdir publictouch public/index.php

现在将以下内容添加到index.php:

settempdirectory(__dir__ . '/../temp');flight::map('render', function(string $template_path, array $data = []) use ($latte) {  $latte->render(__dir__ . '/../views/' . $template_path, $data);});// setup zebra_curl for handling http requests$curl = new zebra_curl();$curl->cache(__dir__ . '/../temp');flight::map('curl', function() use ($curl) {     return $curl; });// define a simple routeflight::route('/', function() {  echo 'hello world!';});flight::start();

在此文件中:

我们加载 composer 的自动加载器。设置 latte 以渲染视图。映射一个自定义渲染方法,该方法使用 latte 渲染 /views 文件夹中的模板。设置 zebra_curl 来处理 api 请求,并在我们想要调用它时将其映射到使用 flight::curl()。为主页 (/) 定义一个简单的路由,仅返回“hello world!”

如果您想测试此设置,您可以从公共目录启动 php 服务器:

php -s localhost:8000 -t public/

现在,在浏览器中访问 http://localhost:8000/,您应该会看到“hello world!”。酷吧?

第5步:添加路由

现在我们已经设置了基本路线,让我们添加一个使用 pokémon api 的更复杂的路线。更新 public/index.php 以包含以下代码:

flight::group('/pokemon', function(router $router) {    // route to list all pokémon types    $router->get('/', function() {        $types_response = json_decode(flight::curl()->scrap('https://pokeapi.co/api/v2/type/', true));        $results = [];        while ($types_response->next) {            $results = array_merge($results, $types_response->results);            $types_response = json_decode(flight::curl()->scrap($types_response->next, true));        }        $results = array_merge($results, $types_response->results);        flight::render('home.latte', [ 'types' => $results ]);    });});

我们创建了一个 /pokemon 路线组。路线组“包围”路线,并允许我们为组内的所有路线定义通用功能。/pokemon 路由通过使用 zebra_curl 从 pokémon api 获取所有可用的 pokémon 类型来列出它们。这还不能工作,因为我们需要添加 home.latte 视图来显示 pokémon 类型。

第 6 步:使用 latte 渲染视图

现在我们正在获取数据,让我们设置视图来显示它。创建views目录并添加latte模板文件以显示神奇宝贝类型。

mkdir viewstouch views/home.latte

将以下代码添加到views/home.latte:

welcome to the pokemon world!

types of pokemon

在此文件中:

我们循环遍历从路由传递过来的 $types 数组并显示每个 pokémon 类型的名称。

现在,访问 /pokemon 将显示所有神奇宝贝类型的列表!

第 7 步:分组并添加更多路线

让我们扩展 pokémon 路线,以获取特定类型和单个 pokémon 的更多详细信息。将以下路线添加到您的 /pokemon 组:

// route to fetch a specific pokémon type and list all associated pokémon$router->get('/type/@type', function(string $type) {    $curl = flight::curl();    $type_response = json_decode($curl->scrap('https://pokeapi.co/api/v2/type/' . $type, true));    $pokemon_urls = [];    foreach($type_response->pokemon as $pokemon_data) {        $pokemon_urls[] = $pokemon_data->pokemon->url;    }    $pokemon_data = [];    // the little & here is important to pass the variable by reference.    // in other words it allows us to modify the variable inside the closure.    $curl->get($pokemon_urls, function(stdclass $result) use (&$pokemon_data) {        $pokemon_data[] = json_decode($result->body);    });    flight::render('type.latte', [         'type' => $type_response->name,        'pokemons' => $pokemon_data    ]);});

在这条路线中,我们:

获取特定神奇宝贝类型的详细信息,包括所有相关的神奇宝贝。发送多个 api 请求以获取每个 pokémon 的详细信息。使用模板 (type.latte) 渲染数据。

接下来,创建 type.latte 视图:

touch views/type.latte

将以下内容添加到type.latte:

{$type|firstupper}

此模板显示与特定类型关联的每个神奇宝贝的名称。

第8步:有效果吗?

此时,您已经使用 flight php、用于 api 请求的 zebra_curl 和用于视图渲染的 latte 设置了基本的 pokémon api 使用者。您可以通过添加更多路线和完善模板来进一步扩展此项目。

要查看您的项目,请从公共目录启动 php 服务器:

php -s localhost:8000 -t public/

现在,在浏览器中访问 http://localhost:8000/pokemon,您应该会看到 pokémon 类型的列表。

故障排除

如果您需要帮助或遇到问题,您可以在 github 中查看完整代码,看看您可能在哪里犯了错误。

希望您喜欢这个小教程。如果您有任何疑问或需要帮助,请随时在下面的评论中提问。快乐编码!

以上就是用 PHP 构建 Pokémon API:初学者指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1246404.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月9日 18:33:49
下一篇 2025年12月9日 18:34:01

相关推荐

  • 如何更新作曲家

    要更新系统上的 composer,请按照以下步骤操作: 全局更新 composer 要更新系统上的 composer,请按照以下步骤操作: 全局更新 composer: 如果您已经全局安装了 composer(可在终端中作为 composer 命令使用),则可以使用以下命令来更新它: compose…

    2025年12月9日
    000
  • 如何在 GitHub 三方授权中正确使用 access_token?

    github三方授权登录 access_token使用问题 在利用 github 进行三方登录时,将 access_token 放到请求头’authorization’字段可能导致获取用户令牌失败。github 授权文档说明,应使用指定格式设置 authorization 字…

    2025年12月9日
    000
  • 如何在 4 中使用 Laravel Pennant 管理功能标志

    管理功能标志是现代软件开发的一个关键方面,它允许开发人员在不重新部署代码的情况下打开和关闭功能。在 laravel 中,可以使用 laravel 10 中引入的 laravel pennant 包来管理功能标志。 pennant 提供了一种简单有效的方法来管理功能标志,使您能够控制对新功能的访问、进…

    2025年12月9日
    000
  • 【Laravel vx Docker】利用 Laravel Sail 高效搭建 Laravel 应用开发环境

    关于 laravel sail laravel sail 是 laravel 框架的官方开发环境。 sail 提供了一个轻量级的命令行界面 (cli),可以使用 docker 轻松设置和管理 laravel 应用程序开发环境。下面,我们讲解一下 laravel sail 的主要特性和使用方法。 使用…

    2025年12月9日
    000
  • 如何正确使用 Access Token 进行 GitHub 三方授权登录?

    github 三方授权登录:access token 使用指南 在使用 github 进行第三方授权登录时,将 access token 放入请求头的“authorization”字段中可能会遇到无法成功获取用户令牌的问题。 根据官方文档,github 授权头部的正确格式应为: authorizat…

    2025年12月9日
    000
  • Authorization 请求头如何正确的设置 Access Token?

    github 三方授权登录 access token 使用 在进行 github 三方授权登录时,用户需要提供来自 github 的 access token。access token 应该被放置在请求头的 authorization 字段中,正确格式如下: authorization: beare…

    2025年12月9日
    000
  • GitHub 三方登录 access_token 如何正确使用?

    github 三方授权登录中 access_token 使用问题 在使用 github 进行三方登录时,将 access_token 放置于请求头的’authorization’字段中,却无法成功获取用户令牌。 根据 github 授权文档,正确的授权头部应为”a…

    2025年12月9日
    000
  • 使用 Github 三方授权登录时 Authorization 字段的正确格式是什么?

    github 三方授权登录 access_token 使用问题 在使用 github 进行三方登录时,将 access token 放入请求头的 authorization 字段却一直未成功获取到用户的令牌。 问题代码 private async getgithubuserinfo(accessto…

    2025年12月9日
    000
  • 授权:了解 Laravel 中的策略

    控制用户在应用程序中可以执行或不能执行的操作是构建实际应用程序时需要做的最重要的事情之一。 例如,在待办事项应用程序中,您不希望用户能够编辑或删除其他用户的待办事项。 在本文中,您将学习在 laravel 中实现此目的的无缝方法之一,即使用策略来控制用户可以通过构建简单的待办事项应用程序执行哪些操作…

    2025年12月9日
    000
  • 如何使用 Eloquent 计算多列的总和

    在本教程中,我将向您展示如何使用 eloquent 计算多列的总和。 laravel 提供了通过“sum”方法聚合列值的内置支持,允许您计算列值的总和。您可以学习如何使用 eloquent 计算列的平均值 这里的主要警告是 eloquent 一次只能对一列求和。要对 2 列求和,我们可以调用 sum…

    2025年12月9日
    000
  • Laravel 中新的 `@bool` Blade 指令!

    新的 @bool blade 指令 laravel 的 blade 模板引擎获得了一个方便的新功能:@bool 指令。这允许您直接将布尔值打印到字符串中或在对象构造中使用它们,使您的 javascript 集成更干净、更高效。 使用方法如下: let config = { isactive: @bo…

    2025年12月9日
    000
  • 了解 PSR – PHP 编码风格指南

    如果您使用 php 进行开发已有一段时间,您可能遇到过术语 psr-12。它是 php 社区中最广泛接受的编码标准之一,旨在确保不同项目之间 php 代码库的一致性。无论您是单独工作还是作为团队的一员,遵循 psr-12 都可以使您的代码更干净、更具可读性并且更易于维护。在本博客中,我们将详细介绍 …

    2025年12月9日
    000
  • Laravel 自定义辅助函数 – 快速提示

    辅助函数在 laravel 开发者中非常流行。它们提供了对一些巧妙算法的访问,可以使用单个语句在您的代码中使用。 最知名的辅助函数可能是 url(),它允许您生成内部应用程序 url。 另一个很棒的帮手是 retry() 函数,例如:https://laravel.com/docs/11.x/hel…

    2025年12月9日
    000
  • Lithe 上的 PHP 会话管理:从基础配置到高级使用

    当我们谈论 web 应用程序时,首要需求之一是在用户浏览页面时维护用户的信息。这就是 lithe 中的 会话管理 的用武之地,它允许您存储登录信息或用户首选项等数据。 安装简单快捷 要开始在 lithe 中使用会话,您只需通过 composer 安装会话中间件。只需在项目中的终端中运行以下命令: c…

    2025年12月9日
    000
  • 使用 Lithe 进行 PHP 会话管理:从基本设置到高级使用

    当我们谈论 web 应用程序时,首要需求之一是在用户浏览页面时维护用户信息。这就是 lithe 中的 会话管理 的用武之地,它允许您存储登录信息或用户首选项等数据。 安装简单快捷 要开始在 lithe 中使用会话,您只需通过 composer 安装会话中间件。只需在项目中的终端中运行以下命令: co…

    2025年12月9日
    000
  • 使用接口和特征在 PHP 中编写灵活的枚举

    php 枚举是一个强大的工具,用于定义一组固定的常量,同时使您能够将功能附加到这些常量。除了简单地保存值之外,枚举还可以实现接口并使用特征来扩展其功能。这使得它们在复杂的应用程序中更加灵活和可重用。 在这篇文章中,我们将通过将枚举与接口和特征相结合,将您的 php 枚举设计提升到一个新的水平。我们将…

    2025年12月9日
    000
  • 发布开源包:真的值得吗?

    很多人喜欢说开源社区是现代发展的支柱。但对于普通开发者来说,投入时间和精力来发布 python 和 php 包真的值得吗?一些人认为,为了获得知名度和机会,任何困难都是值得的。其他人则认为这只是一种“昂贵的爱好”,与付出的努力相比,回报即使不是不存在,也是微乎其微的。 现实情况是,大多数为开源包做出…

    2025年12月9日
    000
  • 使用 Twig 通过 PHP 渲染 Markdown

    twig 是使用 symfony 开发 web 应用程序时渲染 html 的首选模板引擎。然而,twig 的灵活性不仅仅限于生成 html 页面。它可以成为跨多个渠道交付内容的强大工具,例如生成 markdown 文件、json 输出,甚至纯文本,所有这些都来自同一组内容。 这种适应性使您可以为不同…

    2025年12月9日
    000
  • 为什么你应该为开源付费

    几乎每个开发人员每天都会使用开源项目,无论是在 VS Code 中编写代码、使用 TailwindCSS 加速开发,还是使用最流行的 PHP 框架 Laravel 构建强大的 Web 应用程序。我们不要忘记用于创建管理面板的 FilamentPHP。 这些项目不是鬼建的,而是由鬼魂建造的。它们是由人…

    2025年12月9日
    000
  • php网络编程指南:HTTP协议入门

    PHP 网络编程指南:HTTP 协议入门 简介 HTTP(超文本传输协议)是一种客户端-服务器协议,用于在万维网上传输数据。它是 Web 的基础,让我们能够通过浏览器访问网站。本指南将介绍 HTTP 协议的基础知识,并通过代码示例展示如何在 PHP 中使用它。 HTTP 消息格式 立即学习“PHP免…

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信