>백엔드 개발 >PHP 튜토리얼 >PHP와 GraphQL을 사용하여 API 기반 애플리케이션을 구축하는 방법

PHP와 GraphQL을 사용하여 API 기반 애플리케이션을 구축하는 방법

WBOY
WBOY원래의
2023-05-25 08:41:021457검색

오늘날의 디지털 시대에는 많은 애플리케이션이 API(애플리케이션 프로그래밍 인터페이스)를 사용하여 다른 애플리케이션이나 서비스와 상호 작용합니다. 기존 API는 RESTful 아키텍처를 사용하는 반면 GraphQL은 보다 효율적이고 유연하며 확장 가능한 API 인터페이스 솔루션을 제공하는 새로운 API 쿼리 언어입니다. 이 기사에서는 PHP와 GraphQL을 사용하여 API 기반 애플리케이션을 구축하는 방법을 소개합니다.

1. GraphQL이란 무엇인가요?

GraphQL은 API 쿼리 언어이자 런타임 환경입니다. 2012년 Facebook에서 처음에는 내부 API 호출 문제를 해결하기 위해 개발했습니다. 기존 RESTful API와 달리 GraphQL을 사용하면 애플리케이션이 필요한 데이터를 정확하게 설명하고 해당 데이터만 반환하여 보다 효율적인 데이터 쿼리 및 응답 시간을 제공할 수 있습니다.

GraphQL의 주요 기능은 다음과 같습니다.

1. 유형 시스템을 활용하여 API는 물론 쿼리 및 변형의 입력 및 출력을 정의합니다.

2. 유연한 쿼리 기능을 통해 클라이언트는 추가 데이터를 반환하지 않고도 필요한 데이터를 요청할 수 있습니다.

3. 여러 쿼리에 작은 쿼리 중첩을 지원하여 서버와의 데이터 전송 횟수를 줄입니다.

4. API를 빠르게 개발하고 유지 관리할 수 있는 기능을 제공합니다.

2. PHP와 GraphQL을 사용하는 이유는 무엇인가요?

PHP는 광범위한 응용 분야와 강력한 커뮤니티 지원을 갖춘 인기 있는 웹 개발 언어입니다. GraphQL과 결합하면 웹 개발을 위한 보다 유연하고 효율적이며 유지 관리가 쉬운 API 인터페이스 솔루션을 제공할 수 있습니다.

또한 GraphQL은 PHP, JavaScript, Java, Python 등을 포함한 여러 프로그래밍 언어를 지원합니다. 동시에 WebonyxGraphQL, YoushidoGraphQL 등과 같이 PHP에서 GraphQL을 구현하는 데 사용할 수 있는 오픈 소스 프로젝트가 많이 있습니다. 이러한 프로젝트는 개발자가 GraphQL을 사용하여 API 인터페이스를 구현할 수 있는 강력한 도구와 솔루션을 제공합니다.

3. PHP 및 GraphQL을 사용하여 API 기반 애플리케이션 구축

아래에서는 PHP 및 GraphQL을 사용하여 간단한 API 기반 애플리케이션을 구축하는 방법을 보여줍니다.

1. 종속성 설치

작성기 도구를 사용하여 터미널에서 다음 명령을 실행하면 GraphQL을 빠르게 설치할 수 있습니다.

composer require webonyx/graphql-php

2 GraphQL 스키마 작성

GraphQL 스키마는 API 엔드포인트의 핵심입니다. , 쿼리를 정의하는 변형, 유형 및 기타 콘텐츠가 클라이언트에 제공됩니다. WebonyxGraphQL 툴킷은 PHP에서 스키마를 생성, 구문 분석 및 검증하는 데 사용할 수 있습니다.

간단한 스키마 예:

use GraphQLTypeDefinitionObjectType;
use GraphQLTypeDefinitionType;

$queryType = new ObjectType([
    'name' => 'Query',
    'fields' => [
        'echo' => [
            'type' => Type::string(),
            'args' => [
                'message' => Type::string()
            ],
            'resolve' => function ($root, $args) {
                return $args['message'];
            }
        ]
    ]
]);

위 코드는 에코 필드가 있는 간단한 쿼리 유형을 생성합니다. 이 필드는 메시지 매개변수를 수신하고 매개변수를 변경하지 않고 반환합니다.

3. GraphQL 서비스 시작

GraphQL 서비스를 시작하려면 이전에 생성된 스키마를 GraphQL 서비스에 전달해야 합니다. 이는 GraphQL에서 제공하는 서비스 메서드를 호출하여 수행할 수 있습니다.

use GraphQLGraphQL;
use GraphQLTypeSchema;

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

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

$result = GraphQL::executeQuery($schema, $query, null, null, $variableValues);
$output = $result->toArray();
header('Content-Type: application/json; charset=UTF-8');
echo json_encode($output);

4. API

GraphQL 서비스가 시작되면 모든 HTTP 클라이언트를 사용하여 액세스할 수 있습니다. 다음 예에서는 컬을 사용하여 GraphQL API를 요청하는 방법을 보여줍니다.

curl -X POST -H 'Content-Type: application/json' 
    --data '{ "query": "{ echo(message: "Hello, GraphQL!") }" }' 
    http://localhost:8080/graphql

위 명령은 다음 JSON 응답을 반환합니다.

{
  "data": {
    "echo": "Hello, GraphQL!"
  }
}

위 예에서는 PHP와 GraphQL을 사용하여 API 기반 애플리케이션을 구축하는 방법을 보여주었습니다. GraphQL의 효율성, 유연성 및 확장성은 최신 API를 구축하는 데 탁월한 선택이며, PHP의 강력한 성능과 광범위한 애플리케이션은 이상적인 개발 언어입니다.

위 내용은 PHP와 GraphQL을 사용하여 API 기반 애플리케이션을 구축하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.