文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

从零开始构建 PHP GraphQL 后端:一步一步教你

2024-02-07 19:11

关注

1. 前提条件

在开始构建 PHP GraphQL 后端之前,您需要确保已经满足以下前提条件:

- PHP 7.2+
- Composer
- GraphQL PHP 库

2. 初始化项目

首先,使用 Composer 创建一个新的 PHP 项目。

composer create-project --prefer-dist laravel/laravel your-project-name

接下来,安装 GraphQL PHP 库。

composer require graphql/graphql:^0.14

3. 创建 GraphQL Schema

GraphQL Schema 定义了您的 API 的结构,包括数据类型、查询和突变。在 app/GraphQL/Types 目录下创建一个新的文件 UserType.php,内容如下:

namespace AppGraphQLTypes;

use GraphQLTypeDefinitionType;
use GraphQLTypeDefinitionObjectType;

class UserType extends ObjectType
{
    public function __construct()
    {
        $config = [
            "name" => "User",
            "description" => "A user",
            "fields" => [
                "id" => [
                    "type" => Type::string(),
                    "description" => "The ID of the user"
                ],
                "name" => [
                    "type" => Type::string(),
                    "description" => "The name of the user"
                ],
                "email" => [
                    "type" => Type::string(),
                    "description" => "The email of the user"
                ],
            ]
        ];

        parent::__construct($config);
    }
}

同样的方法,分别在 app/GraphQL/Types 目录下创建 QueryType.phpMutationType.php 文件,定义查询和突变类型。

4. 定义查询和突变解析器

接下来,需要定义查询和突变解析器,这些解析器将处理 GraphQL 请求并返回数据。在 app/GraphQL/Resolvers 目录下创建文件 UserResolver.php,内容如下:

namespace AppGraphQLResolvers;

use AppUser;
use GraphQLTypeDefinitionResolveInfo;

class UserResolver
{
    /**
     * 获取所有用户
     *
     * @param mixed $rootValue
     * @param array $args
     * @param mixed $context
     * @param ResolveInfo $info
     * @return mixed
     */
    public function all($rootValue, array $args, $context, ResolveInfo $info)
    {
        return User::all();
    }

    /**
     * 获取单个用户
     *
     * @param mixed $rootValue
     * @param array $args
     * @param mixed $context
     * @param ResolveInfo $info
     * @return mixed
     */
    public function find($rootValue, array $args, $context, ResolveInfo $info)
    {
        return User::find($args["id"]);
    }

    /**
     * 创建一个用户
     *
     * @param mixed $rootValue
     * @param array $args
     * @param mixed $context
     * @param ResolveInfo $info
     * @return mixed
     */
    public function create($rootValue, array $args, $context, ResolveInfo $info)
    {
        $user = new User();
        $user->name = $args["name"];
        $user->email = $args["email"];
        $user->save();

        return $user;
    }

    /**
     * 更新一个用户
     *
     * @param mixed $rootValue
     * @param array $args
     * @param mixed $context
     * @param ResolveInfo $info
     * @return mixed
     */
    public function update($rootValue, array $args, $context, ResolveInfo $info)
    {
        $user = User::find($args["id"]);
        $user->name = $args["name"];
        $user->email = $args["email"];
        $user->save();

        return $user;
    }

    /**
     * 删除一个用户
     *
     * @param mixed $rootValue
     * @param array $args
     * @param mixed $context
     * @param ResolveInfo $info
     * @return mixed
     */
    public function delete($rootValue, array $args, $context, ResolveInfo $info)
    {
        $user = User::find($args["id"]);
        $user->delete();

        return $user;
    }
}

5. 创建 GraphQL 服务提供者

创建一个 GraphQL 服务提供者 app/Providers/GraphQLServiceProvider.php,内容如下:

namespace AppProviders;

use IlluminateSupportServiceProvider;
use GraphQLTypeSchema;
use GraphQLServerServerConfig;
use GraphQLServerStandardServer;
use NuwaveLighthouseSchemaTypeRegistry;
use NuwaveLighthouseGraphQL;

class GraphQLServiceProvider extends ServiceProvider
{
    /**
     * Bootstrap the application services.
     *
     * @return void
     */
    public function boot()
    {
        $this->app->singleton(
            Schema::class,
            function () {
                $schema = new Schema([
                    "query" => TypeRegistry::get(GraphQL::TYPE_QUERY),
                    "mutation" => TypeRegistry::get(GraphQL::TYPE_MUTATION)
                ]);

                return $schema;
            }
        );

        $this->app->singleton(
            StandardServer::class,
            function () {
                $config = ServerConfig::create();

                return new StandardServer($config);
            }
        );
    }

    /**
     * Register the application services.
     *
     * @return void
     */
    public function register()
    {
        $this->app->make(GraphQL::class);
    }
}

6. 注册 GraphQL 服务提供者

config/app.php 文件中注册 GraphQL 服务提供者:

"providers" => [
    // Other providers

    AppProvidersGraphQLServiceProvider::class,
]

7. 设置 GraphQL 路由

routes/api.php 文件中设置 GraphQL 路由:

use GraphQLServerStandardServer;

Route::post("/graphql", function (StandardServer $server) {
    return $server->process();
});

8. 启动 GraphQL 服务

public/index.php 文件中启动 GraphQL 服务:

define("LARAVEL_START", microtime(true));

require __DIR__."/../bootstrap/autoload.php";

$app = require_once __DIR__."/../bootstrap/app.php";

$server = $app->make(StandardServer::class);

$server->process();

9. 测试 GraphQL API

现在您可以使用您的 GraphQL 客户机或工具来测试您的 GraphQL API。例如,您可以使用 GraphiQL IDE 来发送 GraphQL 查询和突变。

10. 结语

通过以上步骤,您已经成功构建了一个功能完整的 PHP GraphQL 后端。您可以继续扩展您的 GraphQL Schema 和解析器,以满足您的 API 需求。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