此错误通常出现在 Blob 存储的触发器函数中使用了条件标头(如 If-Modified-Since、If-None-Match 等)并且条件未得到满足时。要解决此问题,需要检查触发器函数中的条件标头是否正确,并确保与 Blob 存储中相应的 Blob 符合条件。以下是一个 C# 示例代码:
public static void Run(Stream myBlob, string name, TraceWriter log)
{
log.Info($"C# Blob trigger function processed blob\n Name:{name} \n Length: {myBlob.Length} Bytes");
var blobClient = new BlobClient(connectionString, containerName, name);
var properties = blobClient.GetProperties();
var lastModified = properties.Value.LastModified.DateTime.ToString("r");
if (string.IsNullOrEmpty(myBlob?.ToString()))
{
log.Info($"Empty blob found. Name: {name}");
return;
}
var blobModifiedSinceHeaderValue = GetBlobModifiedSinceHeaderValue(myBlob, properties.Value.ContentMD5);
var modifiedSinceCondition = new HttpHeaderConditionHeaderValue("If-Modified-Since", lastModified);
var blobProperties = blobClient.GetProperties(conditions: new[] { modifiedSinceCondition });
log.Info($"Blob Properties Retrieved. Modified On: {blobProperties.Value.LastModified.DateTime}.");
var blobReadResult = new StreamReader(blobClient.Download().Value.Content).ReadToEnd();
// Deserialize the JSON data into a dynamic object
dynamic eventData = JsonConvert.DeserializeObject(blobReadResult);
if (eventData.data != null && eventData.data.Count > 0)
{
log.Info($"Parsed items from blob. Count: {eventData.data.Count}");
}
else
{
log.Info("No items to process.");
}
}
private static string GetBlobModifiedSinceHeaderValue(Stream stream, string contentMD5)
{
var streamReader = new StreamReader(stream);
try
{
var hash = MD5.Create();
var contentBytes = Encoding.UTF8.GetBytes(streamReader.ReadToEnd());
var contentHash = Convert.ToBase64String(hash.ComputeHash(contentBytes));
if (string.IsNullOrEmpty(contentMD5))
{
contentMD5 = contentHash;
}
}
catch (Exception ex)
{
throw new Exception($"Unable to get contentMD5 for stream: {ex}");
}
finally
{
stream.Position = 0;
}
return DateTime.UtcNow.ToString("r");
}
以上代码中,对 If-Modified-Since 头的处理是基于指定的条件进行处理,以检查 Blob 是否