GraphQL-Java用来向前端返回json数据

简介: GraphQL-Java用来向前端返回json数据

GraphQL

GraphQL是 Facebook 开发的一种查询语言,用于在复杂的应用程序的数据模型中,描述数据要求。
官网:http://graphql.org/
GraphQL-Java:https://github.com/graphql-java/graphql-java

GraphQL这个词刚入我眼帘没多久,刚开始也只是看了一下简介而已。由于本人编程能力和知识储备不好,最近想用一个一个小项目来实践一下,采用Java语言写一个web项目,打算使用Java中对我来说全新的知识,经过细想后决定采用struts2框架+bootstrap框架(后台管理)+MUI框架(移动端),一边学习一边做项目,让自己在实践中获取到更多的知识。

在写到数据库连接的时候,本来是想用C3P0来管理数据库连接的,想起前两天在开源中国看到另一个数据库连接池HikariCP,数据显示它比C3P0性能更好,然后就采用了HikariCP,毕竟我这次的目的是学习新的知识,所以毅然用了它。

eclipse+maven(现学现用)+struts2(现学现用)+bootstrap(用过几次)+MUI(现学现用)


GraphQL-Java github示例代码:

import graphql.schema.GraphQLObjectType;
import graphql.schema.GraphQLSchema;
import java.util.Map;

import static graphql.Scalars.GraphQLString;
import static graphql.schema.GraphQLFieldDefinition.newFieldDefinition;
import static graphql.schema.GraphQLObjectType.newObject;

public class HelloWorld {

    public static void main(String[] args) {
        GraphQLObjectType queryType = newObject()
                .name("helloWorldQuery")
                .field(newFieldDefinition()
                        .type(GraphQLString)
                        .name("hello")
                        .staticValue("world"))
                .build();

        GraphQLSchema schema = GraphQLSchema.newSchema()
                .query(queryType)
                .build();

        GraphQL graphQL = GraphQL.newGraphQL(schema).build();

        Map<String, Object> result = graphQL.execute("{hello}").getData();
        System.out.println(result);
        // Prints: {hello=world}
    }
}

百度了GraphQL-Java的相关用法:http://blog.csdn.net/qq362228416/article/details/50854980

我把上面这为朋友的代码直接复制粘贴运行,发现无法得到正确的数据,打印出来的信息全是xxx=null,当时很纳闷,我这半桶水的知识对这百来行代码无法找出问题所在。然后只能尝试结合官方的示例代码和前面这位朋友的用法,尝试着写。


前期准备工作:写一个结构类

public class ZyVo {
//专业类
    private int    id, xy, readnum;
    private String code, title, text, jc, pic, general;
//.....getXXX,setXXX
}

然后编写GraphQL与上面这个类的结构对应信息:

//import graphql.Scalars;//相关包
GraphQLObjectType beanVo = newObject().name("zy")
                .field(newFieldDefinition().name("id").type(Scalars.GraphQLInt).build())//类型一定要与结构类字段的类型相对应
                .field(newFieldDefinition().name("xy").type(Scalars.GraphQLInt).build())
                .field(newFieldDefinition().name("code").type(Scalars.GraphQLString).build())
                .field(newFieldDefinition().name("title").type(Scalars.GraphQLString).build())
                .field(newFieldDefinition().name("jc").type(Scalars.GraphQLString).build())
                .field(newFieldDefinition().name("pic").type(Scalars.GraphQLString).build())
                .field(newFieldDefinition().name("general").type(Scalars.GraphQLString).build())
                .field(newFieldDefinition().name("text").type(Scalars.GraphQLString).build())
                .field(newFieldDefinition().name("readnum").type(Scalars.GraphQLInt).build())
                .build();


之后写一个对数据进行查询的东西(我也不知道怎么描述这个东西所以就称他为东西了)

