如何在gRPC协议中接受和验证此地图?

问题描述

我正在将以下POST请求发送到我的gRPC应用程序:

curl \
--request POST \
--header 'Content-Type: application/json' \
--data-raw '{
 "mandatory-key1": "value1","mandatory-key2": {
    "arbitrary-optional-key1": [
        "b","c"
    ],"arbitrary-optional-key2": [
        "e"
    ]
  }
}' \
'http://localhost:11000/MyEndpoint'

mandatory-key-1关联的值必须是非空字符串。 与mandatory-key-2关联的值必须是一个映射,其中所有键都是字符串,所有值都是字符串列表。

现在,我必须在gRPC原型文件中对该请求的数据结构进行建模。

我正在考虑做这样的事情:

message MyRequestData {
  // pairs represents that map that the user will send in to the MyEndpoint.
  map<string,string> pairs = 1;
}

但是此规范不够通用。我需要知道如何正确编写此规范。

问题1:我如何编写此规范,以便它接受值中的字符串以及字符串列表?

问题2:如何进行验证,以确保pairs拥有密钥mandatory-key1mandatory-key2而没有其他东西?

问题3:如何进行验证以确保:

  1. pairs有键mandatory-key1mandatory-key2,还有其他键吗?
  2. pairs[mandatory-key1"]的值是非空字符串吗?
  3. pairs["mandatory-key2"]的值是的映射?

解决方法

Protobufs不提供(所需的)验证。

使用协议生成的源时,您需要对验证进行编码。

Protobuf不直接支持重复的地图值,但是您可以:

expect(anObject).yesOrNo(expectFoo).toContainEqual(
  expect.objectContaining({
    name: "foo"
  })
);

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...