httpclient +protobuf 实现数据传输_httpclient 调用 protocol buffer协议接口

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Golang全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注go)
img

正文

  1. export PROTOBUF=/Users/jack/software/tools/protobuf
  2. export PATH= P R O T O B U F / b i n : PROTOBUF/bin: PROTOBUF/bin:PATH

1.7 验证

[html] 
view plain
copy

  1. jack-3:bin jack$ protoc --version
  2. libprotoc 2.5.0

二、代码编写

2.1 查看.proto文件,只贴出了部分文件内容

[html] 
view plain
copy

  1. package mobads.apiv5;
  2. // 本文件描述API接口版本:5.0.0
  3. // 版本号信息
  4. message Version {
  5. optional uint32 major = 1[default = 0]; // 必填!
  6. optional uint32 minor = 2[default = 0]; // 选填!
  7. optional uint32 micro = 3[default = 0]; // 选填!
  8. };

2.2 下载 protobuf-java-2.5.0.jar

[html] 
view plain
copy

  1. http://download.csdn.net/download/zinc2008/8128155

2.3 生成.java文件

[html] 
view plain
copy

  1. protoc --java_out=./ baidu_mobads_api_5.0.proto

同样只贴出部分java源文件 ( 注意java文件不要修改哦)

[html] 
view plain
copy

  1. // Generated by the protocol buffer compiler.  DO NOT EDIT!
  2. // source: baidu_mobads_api_5.0.proto
  3. package mobads.apiv5;
  4. public final class BaiduMobadsApi50 {
  5. private BaiduMobadsApi50() {}
  6. }

2.4 代码编写,只贴出关键部分

[html] 
view plain
copy

  1. MobadsRequest adrequest = MobadsRequest.newBuilder().setRequestId(requestId).setAdslot(adslot).build();
  2. byte[] content = adrequest.toByteArray();
  3. HttpClient client = new HttpClient();
  4. PostMethod postMethod = new PostMethod(URL);
  5. postMethod.addRequestHeader(“Content-Type”, “application/octet-stream;charset=utf-8”);
  6. postMethod.setRequestEntity(new ByteArrayRequestEntity(content ));
  7. client.executeMethod(postMethod);

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

注意content-type 设置为
application/octet-stream。

到此,就完成了通过httpclient的post请求传输protobuf二进制流。
使用protobuf,所有的参数和返回都是对象的形式,这点还是用着比较爽的。

String byte 切换方法

服务端返回字符串

方式一:

[java] 
view plain
copy

  1. Arrays.toString(personInfo.toByteArray())

方式二:

[java] 
view plain
copy

  1. toByteString().toStringUtf8()

客户端解析字符串

方式一:

[java] 
view plain
copy

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  1. private static byte[] fromString(String string) {
  2. String[] strings = string.replace(“[”, “”).replace(“]”, “”).split(", ");
  3. byte[] result = new byte[strings.length];
  4. for (int i = 0; i < result.length; i++) {
  5. result[i] = Byte.parseByte(strings[i]);
  6. }
  7. return result;
  8. }
  9. XXX.parseFrom(fromString(byteString))

方式二:

[java] 
view plain
copy

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  1. XXX.parseFrom(ByteString.copyFromUtf8(utf8ByteString))

protobuf已经出来好多年了,原谅我最近才了解到google这个高性能的用于传输的格式。

从各方面来看,它无论从序列化的性能还是从序列化的压缩比都是优于当前各种传输格式的。如json、xml、hessian,java原生的Serializable。具体对比结果参见:http://agapple.iteye.com/blog/859052

网上也看了些资料,并有所了解,看了下,这玩意儿性能上来说真的没什么可说,但初始化和使用的时候感觉不是特别方便。而且网上的例子多数都是序列化过程,没有很多关于演示网络传输的demo,于是自己简单写了一个,将完整的例子摆在这里。

先定义一个Person.proto

Java代码  
收藏代码

  1. option java_package = “com.example.protobuf”;
  2. option java_outer_classname = “PersonProbuf”;
  3. message Person {
  4. required string name = 1;
  5. required int32 id = 2;
  6. optional string email = 3;
  7. repeated PhoneNumber phone = 4;
  8. enum PhoneType {
  9. MOBILE = 0;
  10. HOME = 1;
  11. WORK = 2;
  12. }
  13. message PhoneNumber {
  14. required string number = 1;
  15. optional PhoneType type = 2 [default = HOME];
  16. }
  17. }

使用protoc生成对应的PersonProtobuf类

Java代码  
收藏代码

  1. protoc.exe Person.proto --java_out=.

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
oc生成对应的PersonProtobuf类

Java代码  
[外链图片转存中…(img-gT5wK4cC-1713318975272)]

  1. protoc.exe Person.proto --java_out=.

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
[外链图片转存中…(img-vfbM0k5g-1713318975273)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 24
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值