Home > Backend Development > PHP Tutorial > Learn to build APIs with PHP and GraphQL

Learn to build APIs with PHP and GraphQL

PHPz
Release: 2023-06-19 15:42:01
Original
1190 people have browsed it

With the development of Internet technology, the architecture of front-end and back-end separation has become the mainstream of Web development. In an architecture where the front and back ends are separated, API is an important bridge connecting the front and back ends. When building APIs, PHP and GraphQL, as two popular technology frameworks, are widely favored by developers. This article will introduce how to build an API using PHP and GraphQL.

1. PHP Building API

PHP is an open source scripting language widely used in Web development. Its application scope covers website development, database applications, log processing, image processing and other aspects. . When building an API, PHP can be used as a back-end language to transmit data to the front-end by interacting with the front-end.

  1. Install PHP

First, we need to install the PHP environment. You can check whether PHP has been installed locally by entering the following command in the command line window:

php -v
Copy after login

If the PHP version number is displayed, it means that the PHP environment has been installed. If it is not installed, you need to go to [PHP official website](https://www.php.net/) to download and install it.

  1. Select a framework

In PHP, there are multiple frameworks to choose from, such as Laravel, Symfony, Zend, etc. Among them, Laravel is a framework widely used in PHP web application development. Following are the steps to create an API using Laravel framework.

  1. Create project

You can create a Laravel project named "myapp" locally by entering the following command in the command line window:

composer create-project laravel/laravel myapp --prefer-dist
Copy after login
  1. Create Controller

Before creating the API, you need to create a controller. You can create a controller by entering the following command:

php artisan make:controller MyController
Copy after login

In MyController, you can write the business logic code of the API. For example, in MyController, you can write an API code to query all user information as follows:

public function getAllUsers()
{
    $users = User::all(); // 查询所有用户信息
    return response()->json($users); // 返回JSON格式的用户信息
}
Copy after login

Among them, User represents the user model, which can be defined through Laravel's Eloquent ORM.

  1. Routing

In Laravel, API requests can be processed through routing. You can use the following code to add routing to the API you just created:

Route::get('/users', 'MyController@getAllUsers');
Copy after login

Among them, '/users' represents the URL address of the request, and 'MyController@getAllUsers' represents the controller method that handles the request.

  1. Run the project

Finally, you can run the created Laravel project through the following command:

php artisan serve
Copy after login

By accessing 'http://localhost: 8000/users' to view the JSON format data of all user information.

2. GraphQL construction API

Compared with RESTful API, the advantage of GraphQL is that it allows the front end to initiate a precise query to obtain the required data, reducing the pressure of database query. Below we introduce how to use GraphQL to build an API.

  1. Installing GraphQL

GraphQL can be started as an independent API service, so it needs to be installed first. GraphQL can be installed through the following command:

npm install graphql-yoga
Copy after login
  1. Create Schema

In GraphQL, you need to write a Schema to define the API interface. Schema describes the type of each type of data, the return type of each field, and the input and output parameters of the method. For example, in this Schema, we need to define a User type and an interface for querying all user information. The code is as follows:

const typeDefs = `
  type User {
    id: ID!
    name: String!
    email: String
  }
  type Query {
    getAllUsers: [User]!
  }
`;
Copy after login
  1. Writing Resolver

Resolver implements each field in the Schema and describes how to obtain data. In this example, the Resolver code for querying all user information is as follows:

const resolvers = {
  Query: {
    getAllUsers: async () => {
      const users = await User.find();
      return users;
    },
  },
};
Copy after login
  1. Run the project

Finally, run the GraphQL service. You can start the service with the following command :

const { GraphQLServer } = require('graphql-yoga');

const server = new GraphQLServer({ typeDefs, resolvers });
server.start({ port: 4000 }, () =>
  console.log(`Server is running on localhost:4000`)
);
Copy after login

By accessing 'http://localhost:4000/graphql', you can use the GraphQL Playground tool to test the API.

Conclusion

This article introduced how to build an API using PHP and GraphQL. In PHP, you can use the Laravel framework to create APIs, and in GraphQL, you can use graphql-yoga. By studying the content of this article, I believe that readers have a certain understanding of how to use PHP and GraphQL to build APIs, and can try to apply them in actual projects.

The above is the detailed content of Learn to build APIs with PHP and GraphQL. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template