短視頻、直播數據實時採集接口,請查看文檔: TiToDatahtml
免責聲明:本文檔僅供學習與參考,請勿用於非法用途!不然一切後果自負。java
Protobuf是Google protocol buffer的簡稱,是一種語言中立、平臺無關、易於擴展的結構化數據序列化技術,可用於數據傳輸、存儲等領域。
與Protoful相似的序列化技術還有XML、JSON、Thrift等,但Protoful更快、更小、更簡單,且具有良好的兼容性。git
目前常常運用在 安卓直播彈幕等業務場景中github
只設置客戶端請求時附帶的headeride
類 io.grpc.stub.MetadataUtils,其中有個方法
函數
@ExperimentalApi("https://github.com/grpc/grpc-java/issues/1789") public static <T extends AbstractStub<T>> T attachHeaders( T stub, final Metadata extraHeaders) { return stub.withInterceptors(newAttachHeadersInterceptor(extraHeaders)); }
**
本身封裝後typecho
private static <T extends AbstractStub<T>> T attachHeaders(T stub, final Map<String, String> headerMap) { Metadata extraHeaders = new Metadata(); if (headerMap != null) { for (String key : headerMap.keySet()) { Metadata.Key<String> customHeadKey = Metadata.Key.of(key, Metadata.ASCII_STRING_MARSHALLER); extraHeaders.put(customHeadKey, headerMap.get(key)); } } return MetadataUtils.attachHeaders(stub, extraHeaders); }
**學習
支持設置客戶端請求的header以及獲取服務端返回結果中的headerui
class HeaderClientInterceptor implements ClientInterceptor { private static final String TAG = "HeaderClientInterceptor"; private Map<String, String> mHeaderMap; public HeaderClientInterceptor(Map<String, String> headerMap) { mHeaderMap = headerMap; } @Override public <ReqT, RespT> ClientCall<ReqT, RespT> interceptCall(MethodDescriptor<ReqT, RespT> method, CallOptions callOptions, Channel next) { return new SimpleForwardingClientCall<ReqT, RespT>(next.newCall(method, callOptions)) { @Override public void start(Listener<RespT> responseListener, Metadata headers) { /* put custom header */ if (mHeaderMap != null) { for (String key : mHeaderMap.keySet()) { Metadata.Key<String> customHeadKey = Metadata.Key.of(key, Metadata.ASCII_STRING_MARSHALLER); headers.put(customHeadKey, mHeaderMap.get(key)); } } Logger.i(TAG, "header send to server:" + headers); super.start(new SimpleForwardingClientCallListener<RespT>(responseListener) { @Override public void onHeaders(Metadata headers) { /** * if you don't need receive header from server, * you can use {@link io.grpc.stub.MetadataUtils attachHeaders} * directly to send header */ Logger.i(TAG, "header received from server:" + headers); super.onHeaders(headers); } }, headers); } }; } }
_this
Map<String, String> headerMap = new HashMap<>(); //... ClientInterceptor interceptor = new HeaderClientInterceptor(headerMap); //... ManagedChannel managedChannel = ManagedChannelBuilder.forAddress(host, port).usePlaintext(true).build(); Channel channel = ClientInterceptors.intercept(managedChannel, interceptor); // then create stub here by this channel
**
要實現添加header 那麼必須實現 ClientInterceptor
接口類中的 interceptCall
的方法
z1.c.v.p.a.d.b.f.a.a()
大機率就是混淆後的 interceptCall
z1.c.v.p.a.d.b.f.a.c()
是添加請求頭的函數