Share via


Data - Update Preview

Met de aanvraag Bijwerken kan de aanroeper gegevensinhoud bijwerken die eerder is geüpload met behulp van Gegevens uploaden.
Van toepassing op: Prijscategorie S1.

Met de Api voor gegevensupdates kan de aanroeper een eerder geüploade gegevensinhoud bijwerken.

U kunt deze API gebruiken in een scenario zoals het toevoegen of verwijderen van geofences aan of uit een bestaande verzameling geofences. Geofences worden geüpload met behulp van de Api voor het uploaden van gegevens, voor gebruik in de Azure Maps Geofencing Service.

Houd er rekening mee dat de Update-API de bestaande gegevensinhoud vervangt en overschrijft .

Notitie

buitengebruikstelling van gegevensservice Azure Maps

De Azure Maps Data-service (zowel v1 als v2) is nu afgeschaft en wordt buiten gebruik gesteld op 16-9-24. Om onderbrekingen van de service te voorkomen, moeten alle aanroepen naar de gegevensservice uiterlijk op 16-9-9-24 worden bijgewerkt om de Azure Maps Data Registry-service te kunnen gebruiken. Zie Gegevensregister maken voor meer informatie.

Updateaanvraag indienen

Als u uw inhoud wilt bijwerken, gebruikt u een PUT aanvraag. De aanvraagbody bevat de nieuwe gegevens die de bestaande gegevens vervangen. De Content-Type header wordt ingesteld op het inhoudstype van de gegevens en het pad bevat de udid van de gegevens die moeten worden bijgewerkt.

Als u bijvoorbeeld een verzameling geofences wilt bijwerken die eerder zijn geüpload met behulp van de Upload-API, plaatst u de nieuwe geofence-inhoud in de aanvraagbody. Stel de udid parameter in het pad in op de udid van de gegevens die u eerder hebt ontvangen in het antwoord van de upload-API. Stel de Content-Type header in op een van de volgende mediatypen:

  • application/json
  • application/vnd.geo+json
  • application/octet-stream

Hier volgt een voorbeeld van de aanvraagtekst voor het bijwerken van een eenvoudige Geofence. Het wordt weergegeven als een cirkelgeometrie met behulp van een middelpunt en een radius. Het onderstaande voorbeeld is in GeoJSON:

{
    "type": "FeatureCollection",
    "features": [{
        "type": "Feature",
        "geometry": {
            "type": "Point",
            "coordinates": [-122.126986, 47.639754]
        },
        "properties": {
            "geometryId": "001",
            "radius": 500
        }
    }]
}

De eerder geüploade geofence had een straal van 100 meter. De bovenstaande aanvraag wordt bijgewerkt naar 500m.

De Api voor gegevensupdates voert een langdurige bewerking uit.

Limieten voor gegevensupdates

Houd er rekening mee dat momenteel elke Azure Maps account een limiet voor gegevensopslag heeft. Zodra de opslaglimiet is bereikt, retourneren alle nieuwe upload-API-aanroepen een 409 Conflict HTTP-foutreactie. U kunt altijd de Gegevens verwijderen-API gebruiken om oude/ongebruikte inhoud te verwijderen en ruimte te maken voor nieuwe uploads.

PUT https://{geography}.atlas.microsoft.com/mapData/{udid}?api-version=1.0
PUT https://{geography}.atlas.microsoft.com/mapData/{udid}?subscription-key={subscription-key}&api-version=1.0

URI-parameters

Name In Vereist Type Description
geography
path True

string

Deze parameter geeft aan waar de resource Azure Maps Creator zich bevindt. Geldige waarden zijn wij en eu.

udid
path True

string

De unieke gegevens-id voor de inhoud. De udid moet zijn verkregen na een geslaagde API-aanroep voor het uploaden van gegevens .

api-version
query True

string

Versienummer van Azure Maps API. Huidige versie is 1.0

subscription-key
query

string

Een van de Azure Maps sleutels die zijn opgegeven vanuit een Azure Map-account. Raadpleeg dit artikel voor meer informatie over het beheren van verificatie.

Aanvraagkoptekst

Name Vereist Type Description
x-ms-client-id

string

Hiermee geeft u op welk account is bedoeld voor gebruik in combinatie met het Microsoft Entra ID-beveiligingsmodel. Het vertegenwoordigt een unieke id voor het Azure Maps-account en kan worden opgehaald uit de Azure Maps beheervlak Account-API. Als u Microsoft Entra ID-beveiliging in Azure Maps raadpleegt u de volgende artikelen voor hulp.

Aanvraagbody

Name Type Description
UpdateContent

object

