gRPC java 客户端,服务器端通讯使用json格式

使用 protobuf 作为通讯内容序列化的简单例子请看:http://www.cnblogs.com/ghj1976/p/5458176.html

本文是使用 json 做为内容序列化的简单例子。

新建例子项目,从 proto 文件产生 通讯包的方式跟之前的完全一样。

本文的源码在:

https://github.com/grpc/grpc-java/tree/master/examples/src/main/java/io/grpc/examples/helloworld 这里的

HelloJsonServer.java 和  HelloJsonClient.java 这两个文件中。

 

这个文件跟 protobuf 处理的文件不同的地方如下:

定义一个JSON解析的Stub

整个类的定义文件如下:

package com.ghj1976;

import io.grpc.examples.helloworld.GreeterGrpc;
import io.grpc.examples.helloworld.HelloReply;
import io.grpc.examples.helloworld.HelloRequest;
import io.grpc.stub.AbstractStub;
import static io.grpc.stub.ClientCalls.blockingUnaryCall;
import io.grpc.CallOptions;
import io.grpc.Channel;
import io.grpc.MethodDescriptor;
import io.grpc.protobuf.ProtoUtils;

/**
* Created by ghj1976 on 16/5/4.
*/
public  class HelloWorldJSONStub extends AbstractStub<HelloWorldJSONStub>
        implements io.grpc.examples.helloworld.GreeterGrpc.GreeterBlockingClient {

    static final MethodDescriptor<HelloRequest, HelloReply> METHOD_SAY_HELLO =
            MethodDescriptor.create(
                    GreeterGrpc.METHOD_SAY_HELLO.getType(),
                    GreeterGrpc.METHOD_SAY_HELLO.getFullMethodName(),
                    ProtoUtils.jsonMarshaller(HelloRequest.getDefaultInstance()),
                    ProtoUtils.jsonMarshaller(HelloReply.getDefaultInstance()));

    protected HelloWorldJSONStub(Channel channel) {
        super(channel);
    }

    protected HelloWorldJSONStub(Channel channel, CallOptions callOptions) {
        super(channel, callOptions);
    }

    @Override
    protected HelloWorldJSONStub build(Channel channel, CallOptions callOptions) {
        return new HelloWorldJSONStub(channel, callOptions);
    }

    @Override
    public HelloReply sayHello(HelloRequest request) {
        return blockingUnaryCall(
                getChannel(), METHOD_SAY_HELLO, getCallOptions(), request);
    }
}
具体的解析用的 ProtoUtils.jsonMarshaller() 这个函数。

 

服务器端的修改

服务器端代码封装个函数, bindService, 用于服务器的数据解析分层。

private ServerServiceDefinition bindService(final GreeterGrpc.Greeter serviceImpl){
    return io.grpc.ServerServiceDefinition.builder(GreeterGrpc.SERVICE_NAME)
            .addMethod(
                    com.ghj1976.HelloWorldJSONStub.METHOD_SAY_HELLO,
                    asyncUnaryCall(
                        new ServerCalls.UnaryMethod<HelloRequest,HelloReply>(){
                            @Override
                            public void invoke(HelloRequest request,StreamObserver<HelloReply> responseObserver){
                                serviceImpl.sayHello(request,responseObserver);
                            }
                        }
                    ))
            .build();
}
这里用到了我们前面定义的方法

com.ghj1976.HelloWorldJSONStub.METHOD_SAY_HELLO,

增加服务时用这个 bindService 做封装。

 

服务端的代码改造就这些。

 

 

客户端的代码改造

只需要修改 Stub 为我们刚刚建立的 HelloWorldJSONStub  接口。

 

执行方法跟之前完全一样, 启动 main 方法即可。

 

使用 Wireshark 监听网络请求,可以看到这时候发送的数据包:

客户端请求的数据包:

服务器端返回的包:

使用 protobuf 时,则会是如下的截图:

时间: 2024-10-05 22:02:05

gRPC java 客户端,服务器端通讯使用json格式的相关文章

Java入门系列:处理Json格式数据

