0

0

如何在Ubuntu 18.04上配置PHP与GraphQL的详细教程?

看不見的法師

看不見的法師

发布时间:2025-11-09 10:32:02

|

610人浏览过

|

来源于php中文网

原创

首先安装LAMP环境并验证PHP,再通过Composer安装webonyx/graphql-php库,接着创建schema.php定义模式和graphql.php作为入口脚本处理请求,最后配置Apache启用重写模块以支持GraphQL API。

如何在ubuntu 18.04上配置php与graphql的详细教程?

如果您尝试在Ubuntu 18.04上搭建PHP与GraphQL的集成环境,但无法正确解析请求或执行查询,则可能是由于环境配置不完整或依赖缺失。以下是完成该配置的具体步骤:

一、安装LAMP环境

LAMP(Linux, Apache, MySQL, PHP)是运行PHP应用的基础环境。在Ubuntu 18.04上安装这些组件可确保PHP能够正常运行。

1、更新系统包列表:sudo apt update

2、安装Apache2:sudo apt install apache2

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

3、安装MySQL服务器:sudo apt install mysql-server

4、安装PHP及其常用扩展:sudo apt install php libapache2-mod-php php-mysql php-curl php-json php-mbstring

5、重启Apache服务以加载PHP模块:sudo systemctl restart apache2

二、验证PHP安装

确认PHP已正确安装并可由Web服务器解析,避免后续GraphQL库无法加载。

1、在/var/www/html目录下创建info.php文件:sudo nano /var/www/html/info.php

2、输入以下内容并保存:
<?php
phpinfo();
?>

3、在浏览器中访问http://localhost/info.php,若显示PHP信息页面则表示安装成功。

4、测试完成后删除该文件以保障安全:sudo rm /var/www/html/info.php

三、安装GraphQL PHP库

使用第三方GraphQL实现库(如webonyx/graphql-php)来支持GraphQL查询解析和执行。

1、进入网站根目录:cd /var/www/html

2、使用Composer安装GraphQL PHP库:composer require webonyx/graphql-php

3、若未安装Composer,先执行:sudo apt install composer

ModelGate
ModelGate

一站式AI模型管理与调用工具

下载

4、再次运行安装命令以确保依赖被正确引入。

四、创建GraphQL模式文件

定义GraphQL的Schema和类型,用于处理客户端查询请求。

1、创建schema.php文件:nano /var/www/html/schema.php

2、添加基础类型和查询结构示例代码:

<?php
require_once 'vendor/autoload.php';

use GraphQL\Type\Definition\ObjectType;
use GraphQL\Type\Definition\Type;
use GraphQL\Type\Schema;

$queryType = new ObjectType([
    'name' => 'Query',
    'fields' => [
        'hello' => [
            'type' => Type::string(),
            'resolve' => function () {
                return 'Hello World';
            }
        ]
    ]
]);

$schema = new Schema(['query' => $queryType]);
?>

五、设置GraphQL入口脚本

创建一个PHP脚本接收HTTP请求,解析GraphQL查询并返回结果。

1、创建graphql.php文件:nano /var/www/html/graphql.php

2、写入以下处理逻辑:

<?php
require_once 'vendor/autoload.php';
require_once 'schema.php';

use GraphQL\GraphQL;

try {
    $input = json_decode(file_get_contents('php://input'), true);
    $query = $input['query'];
    $variableValues = isset($input['variables']) ? $input['variables'] : null;

    $result = GraphQL::executeQuery($schema, $query, null, null, $variableValues);
    $output = $result->toArray();
} catch (\Exception $e) {
    $output = ['error' => $e->getMessage()];
}
header('Content-Type: application/json');
echo json_encode($output);
?>

3、保存后可通过POST请求向该文件发送GraphQL查询。

六、配置Apache虚拟主机支持重写规则

启用mod_rewrite模块,以便支持友好的URL路径或API路由。

1、启用重写模块:sudo a2enmod rewrite

2、编辑默认站点配置:sudo nano /etc/apache2/sites-available/000-default.conf

3、在<Directory /var/www/html>段落内添加:

AllowOverride All
Require all granted

4、保存后重启Apache:sudo systemctl restart apache2

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

162

2023.12.25

mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

514

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

267

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 850人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号