GraphQLFieldDefinition findforid = GraphQLFieldDefinition.newFieldDefinition().name("zy")
                .argument(//这里用GraphQL些查询语句时传入的参数
                        newArgument()
                        .name("id")//参数名为id
                        .type(Scalars.GraphQLInt)//参数类型
                        .build()
                        )
                .type(beanVo)//绑定GraphQL的一个结构,就是上面的那段代码
                .dataFetcher(environment -> {
                    // 获取查询参数
                    int id = environment.getArgument("id");
                    ZyProxy zyProxy = new ZyProxy();//一个对ZyVo数据进行增删改查代理的操作类
                    ZyVo vo = null;
                    try {
                        vo = zyProxy.findById(id);//通过ID查找数据
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                    System.out.println(vo);
                    
                    return vo;
                }).build();


//我也不懂怎么称呼下面这个代码

GraphQLSchema schema = GraphQLSchema.newSchema()
                .query(newObject().name("GraphQuery")
                                               .field(findforid)//半桶水不知道怎么描述它
                                               .build()
                 )
                .build();


//写一条类似查询语句的东西,GraphQL会解析它然后返回相关的结果

String ghql = "{zy(id:1){id,title,readnum,text,pic,jc}}";
//最后就是获取结果了
ExecutionResult re = new GraphQL(schema).execute(ghql);
Map<String, Object> result1 = (Map<String, Object>) re.getData();
//把它打印出来
System.out.println(result1);//结果:{zy={id=1, title=服装与服饰设计, readnum=0, text=null, pic=null, jc=null}}
//可以把它加入到json对象中

JSONObject json = new JSONObject();
json.putAll(result1);
System.out.println(json);//输出就成了json数据了:{"zy":{"id":1,"title":"服装与服饰设计","readnum":0}}


至此我的目的达到了,灵活定制我想要的json数据,因为有时候有的字段并不想让前端看到,用这个方法感觉很方便。

当然,我打开它方式可能很不正确,恳请各位大神展示GraphQL-Java更多的用法,小白坐等。

目前我只用它来生成我想要的json数据,因为可以很方便的定制我想要的数据,而不用更改其他Java代码,只需要改一条字符串信息就行了。




目录
相关文章
|
17天前
|
数据采集 JSON 数据处理
抓取和分析JSON数据:使用Python构建数据处理管道
在大数据时代,电商网站如亚马逊、京东等成为数据采集的重要来源。本文介绍如何使用Python结合代理IP、多线程等技术,高效、隐秘地抓取并处理电商网站的JSON数据。通过爬虫代理服务,模拟真实用户行为,提升抓取效率和稳定性。示例代码展示了如何抓取亚马逊商品信息并进行解析。
抓取和分析JSON数据:使用Python构建数据处理管道
|
2天前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
6天前
|
JSON 缓存 前端开发
PHP如何高效地处理JSON数据:从编码到解码
在现代Web开发中,JSON已成为数据交换的标准格式。本文探讨了PHP如何高效处理JSON数据,包括编码和解码的过程。通过简化数据结构、使用优化选项、缓存机制及合理设置解码参数等方法,可以显著提升JSON处理的性能,确保系统快速稳定运行。
|
15天前
|
监控 JavaScript 前端开发
前端的混合之路Meteor篇(六):发布订阅示例代码及如何将Meteor的响应数据映射到vue3的reactive系统
本文介绍了 Meteor 3.0 中的发布-订阅模型,详细讲解了如何在服务器端通过 `Meteor.publish` 发布数据,包括简单发布和自定义发布。客户端则通过 `Meteor.subscribe` 订阅数据,并使用 MiniMongo 实现实时数据同步。此外,还展示了如何在 Vue 3 中将 MiniMongo 的 `cursor` 转化为响应式数组,实现数据的自动更新。
|
15天前
|
JSON 分布式计算 前端开发
前端的全栈之路Meteor篇(七):轻量的NoSql分布式数据协议同步协议DDP深度剖析
本文深入探讨了DDP(Distributed Data Protocol)协议,这是一种在Meteor框架中广泛使用的发布/订阅协议,支持实时数据同步。文章详细介绍了DDP的主要特点、消息类型、协议流程及其在Meteor中的应用,包括实时数据同步、用户界面响应、分布式计算、多客户端协作和离线支持等。通过学习DDP,开发者可以构建响应迅速、适应性强的现代Web应用。
|
21天前
|
JSON JavaScript Java
在Java中处理JSON数据:Jackson与Gson库比较
本文介绍了JSON数据交换格式及其在Java中的应用,重点探讨了两个强大的JSON处理库——Jackson和Gson。文章详细讲解了Jackson库的核心功能,包括数据绑定、流式API和树模型,并通过示例演示了如何使用Jackson进行JSON解析和生成。最后,作者分享了一些实用的代码片段和使用技巧,帮助读者更好地理解和应用这些工具。
在Java中处理JSON数据:Jackson与Gson库比较
|
15天前
|
NoSQL 前端开发 MongoDB
前端的全栈之路Meteor篇(三):运行在浏览器端的NoSQL数据库副本-MiniMongo介绍及其前后端数据实时同步示例
MiniMongo 是 Meteor 框架中的客户端数据库组件,模拟了 MongoDB 的核心功能,允许前端开发者使用类似 MongoDB 的 API 进行数据操作。通过 Meteor 的数据同步机制,MiniMongo 与服务器端的 MongoDB 实现实时数据同步,确保数据一致性,支持发布/订阅模型和响应式数据源,适用于实时聊天、项目管理和协作工具等应用场景。
|
22天前
|
存储 前端开发 API
前端开发中,Web Storage的存储数据的方法localstorage和sessionStorage的使用及区别
前端开发中,Web Storage的存储数据的方法localstorage和sessionStorage的使用及区别
74 0
|
23天前
|
JSON API 数据格式
商品详情数据JSON格式示例参考(api接口)
JSON数据格式的商品详情数据通常包含商品的多个层级信息,以下是一个综合多个来源信息的JSON数据格式的商品详情数据示例参考:
|
24天前
|
存储 JSON 前端开发
JSON与现代Web开发:数据交互的最佳选择
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也便于机器解析和生成。它以文本格式存储数据,常用于Web应用中的数据传输,尤其是在客户端和服务器之间。
33 0