Android怎么使用GRPC进行通信


这篇文章主要介绍“Android怎么使用GRPC进行通信”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android怎么使用GRPC进行通信”文章能帮助大家解决问题。Android作为一个开发平台,本身是使用java进行封装的,因此java可以调用的库,在Android中同样可以进行调用,这样就使得Android设备具有丰富的功能,可以进行各种类型的开发。工欲善其事,必先利其器。首先我们先来进行开发环境的搭建。这里先要强调一下,Android开发中使用的项目管理工具Gradle对于版本的要求非常严格,如果不使用正确的版本号,可能导致程序报错,因此这一点需要特别注意。我们在创建完一个项目后,需要修改一些文件的信息,具体需要修改的文件信息如下对于上面的修改我们一个一个来看。这个文件里面指定了gradle去哪个仓库中去找插件和第三方依赖库,我以及项目引入的模块信息。我找到的一个可行的配置信息如下pluginManagement {
repositories {
gradlePluginPortal()
google()
mavenCentral()
}
}
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
google()
mavenCentral()
maven { url ‘https://jitpack.io’ }
maven { url ‘https://repo.eclipse.org/content/repositories/paho-releases/’}
}
}
rootProject.name = “gprc_learn”
include ‘:app’项目目录下的build.gradle文件主要指定了项目中需要引入的插件,当然在这个文件中主要是下载插件,我们需要到具体的模块的build.gralde中去引入插件。在这个项目中,主要指定gradle插件和protobuf插件,我找到的一个可行配置如下// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
maven{ url ‘https://maven.aliyun.com/repository/jcenter’}
maven { url ‘https://maven.aliyun.com/repository/google’ }
maven { url ‘https://maven.aliyun.com/repository/gradle-plugin’ }
maven { url ‘https://maven.aliyun.com/repository/public’ }
google()
mavenCentral()
}
dependencies {
classpath “com.android.tools.build:gradle:7.2.0”
classpath “com.google.protobuf:protobuf-gradle-plugin:0.8.17”
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}这一步需要和你引入的gradle插件相关联,插件的版本和你引入的gradle版本必须要匹配才行,我引入的插件版本是7.2.0,引入的gralde版本是7.4。修改gradle版本一共有两种方式,第一种就是在projectstructure中进行修改。第二种方法就是直接在配置文件中进行修改你需要哪个版本的gradle就直接在配置文件中指定对应版本的压缩包。这两种修改方式都是等效的。模块的build.gradle中引入了插件,同时对插件做了一些配置,最最重要的就是引入第三方库。我的配置信息如下plugins {
id ‘com.android.application’
id ‘com.google.protobuf’
}
android {
namespace ‘com.example.grpc_learn’
compileSdk 32
defaultConfig {
applicationId “com.example.grpc_learn”
minSdk 29
targetSdk 32
versionCode 1
versionName “1.0”
testInstrumentationRunner “androidx.test.runner.AndroidJUnitRunner”
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile(‘proguard-android-optimize.txt’), ‘proguard-rules.pro’
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
configurations.all {
resolutionStrategy.force ‘com.google.code.findbugs:jsr305:3.0.1’
exclude group: ‘com.google.guava’, module: ‘listenablefuture’
}
sourceSets {
main {
proto {
srcDir ‘src/main/proto’
}
}
}
packagingOptions {
pickFirst ‘META-INF/INDEX.LIST’
pickFirst ‘META-INF/LICENSE’
pickFirst ‘META-INF/io.netty.versions.properties’
}
}
protobuf {
protoc {
artifact = ‘com.google.protobuf:protoc:3.17.2’
}
plugins {
grpc {
artifact = ‘io.grpc:protoc-gen-grpc-java:1.39.0’ // CURRENT_GRPC_VERSION
}
}
generateProtoTasks {
all().each { task ->
task.builtins {
java { option ‘lite’ }
}
task.plugins {
grpc {
option ‘lite’ }
}
}
}
}
dependencies {
implementation ‘androidx.appcompat:appcompat:1.4.1’
implementation ‘com.google.android.material:material:1.5.0’
implementation ‘androidx.constraintlayout:constraintlayout:2.1.3’
testImplementation ‘junit:junit:4.13.2’
androidTestImplementation ‘androidx.test.ext:junit:1.1.3’
androidTestImplementation ‘androidx.test.espresso:espresso-core:3.4.0’
implementation ‘io.grpc:grpc-netty:1.39.0’
implementation ‘io.grpc:grpc-okhttp:1.39.0’ // CURRENT_GRPC_VERSION
implementation ‘io.grpc:grpc-protobuf-lite:1.39.0’ // CURRENT_GRPC_VERSION
implementation ‘io.grpc:grpc-stub:1.39.0’ // CURRENT_GRPC_VERSION
implementation ‘org.apache.tomcat:annotations-api:6.0.53’
}模块编译的时候会根据这个文件指定的信息进行操作。这里最好根据你自己的配置文件,然后对比看看和上述文件有哪些缺失的信息,一般只需要添加缺失的信息即可,如果完全照搬上面的内容可能导致项目报错,因为里面记录了你本身的项目信息,可能和我的项目信息产生冲突。我们需要创建一个和java目录同级的proto文件夹,里面存放proto文件,这样做是因为在build.gradle文件中指定了去proto文件夹中找到*.proto文件,并且编译成java代码。做完上述的几个步骤后,我们可以编写一个简单的grpc通信模型,测免费云主机域名试一下环境是否搭建成功。首先在proto文件夹下编写hello.proto文件然后编译项目,我们可以在build目录下看到对应的java文件最后,我们可以使用一段简单的grpc通信代码看看是否可以正常通信,我们直接修改MainActivity文件即可然后需要在AndroidManifest.xml文件中添加网络权限最后编译运行,如果能看到控制台中有如下信息表示环境搭建成功了,好耶ヾ(✿゚▽゚)ノ好了,到了这一步,我们可以将hello.proto和MainActivity中的代码清除啦,这只是为了测试环境是否搭建成功而编写的文件。GRPC针对不同的业务场景,一共提供了四种通信模式,分别是简单一元模式,客户端流模式,服务端流模式和双向流模式,接下来这个进行介绍。所谓简单一元模式,实际上就是客户端和服务端进行一问一答的通信。这种通信模式是最简单的,应用场景有无线设备之间和客户端之间保持连接的心跳检测,每隔一段时间就给服务端发送一个心跳检测包,服务端接收到心跳包后就知道相应客户端处于连接状态。在客户端编写如下程序服务端也需要编写对应的处理程序客户端流模式的意思就是客户端可以一次性发送多个数据片段,当然数据片段是一个类,具体的类有哪些字段都是你在最开始的proto文件中进行指定的。这种模式的应用场景就比如客户端向服务端发送一连串的数据,然后服务端最后发送一个响应数据表示接收成功。在客户端流模式中,客户端可以在onCompleted之前使用多个onNext进行数据发送。客户端代码如下服务端也需要编写相应代码服务端流模式和客户端流模式正好相反,本质都是差不多的,应用场景有客户端发送一个数据包告诉服务端,我需要某某数据,然后服务器将对应的所有信息都发送给客户端。客户端和服务端代码分别如下所示双向流模式是最后一种,也是最常用的一种,在这种模式中,客户端和服务端的通信没有什么限制,是比较理想的通信模式,应用场景也最为广泛,因为在这种模式中,你也可以只发送一个数据包。客户端和服务端的代码如下上面介绍了GRPC的四种通信模式,以及各种模式中客户端和服务端对应的编写方法。下面来介绍一下我们具体应该如何编写客户端服务端代码。我们一般会将客户端和服务端分开来编写,具体的文件如下图所示首先需要编写hello.proto文件,并且编译后生成对应的java文件,我们在proto文件中编写了两个类用来请求和相应,并且编写了四个接口方法,分别对应GRPC请求响应的四种模式客户端我们只需要编写一个文件即可在构造函数中,我们需要和服务端建立连接,所以一般需要服务端先启动。在连接建立完成后,无论调用什么方法都采用一个连接,然后分别编写GRPC对应的不同服务接口。服务端可以分成两个类来编写,其中GRPCServer主要用来启动服务端,GRPCServiceImpl则是继承了GreeterGrpc.GreeterImplBase,可以重写里面的方法,表示服务端如何处理GRPC请求。我们采用一个简单的布局,就是四个按钮,分别对应GRPC的四个接口,然后在显示客户端和服务端发送给MainActivity的信息。这里面我们在信息传递的时候采用了广播的方法,为了能够发送广播,在实例化客户端和服务端类的时候都需要传递Context作为参数,这个Context就可以发送广播了,然后在MainActivity中需要注册一个广播接收器,当接收到具体信息的时候就更新ui。最后在虚拟机上运行程序,依次点击四个按钮,如果得到了下图的结果,则表示程序跑通关于“Android怎么使用GRPC进行通信”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注百云主机行业资讯频道,小编每天都会为大家更新不同的知识点。

相关推荐: Vue3侦听器的实现原理是什么

这篇文章主要讲解了“Vue3侦听器的实现原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue3侦听器的实现原理是什么”吧!前面我们聊到计算属性,它可以自动计算并缓存响应式数据的值。而如果我们仅需要在响…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 05/16 10:35
Next 05/16 10:36

相关推荐