De nieuwe inhoud die de eerder geüploade inhoud bijwerkt/vervangt.

Antwoorden

Name Type Description
200 OK

ODataErrorResponse

Het bijwerken van gegevens is mislukt. De geüploade inhoud voldoet niet aan alle validatiecontroles. De antwoordtekst bevat alle fouten die zijn opgetreden.

201 Created

LongRunningOperationResult

De resource is gemaakt.

Headers

Location: string

202 Accepted

Alleen ondersteund voor asynchrone aanvragen. Aanvraag geaccepteerd: de aanvraag is geaccepteerd voor verwerking. Gebruik de URL in de locatieheader om het opnieuw te proberen of de resultaten te openen.

Headers

Location: string

400 Bad Request

ODataErrorResponse

Ongeldige aanvraag: een of meer parameters zijn onjuist opgegeven of sluiten elkaar uit.

401 Unauthorized

ODataErrorResponse

Toegang geweigerd vanwege een ongeldige abonnementssleutel of ongeldig Microsoft Entra ID bearer-token. Zorg ervoor dat u een geldige sleutel opgeeft voor een actief Azure-abonnement en een Maps-resource. Controleer anders de WWW-Authenticate-header op foutcode en beschrijving van het opgegeven Microsoft Entra ID bearer-token.

Headers

WWW-Authenticate: string

403 Forbidden

ODataErrorResponse

Machtigings-, capaciteits- of verificatieproblemen.

404 Not Found

ODataErrorResponse

Niet gevonden: de aangevraagde resource kan niet worden gevonden, maar deze is in de toekomst mogelijk weer beschikbaar.

500 Internal Server Error

ODataErrorResponse

Er is een fout opgetreden tijdens het verwerken van de aanvraag. Probeert u het later nog eens.

Beveiliging

AADToken

Dit zijn de Microsoft Entra OAuth 2.0-stromen. In combinatie met op rollen gebaseerd toegangsbeheer van Azure kan het worden gebruikt om de toegang tot Azure Maps REST API's te beheren. Op rollen gebaseerd toegangsbeheer van Azure wordt gebruikt om toegang tot een of meer Azure Maps resourceaccount of subresources aan te wijzen. Elke gebruiker, groep of service-principal kan toegang krijgen via een ingebouwde rol of een aangepaste rol die bestaat uit een of meer machtigingen voor Azure Maps REST API's.

Als u scenario's wilt implementeren, raden we u aan om verificatieconcepten te bekijken. Samengevat biedt deze beveiligingsdefinitie een oplossing voor het modelleren van toepassingen via objecten die toegangsbeheer kunnen hebben voor specifieke API's en bereiken.

Notities

  • Deze beveiligingsdefinitie vereist het gebruik van de x-ms-client-id header om aan te geven tot welke Azure Maps resource de toepassing toegang aanvraagt. Dit kan worden verkregen via de Beheer-API van Maps.

De Authorization URL is specifiek voor het azure-exemplaar van de openbare cloud. Onafhankelijke clouds hebben unieke autorisatie-URL's en Microsoft Entra ID configuraties. * Op rollen gebaseerd toegangsbeheer van Azure wordt geconfigureerd vanuit het Azure-beheervlak via Azure Portal, PowerShell, CLI, Azure SDK's of REST API's. * Gebruik van de Azure Maps Web SDK maakt configuratie van een toepassing mogelijk voor meerdere gebruiksscenario's.

Type: oauth2
Flow: implicit
Authorization URL: https://login.microsoftonline.com/common/oauth2/authorize

Scopes

Name Description
https://atlas.microsoft.com/.default https://atlas.microsoft.com/.default

subscription-key

Dit is een gedeelde sleutel die wordt ingericht wanneer u een Azure Maps-account maakt in de Azure Portal of met behulp van PowerShell, CLI, Azure SDK's of REST API.

Met deze sleutel heeft elke toepassing toegang tot alle REST API's. Met andere woorden, deze sleutel kan worden gebruikt als een hoofdsleutel in het account waarin ze zijn uitgegeven.

Voor openbaar beschikbare toepassingen wordt aanbevolen om de vertrouwelijke clienttoepassingen te gebruiken voor toegang tot Azure Maps REST API's, zodat uw sleutel veilig kan worden opgeslagen.

Type: apiKey
In: query

SAS Token

Dit is een shared access signature-token dat wordt gemaakt op basis van de SAS-bewerking List op de Azure Maps resource via het Azure-beheervlak via Azure Portal, PowerShell, CLI, Azure SDK's of REST API's.

