- A+
- 实现定义的服务
9.在“解决方案资源管理器”中,使用鼠标左键选中“Services”文件夹,然后在菜单栏上,依次选择“添加-->新建项”。
10.在“添加新项”对话框中,选择“ASP.NET Core-->代码”节点,然后选择“类”项。
11.在“名称”文本框中,输入 UserService.cs,然后选择“添加”按钮。如下图。
12.在文本编辑器打开的UserService.cs
类文件,编写如下代码:
using Demo.GrpcService.Protos; using Grpc.Core; namespace Demo.GrpcService.Services { public class UserInfoService : UserInfo.UserInfoBase { private readonly ILogger<GreeterService> _logger; public UserInfoService(ILogger<GreeterService> logger) { _logger = logger; } /// <summary> /// 实现了userinfo.proto协议文件中定义的GetUserInfo方法 /// </summary> /// <param name="request"></param> /// <param name="context"></param> /// <returns></returns> public override Task<UserInfoResult> GetUserInfo(UserInfoRequest request, ServerCallContext context) { //return base.GetUserInfo(request, context); //返回了user.proto协议文件中GetUserInfo方法定义的响应对象:UserInfoResult return Task.FromResult(new UserInfoResult { UserName = request.UserName, Password = request.Password, Name = $"姓名:张三", Tel="18800022269", Sex=1, IsLogin=false, Age = 10, City = "成都" }); } /// <summary> /// 实现了userinfo.proto协议文件中定义的Login方法 /// </summary> /// <param name="request"></param> /// <param name="context"></param> /// <returns></returns> public override Task<UserInfoResult> Login(UserInfoRequest request, ServerCallContext context) { //return base.Login(request, context); if (request.UserName=="Admin" && request.Password=="111111") { //返回了user.proto协议文件定义的响应对象:UserInfoResult return Task.FromResult(new UserInfoResult { UserName = request.UserName, Name = $"姓名:张三", Tel = "18800022269", Sex = 1, IsLogin = true, Age = 10, City = "成都" }); } return Task.FromResult(new UserInfoResult { IsLogin = false }); } /// <summary> /// 实现了userinfo.proto协议文件中定义的Save方法 /// </summary> /// <param name="request"></param> /// <param name="context"></param> /// <returns></returns> public override Task<UserInfoResult> Save(UserInfoModifyRequest request, ServerCallContext context) { //return base.Save(request,context); //返回了user.proto协议文件定义的响应对象:UserInfoResult return Task.FromResult(new UserInfoResult { UserName = request.UserName, Name = request.Name, Password = request.Password, Sex =(int)request.Sex, Age =(int)request.Age, City=request.City, Tel=request.Tel, }); } } }
继承的UserInfo.UserInfoBase
是UserInfo.proto协议文件生成的类文件中的。
- 注册
UserInfoService
服务
13.在Visual Studio 2022中进行重新生成,编译成功之后。我们需要将新建的UserInfoService服务在启动文件中进行注册。 在“解决方案资源管理器”中,找到Program.cs文件,使用鼠标双击打开Program.cs
文件,在文本编辑器中,添加一行代码。将业务服务进行注册。如下面代码中斜体的一行代码,
using Demo.GrpcService.Services; var builder = WebApplication.CreateBuilder(args); // Additional configuration is required to successfully run gRPC on macOS. // For instructions on how to configure Kestrel and gRPC clients on macOS, visit https://go.microsoft.com/fwlink/?linkid=2099682 // Add services to the container. builder.Services.AddGrpc(); var app = builder.Build(); // Configure the HTTP request pipeline. app.MapGrpcService<GreeterService>(); app.MapGrpcService<UserInfoService>(); app.MapGet("/", () => "Communication with gRPC endpoints must be made through a gRPC client. To learn how to create a client, visit: https://go.microsoft.com/fwlink/?linkid=2086909"); app.Run();
启动服务
到此,gRPC服务端就新建配置完成了,此时我们就可以启动该项目让其运行起来。
13.在Visual Studio 2022的菜单栏上,依次选择“调试”、“开始执行(不调试)”以运行服务。 Visual Studio 会弹出一个“信任Asp.Net Core SSL证书”的提示信息。如下图。
14.此处建议是点击“是”。然后会打开一个控制台窗口,并显示该服务的监听端口。如下图。
15.在上图中我们发现有2个地址http://localhost:5209
和https://localhost:7149
,如图中的两处框。这2个地址是我们在创建项目的时候,Visual Studio 2022在launchSettings.json配置文件中自动给我们配置的。gRPC客户端会使用到这2个地址,目的是给客户端请求请求地址,服务端将监听这两个端口。