'$id' property usage in JSON Schema

2019-06-20 04:18发布

问题:

I'm using JSON Schema for validating data.

I think that I may have a mistake on my schema by using the reserved keywords $id. The intention of this field was to designate what the REMOTE ID of the property on another platform was. So it was the "origin ID".

Can you please advise what $id is and if I have made a critical mistake and this value needs changing. Because in the documentation I have found this definition:

If present, the value for this keyword MUST be a string, and MUST represent a valid URI-reference [RFC3986]. This value SHOULD be normalized, and SHOULD NOT be an empty fragment <#> or an empty string <>.

回答1:

$id is a reserved keyword.

It serves for:

  • Declaring an identifier for the schema or subschema
  • Declaring a base URL against which $ref URLs are resolved

You can identify a schema, or a part of your schema (a subschema) by using $id, and then you can reuse it somewhere else by using the $ref keyword. The most simple way of seeing this, is that the $ref would be replaced by the schema with the corresponding id.

  • https://tools.ietf.org/html/draft-wright-json-schema-01#section-9.2


回答2:

Since $id changes the base URI of your schema, any $ref values in that same schema or any of its subschemas will be resolved differently.

For instance, if your base URI was "https://example.com/thing" and you had this schema

{
    "allOf": [
        {"$ref": "foo"},
        {
            "$id": "stuff/and/nonsense",
            "allOf": {"$ref": "bar"}
        }
    ]
}

then the "$ref" to "foo" resolves to "https://example.com/foo". But the "$ref" to "bar" resolves to "https://example.com/stuff/and/bar"

So whatever you put in "$id" for another purpose, it is likely to cause problems, particularly with "$ref" resolution.