【gRPC报错】 Assignment not allowed to message, map, or repeated field “rect“ in protocol message object

本文介绍了一种常见的gRPC消息传递错误:尝试给消息、映射或重复字段赋值,并提供了解决方案。通过直接设置字段属性而非创建单独的对象再赋值,可以避免此类错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 Assignment not allowed to message, map, or repeated field \"rect\" in protocol message object

报错原因
grpc中的字段rect 不允许被赋值
rect是DnBoundingRect 的对象

        result_pro = digitalNumber_pb2.DnResponse()
        for bbox_dict in bbox_list:
            bbox = digitalNumber_pb2.DnBoundingRect()
            bbox.x = bbox_dict['rect'][0]
            bbox.y = bbox_dict['rect'][1]
            bbox.w = bbox_dict['rect'][2]
            bbox.h = bbox_dict['rect'][3]
            result_dict = digitalNumber_pb2.DnResult()
            result_dict.classid = bbox_dict['classid']
            result_dict.score = bbox_dict['score']
            result_dict.rect = bbox
            result_pro.results.append(result_dict)

解决

        result_pro = digitalNumber_pb2.DnResponse()
        for bbox_dict in bbox_list:
            result_dict = digitalNumber_pb2.DnResult()
            result_dict.classid = bbox_dict['classid']
            result_dict.score = bbox_dict['score']
            result_dict.rect.x = bbox_dict['rect'][0]
            result_dict.rect.y = bbox_dict['rect'][1]
            result_dict.rect.w = bbox_dict['rect'][2]
            result_dict.rect.h = bbox_dict['rect'][3]
            result_pro.results.append(result_dict)

在Nginx代理gRPC时出现"not an SSL/TLS record"错误,通常是由于Nginx配置不正确导致的。gRPC默认使用HTTP/2协议,而HTTP/2协议要求使用TLS加密。因此,Nginx需要正确配置TLS证书和私钥。 以下是解决该问题的步骤: 1. **配置TLS证书和私钥**:确保你的Nginx配置文件中有正确的TLS证书和私钥配置。 ```nginx server { listen 443 ssl http2; server_name your_domain.com; ssl_certificate /path/to/your_certificate.crt; ssl_certificate_key /path/to/your_private.key; location /your_grpc_service/ { grpc_pass grpcs://your_grpc_server:50051; } } ``` 2. **启用HTTP/2协议**:在`listen`指令中添加`http2`参数,以确保Nginx使用HTTP/2协议。 ```nginx listen 443 ssl http2; ``` 3. **配置gRPC反向代理**:使用`grpc_pass`指令来代理gRPC请求。注意,如果你的gRPC服务使用的是HTTP/2 over TLS(grpcs),则需要使用`grpcs`协议。 ```nginx grpc_pass grpcs://your_grpc_server:50051; ``` 4. **验证Nginx配置**:在重新加载Nginx配置之前,使用以下命令验证配置是否正确: ```sh nginx -t ``` 5. **重新加载Nginx**:如果配置验证通过,重新加载Nginx以应用更改: ```sh nginx -s reload ``` 如果你的gRPC服务不使用TLS,而是使用纯文本的HTTP/2协议,则需要调整Nginx配置如下: ```nginx server { listen 443 ssl http2; server_name your_domain.com; ssl_certificate /path/to/your_certificate.crt; ssl_certificate_key /path/to/your_private.key; location /your_grpc_service/ { grpc_pass grpc://your_grpc_server:50051; } } ``` 在这种情况下,`grpc_pass`指令使用`grpc`协议而不是`grpcs`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值