GraphQL là gì? Bắt đầu với GraphQL
https://viblo.asia/p/graphql-la-gi-bat-dau-voi-graphql-gDVK2nX0KLj
GraphQL là gì? Bắt đầu với GraphQL
Chào mọi người. Sau khi tìm hiểu về GraphQL, mình xin mạo muội chia sẻ chút kiến thức về nó cho mọi người cùng tiếp cận và cách sử dụng GraphQL như thế nào nhé.
I. Giới thiệu về GraphQL
1.1 Tổng quan
GraphQL là ngôn ngữ thao tác và truy vấn dữ liệu nguồn mở cho API, cung cấp cho client 1 cách thức dễ dàng để request chính xác những gì họ cần, giúp việc phát triển API dễ dàng hơn theo thời gian. GraphQL được Facebook phát triển nội bộ vào năm 2012 trước khi phát hành công khai vào năm 2015.
GraphQL bao gồm 3 điểm đặc trưng bao gồm:
Cho phép client xác định chính xác những dữ liệu gì họ cần
GraphQL làm cho việc tổng hợp dữ liệu từ nhiều nguồn dễ dàng hơn
Sử dụng một type system để khai báo dữ liệu.
1.2 Trả về chính xác những gì bạn gửi request
Khi bạn gửi 1 request GraphQL đến API của bạn, bạn sẽ nhận được chính xác những gì bạn yêu cầu trong request, không hơn không kém.
Các truy vấn GraphQL luôn trả về kết quả có thể dự đoán được.
Các ứng dụng sử dụng GraphQL rất nhanh và ổn định vì GraphQL kiểm soát dữ liệu mà nó nhận được chứ không phải máy chủ.
1.3 Nhận nhiều dữ liệu trong một request duy nhất
Các câu query GraphQL không chỉ có thể truy xuất các thuộc tính của một dữ liệu mà còn làm việc trơn tru với các đối tượng khác.
Trong khi các API REST chúng ta hay dùng phải yêu cầu request từ nhiều URL thì API GraphQL lại có thể lấy tất cả dữ liệu mà ứng dụng của bạn cần trong một request duy nhất.
1.4 Mô tả những gì có thể với một type system
API GraphQL được tổ chức theo types và fields, truy cập toàn bộ dữ liệu của bạn từ một endpoint duy nhất.
GraphQL sử dụng các types để đảm bảo ứng dụng của bạn chỉ request những gì có thể, ngoài ra GraphQL còn giải thích các lỗi 1 cách rất dễ hiểu.
OK, như vậy sau 1 hồi đọc lý thuyết thì cũng cần phải có chút thực hành để rõ hơn các bạn nhỉ?
II. Bắt đầu với GraphQL:
2.1 Chuẩn bị
Với GraphQL bạn có thể code bằng nhiều ngôn ngữ khác nhau, như: C# / .NET, Go, Java, PHP, Python, Ruby, Perl, ... Các bạn có thể tham khảo code demo tại đây: https://graphql.org/code/
Trong bài này mình dùng NodeJS 10.15.1 để demo.
2.2 Khởi tạo project
Cách đơn giản nhất để chạy máy chủ API GraphQL là sử dụng module express
(một khung ứng dụng web phổ biến cho Node.js). Bạn sẽ cần cài đặt thêm 2 package express-graphql
, graphql.
express
: Chạy máy chủ web và thực hiện truy vấn trực tiếp với hàmgraphql
express-graphql
: Gắn máy chủ API GraphQL trênendpoint
HTTP/graphql
graphql
: Package để sử dụng API GraphQL
Chạy command line:
Hoặc tạo file package.json với nội dung:
2.3 Tạo server
Tiếp đến tạo file server.js
để chạy server:
2.4 Start server
Sau khi đã tạo được file server, mình sẽ khởi chạy server node vừa tạo với command:
2.5 Test
Nếu bạn truy cập trong trình duyệt web http://localhost:4000/graphql, bạn sẽ thấy một giao diện cho phép bạn nhập các truy vấn.
GraphiQL
là một công cụ tuyệt vời để debug và kiểm tra server, vì vậy mình khuyên bạn nên chạy nó bất cứ khi nào ứng dụng của bạn ở chế độ develop.
Như vậy, mình vừa test thử cho các bạn cách chạy máy chủ và sử dụng trên giao diện GraphiQL để đưa ra các truy vấn. Bước tiếp theo là tìm hiểu cách đưa ra các truy vấn GraphQL từ client.
GraphQL Clients
Thực hiện test curl trên command line:
Data response:
III. Tổng kết
Mong rằng sau bài viết này các bạn có thể tiếp cận được GraphQL 1 cách nhanh chóng và dễ dàng hơn...
Cảm ơn các bạn đã đọc bài viết của mình!
Thao khảo
Last updated