这是一个带有输出 blob 绑定的组合 HTTP 触发函数:
[FunctionName("HttpTriggeredFunction")]
public static async Task<IActionResult> Run(
[HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest httpRequest,
[Blob("blobcontainer", Connection = "StorageConnectionString")] CloudBlobContainer outputContainer,
ILogger log)
{
log.LogInformation("C# HTTP trigger function processed a request.");
await outputContainer.CreateIfNotExistsAsync();
var requestBody = await new StreamReader(httpRequest.Body).ReadToEndAsync();
var blobName = Guid.NewGuid().ToString();
var cloudBlockBlob = outputContainer.GetBlockBlobReference(blobName);
await cloudBlockBlob.UploadTextAsync(requestBody);
return new OkObjectResult(blobName);
}
它使用CloudBlobContainer 输出类型来获取对blob 容器的引用,然后您可以使用.GetBlockBlobReference("blobPath") 等方法来获取对blob 的引用。
一旦你有一个 blob 的引用,你就可以使用不同的方法来上传:
cloudBlockBlob.UploadFromByteArrayAsync()
cloudBlockBlob.UploadFromFileAsync()
cloudBlockBlob.UploadTextAsync()
cloudBlockBlob.UploadFromStreamAsync()
要让它在本地运行,您需要进行一些设置。请注意我的示例中的属性[Blob("blobcontainer", Connection = "StorageConnectionString")]
- “blobcontainer”这可以是您想要的任何内容,并且将是通过此行
outputContainer.CreateIfNotExistsAsync(); 在您的存储帐户中创建的容器的名称(如果它尚不存在)。
- Connection = "StorageConnectionString" 这可以是您的
local.settings.json 中用于存储帐户连接字符串的设置。在本地开发时,我建议将其设置为"UseDevelopmentStorage=true",以便您可以利用存储模拟器。然后,当您准备好部署到 Azure 上时,您将在函数应用中创建一个包含实际连接字符串的设置。
local.settings.json
{
"IsEncrypted": false,
"Values": {
"AzureWebJobsStorage": "UseDevelopmentStorage=true",
"FUNCTIONS_WORKER_RUNTIME": "dotnet",
"StorageConnectionString": "UseDevelopmentStorage=true"
}
}