您好,登錄后才能下訂單哦!
要在ThinkPHP(TP)框架中集成GraphQL,你需要遵循以下步驟:
首先,你需要為PHP安裝GraphQL庫。我們將使用webonyx/graphql-php庫。通過Composer安裝此庫:
composer require webonyx/graphql-php
接下來,你需要定義GraphQL schema,它描述了你的API的數據類型和可用查詢。創建一個名為schema.graphql
的文件,并添加以下內容:
type Query {
echo(message: String!): String
}
這個簡單的schema定義了一個echo
查詢,它接受一個字符串參數message
,并返回一個字符串。
現在,你需要實現echo
查詢的解析器。在你的項目中創建一個新的文件夾,例如graphql
,然后創建一個名為resolvers.php
的文件。在這個文件中,添加以下內容:
<?php
use GraphQL\Type\Definition\ResolveInfo;
function resolveEcho($rootValue, $args, $context, ResolveInfo $info)
{
return $args['message'];
}
這個函數將處理echo
查詢的解析。
現在,你需要創建一個GraphQL服務器,它將處理客戶端發送的GraphQL請求。在graphql
文件夾中創建一個名為server.php
的文件,并添加以下內容:
<?php
require_once 'vendor/autoload.php';
require_once 'resolvers.php';
use GraphQL\GraphQL;
use GraphQL\Type\Schema;
use GraphQL\Type\Definition\ObjectType;
use GraphQL\Type\Definition\Type;
$queryType = new ObjectType([
'name' => 'Query',
'fields' => [
'echo' => [
'type' => Type::string(),
'args' => [
'message' => Type::nonNull(Type::string()),
],
'resolve' => 'resolveEcho',
],
],
]);
$schema = new Schema([
'query' => $queryType,
]);
$rawInput = file_get_contents('php://input');
$input = json_decode($rawInput, true);
$query = $input['query'];
$variableValues = isset($input['variables']) ? $input['variables'] : null;
try {
$result = GraphQL::executeQuery($schema, $query, null, null, $variableValues);
$output = $result->toArray();
} catch (\Exception $e) {
$output = [
'errors' => [
[
'message' => $e->getMessage(),
],
],
];
}
header('Content-Type: application/json');
echo json_encode($output);
最后,你需要配置ThinkPHP的路由,以便將GraphQL請求指向剛剛創建的服務器。打開application/route.php
文件,并添加以下內容:
<?php
use think\facade\Route;
Route::post('graphql', function () {
require_once 'graphql/server.php';
});
現在,你已經在ThinkPHP框架中集成了GraphQL。你可以通過發送POST請求到/graphql
端點來測試你的GraphQL API。例如,使用以下請求體:
{
"query": "query { echo(message: \"Hello, world!\") }"
}
你應該會收到以下響應:
{
"data": {
"echo": "Hello, world!"
}
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。