本节主要讲解: 1)json格式数据处理方法 2)第三方工具包的使用方法 3)java集合数据类型 [项目任务] 编写一个程序,显示未来的天气信息. [知识点解析] 为了方便后面代码的分析,先需要掌握几个相关的知识. 1.什么是json格式数据 从结构上看,我们所见到的所有的数据(data)最终都可以分解成三种类型: 第一种类型是标量(scalar),也就是一个单独的字符串(string)或数字(numbers),比如"北京"这个单独的词. 第二种类型是序列(sequence),也就是

通过java代码来完成对于json格式的转换

/** * */ package net.nyist.jsondemo.servlet; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import org.json.JSONObject; /** * @author yuchao * * @school 南阳理工软件学院移动设备应用与开发11软工移动四班 * * @time 2014-9-17

【Java】+map对象转换为json格式对象

包:com.alibaba.fastjson.JSONObject;需求:在调用post请求的接口时,入参参数是json格式. 解决: 1.用map对象分别将入参的格式键值对写好 2.将map对象转换为json对象 3.直接用此json对象作为post接口的入参即可 原文地址:https://www.cnblogs.com/danhuai/p/11207326.html

基于JDK6的JAX-WX为客户端提供XML与JSON格式数据服务,以及客户端采用AXIS调用案例

1:WebService服务端工程目录如下: 需要第三方jar包:gson-2.2.4.jar\javax.xml.bind.jar\commons-lang-2.5.jar 源码如下: package com.mw.dao; import com.mw.vo.Nsr; import java.util.List; /** * @author y * @date 2015-4-4 9:23:53 * @version 1.0 * @desc */ public interface NsrDao

最好用的 Kafka Json Logger Java客户端,赶紧尝试一下

最好用的 Kafka Json Logger Java客户端. slf4j4json 最好用的 Kafka Json Logger 库:不尝试一下可惜了! Description 一款为 Kafka 提供的 json logger 客户端,支持将 json 格式的 log 输出到 kafka.文件.控制台. 支持 slf4j 的全部功能. 比 KafkaLog4jAppender 更好用,可配置性更好. 支持 close logger, 在程序关闭之前 flush log to kafka. 支

java后台对json格式数据的解析

Json 和 Jsonlib 的使用 什么是 Json JSON(JvaScript Object Notation)(官网网站:http://www.json.org/)是 一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成.它基于 JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999 的一个子集. JSON 采用完全独立于语言的文本格式,但是也使用了类似于 C 语言家族

JAVA学习日志——Ajax和Json

# JAVA学习日志--Ajax和Json # Ajax和Json在一个web项目中可以说是经常用到了,Ajax是一种用于创建快速动态网页的技术,而Json则是一种与语言无关的数据交换的格式.以下是个人在学习过程中的总结. 一.Ajax 1.同步与异步 在学习Ajax之前我们要先知道什么是同步,什么是异步. 同步现象:客户端发送请求到服务器端,当服务器返回响应之前,客户端都处于等待卡死状态. 异步现象:客户端发送请求到服务器端,无论服务器是否返回响应,客户端都可以随    意做其他事情,不会被卡

java web 服务器端处理json格式参数

前面我们说了传递参数的两种访书,第一是key-value形式,第二是json格式,对于第一种我们在服务器端直接使用 request.getParameter("key");就能获取key对应的value.但是对于传递的json就不能使用这样的代码了,利用json传递的参数存在request的body里,我们需要从里面输入流里面读取,下面是代码: 1 /** 2 * 获取请求的 body 3 * @param req 4 * @return 5 * @throws IOException

服务器采用JSON格式返回数据给安卓客户端

最近打算做一个酒店无线点餐的APP,需要将图片放在服务器端的文件夹下,客户端通过更新菜单按钮可以获得最新的菜品信息.要获取图片的信息首先需要得到图片的名称.对应的菜品价格以及图片所在的路径,因此需要在服务器端搜索文件夹下的所有图片并将数据打包成JSON格式转发给客户端,具体格式为[{name="菜名",price=价格,path="文件路径",category="菜品分类:如川菜.湘菜等"}].服务器端采用servlet+jsp部署在Tomcat