Version | Artikellänk |
---|---|
AEM as a Cloud Service | Klicka här |
AEM 6.5 | Den här artikeln |
The Assets HTTP-API:t gör det möjligt att skapa, läsa, uppdatera och ta bort (CRUD) på digitala resurser, inklusive metadata, återgivningar och kommentarer, samt strukturerat innehåll med Experience Manager Innehållsfragment. Den exponeras vid /api/assets
och implementeras som REST API. Den innehåller stöd för innehållsfragment.
Så här kommer du åt API:
https://[hostname]:[port]/api.json
.https://[hostname]:[server]/api/assets.json
.API-svaret är en JSON-fil för vissa MIME-typer och en svarskod för alla MIME-typer. JSON-svaret är valfritt och kanske inte är tillgängligt, till exempel för PDF-filer. Använd svarskoden för ytterligare analyser eller åtgärder.
Efter Off Time, är en resurs och dess återgivningar inte tillgängliga via Assets webbgränssnitt och via HTTP API. API:t returnerar 404-felmeddelande om On Time kommer i framtiden eller Off Time har redan varit.
HTTP API uppdaterar metadataegenskaperna i jcr
namnutrymme. Experience Manager uppdaterar emellertid metadataegenskaperna i dc
namnutrymme.
A innehållsfragment är en särskild typ av tillgång. Den kan användas för att komma åt strukturerade data, t.ex. texter, siffror och datum. Som det finns flera skillnader mellan standard
resurser (t.ex. bilder eller dokument), kan ytterligare regler gälla för hantering av innehållsfragment.
Mer information finns på Stöd för innehållsfragment i Experience Manager Assets HTTP API.
The Assets HTTP API visar två huvudelement, mappar och resurser (för standardresurser).
Dessutom visas mer detaljerade element för anpassade datamodeller som beskriver strukturerat innehåll i innehållsfragment. Se Datamodeller för innehållsfragment för ytterligare information.
Mappar är som kataloger i traditionella filsystem. De är behållare för andra mappar eller kontroller. Mappar har följande komponenter:
Enheter: Enheterna i en mapp är dess underordnade element, som kan vara mappar och resurser.
Egenskaper:
name
är namnet på mappen. Detta är samma som det sista segmentet i URL-sökvägen utan tillägget.title
är en valfri mapptitel som kan visas i stället för dess namn.Vissa egenskaper för mapp eller resurs är mappade till ett annat prefix. The jcr
prefix för jcr:title
, jcr:description
och jcr:language
ersätts med dc
prefix. I den returnerade JSON-koden dc:title
och dc:description
innehåller värdena för jcr:title
och jcr:description
, respektive.
Länkar I mapparna visas tre länkar:
self
: Länka till sig själv.parent
: Länka till den överordnade mappen.thumbnail
: (Valfritt) länka till en mappminiatyrbild.I Experience Manager innehåller en resurs följande element:
Mer information om element i innehållsfragment finns i Stöd för innehållsfragment i Experience Manager Assets HTTP API.
I Experience Manager en mapp har följande komponenter:
The Assets HTTP API innehåller följande funktioner:
För att underlätta läsbarheten utelämnar följande exempel den fullständiga cURL-notationen. Faktum är att notationen korrelerar med Återställ som är en skriptwrapper för cURL
.
Förutsättningar
https://[aem_server]:[port]/system/console/configMgr
.POST
, PUT
, DELETE
.Hämtar en siren-representation av en befintlig mapp och av dess underordnade enheter (undermappar eller resurser).
Begäran: GET /api/assets/myFolder.json
Svarskoder: Svarskoderna är:
Svar: Klassen för enheten som returneras är en resurs eller en mapp. Egenskaperna för enheter som ingår är en deluppsättning av alla egenskaper för varje enhet. För att få en fullständig representation av enheten bör kunderna hämta innehållet i den URL som länken pekar på med en rel
av self
.
Skapar en ny sling
: OrderedFolder
vid den angivna sökvägen. Om en *
anges i stället för ett nodnamn, används parameternamnet som nodnamn. Godkänt som begärandedata är antingen en Siren-representation av den nya mappen eller en uppsättning namn/värde-par, kodade som application/www-form-urlencoded
eller multipart
/ form
- data
, användbart när du vill skapa en mapp direkt från ett HTML-formulär. Dessutom kan mappens egenskaper anges som URL-frågeparametrar.
Ett API-anrop misslyckas med en 500
svarskod om den överordnade noden för den angivna sökvägen inte finns. Ett anrop returnerar en svarskod 409
om mappen redan finns.
Parametrar: name
är mappnamnet.
Begäran
POST /api/assets/myFolder -H"Content-Type: application/json" -d '{"class":"assetFolder","properties":{"jcr:title":"My Folder"}}'
POST /api/assets/* -F"name=myfolder" -F"jcr:title=My Folder"
Svarskoder: Svarskoderna är:
Placera den angivna filen på den angivna sökvägen för att skapa en resurs i DAM-databasen. Om en *
anges i stället för ett nodnamn, används parameternamnet eller filnamnet som nodnamn.
Parametrar: Parametrarna är name
för resursnamnet och file
för filreferensen.
Begäran
POST /api/assets/myFolder/myAsset.png -H"Content-Type: image/png" --data-binary "@myPicture.png"
POST /api/assets/myFolder/* -F"name=myAsset.png" -F"file=@myPicture.png"
Svarskoder: Svarskoderna är:
Uppdaterar en resurs binärfil (återgivning med namnet original). En uppdatering utlöser standardarbetsflödet för resurshantering som körs, om det är konfigurerat.
Begäran: PUT /api/assets/myfolder/myAsset.png -H"Content-Type: image/png" --data-binary @myPicture.png
Svarskoder: Svarskoderna är:
Uppdaterar metadataegenskaperna för resursen. Om du uppdaterar någon egenskap i dc:
namnutrymme, uppdaterar API-gränssnittet samma egenskap i jcr
namnutrymme. API:t synkroniserar inte egenskaperna under de två namnutrymmena.
Begäran: PUT /api/assets/myfolder/myAsset.png -H"Content-Type: application/json" -d '{"class":"asset", "properties":{"jcr:title":"My Asset"}}'
Svarskoder: Svarskoderna är:
dc
och jcr
namespaceAPI-metoden uppdaterar metadataegenskaperna i jcr
namnutrymme. Uppdateringarna som görs med användargränssnittet ändrar metadataegenskaperna i dc
namnutrymme. Synkronisera metadatavärdena mellan dc
och jcr
I kan du skapa ett arbetsflöde och konfigurera Experience Manager för att köra arbetsflödet när resursen redigeras. Använd ett ECMA-skript för att synkronisera de metadataegenskaper som krävs. Följande exempelskript synkroniserar titelsträngen mellan dc:title
och jcr:title
.
var workflowData = workItem.getWorkflowData();
if (workflowData.getPayloadType() == "JCR_PATH")
{
var path = workflowData.getPayload().toString();
var node = workflowSession.getSession().getItem(path);
var metadataNode = node.getNode("jcr:content/metadata");
var jcrcontentNode = node.getNode("jcr:content");
if (jcrcontentNode.hasProperty("jcr:title"))
{
var jcrTitle = jcrcontentNode.getProperty("jcr:title");
metadataNode.setProperty("dc:title", jcrTitle.toString());
metadataNode.save();
}
}
Skapa en ny resursåtergivning för en resurs. Om parameternamnet för begäran inte anges används filnamnet som återgivningsnamn.
Parametrar: Parametrarna är name
för renderingens namn och file
som en filreferens.
Begäran
POST /api/assets/myfolder/myasset.png/renditions/web-rendition -H"Content-Type: image/png" --data-binary "@myRendition.png"
POST /api/assets/myfolder/myasset.png/renditions/* -F"name=web-rendition" -F"file=@myRendition.png"
Svarskoder: Svarskoderna är:
Uppdateringar ersätter en resursåtergivning med nya binära data.
Begäran: PUT /api/assets/myfolder/myasset.png/renditions/myRendition.png -H"Content-Type: image/png" --data-binary @myRendition.png
Svarskoder: Svarskoderna är:
Skapar en ny resurskommentar.
Parametrar: Parametrarna är message
för kommentarens meddelandetext och annotationData
för anteckningsdata i JSON-format.
Begäran: POST /api/assets/myfolder/myasset.png/comments/* -F"message=Hello World." -F"annotationData={}"
Svarskoder: Svarskoderna är:
Kopierar en mapp eller resurs som är tillgänglig på den angivna sökvägen till ett nytt mål.
Begäranrubriker: Parametrarna är:
X-Destination
- en ny mål-URI inom API-lösningens omfång att kopiera resursen till.X-Depth
- antingen infinity
eller 0
. Använda 0
kopierar bara resursen och dess egenskaper och inte dess underordnade.X-Overwrite
- Användning F
för att förhindra att en resurs skrivs över på det befintliga målet.Begäran: COPY /api/assets/myFolder -H"X-Destination: /api/assets/myFolder-copy"
Svarskoder: Svarskoderna är:
Flyttar en mapp eller resurs vid den angivna sökvägen till ett nytt mål.
Begäranrubriker: Parametrarna är:
X-Destination
- en ny mål-URI inom API-lösningens omfång att kopiera resursen till.X-Depth
- antingen infinity
eller 0
. Använda 0
kopierar bara resursen och dess egenskaper och inte dess underordnade.X-Overwrite
- Använd antingen T
för att tvinga bort befintliga resurser eller F
för att förhindra att en befintlig resurs skrivs över.Begäran: MOVE /api/assets/myFolder -H"X-Destination: /api/assets/myFolder-moved"
Använd inte /content/dam
i webbadressen. Ett exempelkommando för att flytta resurser och skriva över befintliga är:
curl -u admin:admin -X MOVE https://[aem_server]:[port]/api/assets/source/file.png -H "X-Destination: https://[aem_server]:[port]/api/assets/destination/file.png" -H "X-Overwrite: T"
Svarskoder: Svarskoderna är:
Tar bort en resurs (-tree) vid den angivna sökvägen.
Begäran
DELETE /api/assets/myFolder
DELETE /api/assets/myFolder/myAsset.png
DELETE /api/assets/myFolder/myAsset.png/renditions/original
Svarskoder: Svarskoderna är:
HTTP API uppdaterar metadataegenskaperna i jcr
namnutrymme. Experience Manager uppdaterar emellertid metadataegenskaperna i dc
namnutrymme.
Resursens HTTP API returnerar inte alla metadata. Namnutrymmena är hårdkodade och endast dessa namnutrymmen returneras. Fullständiga metadata finns i resurssökvägen /jcr_content/metadata.json
.