GraphQL can be implemented in any language. Today let’s take a look at Java server implementation for GraphQL. Let’s use Maven and assume that we already have set up the project structure. What's next?
Dependencies
To run GraphQL in your Java project you only need one library which is GraphQL Java implementation. However, there are a couple of libs you might find useful when using GraphQL Java:
- Spring Boot - GraphQL Java Spring and Spring Boot integration that will handle any HTTP related tasks, expose the GraphQL service on the
/graphql
endpoint of your app and acceptPOST
requests containing your GraphQL payload. - GraphQL Java Tools - this library allows you to use the GraphQL SDL to build your graphql-java schema.
- GraphQL Java Servlet - implementation of GraphQL Java Servlet including support for libraries like Relay.js, Apollo etc. and wraps the Java implementation of GraphQL provided by GraphQL Java.
So add dependencies you need to Project Object Model file (pom.xml):
Define the schema
GraphQL Schema is the centerpiece of any GraphQL implementation so we definitely need one before going any further. To make it easier to understand the operation that a server can perform GraphQL defined a universal schema syntax know as SDL (Schema Definition Language).
SDL定义项目的元素,例如:
-
type
(the most basic GraphQL schema components): -
query
(asking the server for the data) -
mutation
(manipulating the data):The fastest way to define your schema is to use GraphQL Editor. It allows you to define your schema traditionally (code) or shape it from visual nodes.
Server
There plenty of servlet containers to choose from, both open source and commercial, so just pick the one you feel comfortable with. Let's use Jetty for our example and implement it via a Maven Plugins:
您已经准备就绪,接下来的步骤是:
- 添加一些更基本的服务器配置,例如正确的Java版本或Servlet规范创造GraphQL端点公开您的API的类定义解析器
If you want to read more details about GraphQL Java implementation to take a look at Bojan's tutorial regarding setting up GraphQL Java server on https://www.howtographql.com/