本教程使用Flow Service API指导您完成将Azure Blob(以下简称“Blob”)连接到Adobe Experience Platform的步骤。
本指南要求对Adobe Experience Platform的下列部分有工作上的理解:
以下各节提供您需要了解的其他信息,以便使用Flow Service API成功创建Blob源连接。
要使Flow Service与Blob存储连接,必须为以下连接属性提供值:
凭据 | 描述 |
---|---|
connectionString |
包含验证Blob为Experience Platform所必需的授权信息的字符串。 Blob连接字符串模式为:DefaultEndpointsProtocol=https;AccountName={ACCOUNT_NAME};AccountKey={ACCOUNT_KEY} 。 有关连接字符串的详细信息,请参阅配置连接字符串的此Blob文档。 |
sasUri |
可用作连接Blob帐户的替代身份验证类型的共享访问签名URI。 Blob SAS URI模式为:https://{ACCOUNT_NAME}.blob.core.windows.net/?sv=<storage version>&st={START_TIME}&se={EXPIRE_TIME}&sr={RESOURCE}&sp={PERMISSIONS}>&sip=<{IP_RANGE}>&spr={PROTOCOL}&sig={SIGNATURE}> 有关详细信息,请参阅此Blob文档,关于共享访问签名URI。 |
connectionSpec.id |
创建连接所需的唯一标识符。 Blob的连接规范ID为:4c10e202-c428-4796-9208-5f1f5732b1cf |
本教程提供示例API调用,以演示如何设置请求的格式。 这包括路径、必需的标头和格式正确的请求负载。 还提供API响应中返回的示例JSON。 有关示例API调用文档中使用的约定的信息,请参阅Experience Platform疑难解答指南中的如何阅读示例API调用一节。
要调用平台API,您必须先完成身份验证教程。 完成身份验证教程将提供所有Experience PlatformAPI调用中每个所需标头的值,如下所示:
Authorization: Bearer {ACCESS_TOKEN}
x-api-key: {API_KEY}
x-gw-ims-org-id: {IMS_ORG}
Experience Platform中的所有资源(包括属于Flow Service的资源)都隔离到特定虚拟沙箱。 对平台API的所有请求都需要一个标头,它指定操作将在以下位置进行的沙箱的名称:
x-sandbox-name: {SANDBOX_NAME}
所有包含有效负荷(POST、PUT、PATCH)的请求都需要额外的媒体类型标头:
Content-Type: application/json
连接指定源并包含该源的凭据。 每个Blob帐户只需要一个连接,因为它可用于创建多个数据流以引入不同的数据。
要使用基于连接字符串的身份验证创建Blob连接,请在提供Blob connectionString
时向Flow Service API发出POST请求。
API格式
POST /connections
请求
要创建Blob连接,其唯一连接规范ID必须作为POST请求的一部分提供。 Blob的连接规范ID为4c10e202-c428-4796-9208-5f1f5732b1cf
。
curl -X POST \
'https://platform.adobe.io/data/foundation/flowservice/connections' \
-H 'Authorization: Bearer {ACCESS_TOKEN}' \
-H 'x-api-key: {API_KEY}' \
-H 'x-gw-ims-org-id: {IMS_ORG}' \
-H 'x-sandbox-name: {SANDBOX_NAME}' \
-H 'Content-Type: application/json' \
-d '{
"name": "Azure Blob connection using connectionString",
"description": "Azure Blob connection using connectionString",
"auth": {
"specName": "ConnectionString",
"params": {
"connectionString": "DefaultEndpointsProtocol=https;AccountName={ACCOUNT_NAME};AccountKey={ACCOUNT_KEY}"
}
},
"connectionSpec": {
"id": "4c10e202-c428-4796-9208-5f1f5732b1cf",
"version": "1.0"
}
}'
属性 | 描述 |
---|---|
auth.params.connectionString |
访问Blob存储中的数据所需的连接字符串。 Blob连接字符串模式为:DefaultEndpointsProtocol=https;AccountName={ACCOUNT_NAME};AccountKey={ACCOUNT_KEY} 。 |
connectionSpec.id |
Blob存储连接规范ID为:4c10e202-c428-4796-9208-5f1f5732b1cf |
响应
成功的响应会返回新创建的连接的详细信息,包括其唯一标识符(id
)。 在下一个教程中浏览您的存储需要此ID。
{
"id": "4cb0c374-d3bb-4557-b139-5712880adc55",
"etag": "\"1700c57b-0000-0200-0000-5e3b3f440000\""
}
共享访问签名(SAS)URI允许对您的Blob帐户进行安全授权。 您可以使用SAS创建不同访问权限的身份验证凭据,因为基于SAS的身份验证允许您设置权限、开始和到期日期,以及为特定资源提供资源。
要使用共享访问签名URI创建Blob连接,请向Flow Service API发出POST请求,同时为Blob sasUri
提供值。
API格式
POST /connections
请求
curl -X POST \
'https://platform.adobe.io/data/foundation/flowservice/connections' \
-H 'Authorization: Bearer {ACCESS_TOKEN}' \
-H 'x-api-key: {API_KEY}' \
-H 'x-gw-ims-org-id: {IMS_ORG}' \
-H 'x-sandbox-name: {SANDBOX_NAME}' \
-H 'Content-Type: application/json' \
-d '{
"name": "Azure Blob source connection using SAS URI",
"description": "Azure Blob source connection using SAS URI",
"auth": {
"specName": "SasURIAuthentication",
"params": {
"sasUri": "https://{ACCOUNT_NAME}.blob.core.windows.net/?sv={STORAGE_VERSION}&st={START_TIME}&se={EXPIRE_TIME}&sr={RESOURCE}&sp={PERMISSIONS}>&sip=<{IP_RANGE}>&spr={PROTOCOL}&sig={SIGNATURE}>"
}
},
"connectionSpec": {
"id": "4c10e202-c428-4796-9208-5f1f5732b1cf",
"version": "1.0"
}
}'
属性 | 描述 |
---|---|
auth.params.connectionString |
访问Blob存储中的数据所需的SAS URI。 Blob SAS URI模式为:https://{ACCOUNT_NAME}.blob.core.windows.net/?sv=<storage version>&st={START_TIME}&se={EXPIRE_TIME}&sr={RESOURCE}&sp={PERMISSIONS}>&sip=<{IP_RANGE}>&spr={PROTOCOL}&sig={SIGNATURE}> 。 |
connectionSpec.id |
Blob存储连接规范ID为:4c10e202-c428-4796-9208-5f1f5732b1cf |
响应
成功的响应会返回新创建的连接的详细信息,包括其唯一标识符(id
)。 在下一个教程中浏览您的存储需要此ID。
{
"id": "4cb0c374-d3bb-4557-b139-5712880adc55",
"etag": "\"1700c57b-0000-0200-0000-5e3b3f440000\""
}
通过本教程,您已使用API创建了Blob连接,并且作为响应主体的一部分获得了唯一ID。 您可以使用此连接ID来使用流服务API或使用流服务API采集拼花存储。