Met dit token is elke toepassing gemachtigd om toegang te krijgen met op rollen gebaseerd toegangsbeheer van Azure en fijnmazige controle over het verloop, de snelheid en de gebruiksregio(s) voor het specifieke token. Met andere woorden, het SAS-token kan worden gebruikt om toepassingen in staat te stellen toegang op een veiligere manier te beheren dan de gedeelde sleutel.

Voor openbaar beschikbaar gemaakte toepassingen wordt aanbevolen om een specifieke lijst met toegestane oorsprongen te configureren op de resource Van het account toewijzen om misbruik van het genereren te beperken en het SAS-token regelmatig te vernieuwen.

Type: apiKey
In: header

Voorbeelden

Update previously uploaded GeoJSON data containing geometries that represent a collection of geofences

Sample Request

PUT https://us.atlas.microsoft.com/mapData/25084fb7-307a-4720-8f91-7952a0b91012?subscription-key=[subscription-key]&api-version=1.0

{
  "type": "FeatureCollection",
  "features": [
    {
      "type": "Feature",
      "geometry": {
        "type": "Point",
        "coordinates": [
          -122.126986,
          47.639754
        ]
      },
      "properties": {
        "geometryId": "001",
        "radius": 500
      }
    }
  ]
}

Sample Response

Location: https://atlas.microsoft.com/mapData/metadata/{udid}?api-version=1.0
Access-Control-Expose-Headers: Location
{
  "operationId": "{operationId}",
  "status": "Succeeded",
  "created": "2020-01-02 1:02:03 AM +00:00",
  "resourceLocation": "https://atlas.microsoft.com/mapData/metadata/{resourceId}?api-version=1.0"
}
Location: https://atlas.microsoft.com/mapData/operations/{operationId}?api-version=1.0
Access-Control-Expose-Headers: Location
{
  "error": {
    "code": "400 Bad Request",
    "message": "Upload request failed. Your data has been removed as we encountered the following problems with it: Map data is not a valid GeoJSON geometry."
  }
}
{
  "error": {
    "code": "400 BadRequest",
    "message": "Bad request: one or more parameters were incorrectly specified or are mutually exclusive."
  }
}
{
  "error": {
    "code": "401 Unauthorized",
    "message": "Access denied due to invalid subscription key. Make sure to provide a valid key for an active subscription."
  }
}
{
  "error": {
    "code": "403 Forbidden",
    "message": "Permission, capacity, or authentication issues."
  }
}
{
  "error": {
    "code": "404 NotFound",
    "message": "Not Found: the requested resource could not be found, but it may be available again in the future."
  }
}
{
  "error": {
    "code": "500 InternalServerError",
    "message": "An error occurred while processing the request. Please try again later."
  }
}

Definities

Name Description
LongRunningOperationResult

Het antwoordmodel voor een Long-Running Operations-API.

ODataError

Dit object wordt geretourneerd wanneer er een fout optreedt in de Azure Maps-API.

ODataErrorResponse

Dit antwoordobject wordt geretourneerd wanneer er een fout optreedt in de Azure Maps-API.

type

De status van de aanvraag.

LongRunningOperationResult

Het antwoordmodel voor een Long-Running Operations-API.

Name Type Description
created

string

De gemaakte tijdstempel.

error

ODataError

Dit object wordt geretourneerd wanneer er een fout optreedt in de Azure Maps-API.

operationId

string

De id voor deze langdurige bewerking.

resourceLocation

string

De locatie-URI voor meer informatie over de gemaakte resource. Dit wordt alleen opgegeven wanneer de aanvraag is voltooid.

status

type

De status van de aanvraag.

warning

ODataError

Dit object wordt geretourneerd wanneer er een fout optreedt in de Azure Maps-API.

ODataError

Dit object wordt geretourneerd wanneer er een fout optreedt in de Azure Maps-API.

Name Type Description
code

string

De ODataError-code.

details

ODataError[]

Dit object wordt geretourneerd wanneer er een fout optreedt in de Azure Maps-API.

message

string

Indien beschikbaar, een door mensen leesbare beschrijving van de fout.

target

string

Indien beschikbaar, het doel dat de fout veroorzaakt.

ODataErrorResponse

Dit antwoordobject wordt geretourneerd wanneer er een fout optreedt in de Azure Maps-API.

Name Type Description
error

ODataError

Dit object wordt geretourneerd wanneer er een fout optreedt in de Azure Maps-API.

type

De status van de aanvraag.

Name Type Description
Failed

string

De aanvraag heeft een of meer fouten.

NotStarted

string

De verwerking van de aanvraag is nog niet gestart.

Running

string

De verwerking van de aanvraag is gestart.

Succeeded

string

De aanvraag is voltooid.