![](/img/trans.png)
[英]Secret initialization from Blob storage failed due to missing both an Azure Storage connection string and a SAS connection uri
[英]Programmatically extract properties from an Azure blob storage connection string
给定一个 blob 存储连接字符串,例如:
DefaultEndpointsProtocol=https;AccountName=foo;AccountKey=bar;EndpointSuffix=core.windows.net
是否有已知的 Microsoft 对象可以将其转换/反序列化为? 我不想实际解析字符串,但我需要从整个连接字符串中提取 AccountName 和 AccountKey,我有一个字符串。
预先阻止可能的“你为什么要这样做?” 问题...我有一个现有的类,需要将连接字符串作为字符串注入。 为避免破坏性更改,我无法更改它。 但是我确实需要在这个类中添加一些需要 AccountName 和 AccountKey 作为单独项目的方法。
谢谢!
如果安装Microsoft.Azure.Storage.Common
,则可以以编程方式提取连接字符串的几位,而无需自己解析连接字符串。
例如(混淆了实际信息):
using System;
using Microsoft.Azure.Storage;
namespace dotnet_connectionstring
{
class Program
{
static void Main(string[] args)
{
CloudStorageAccount storageAccount = CloudStorageAccount.Parse("DefaultEndpointsProtocol=https;AccountName=youraccount;AccountKey=yourkey==;EndpointSuffix=core.windows.net");
Console.WriteLine(storageAccount.BlobEndpoint);
Console.WriteLine("---");
Console.WriteLine(storageAccount.BlobStorageUri);
Console.WriteLine("---");
Console.WriteLine(storageAccount.Credentials.AccountName);
Console.WriteLine("---");
Console.WriteLine(storageAccount.Credentials.ExportBase64EncodedKey());
}
}
}
这给出了类似的输出:
https://youraccount.blob.core.windows.net/ --- Primary = 'https://youraccount.blob.core.windows.net/'; Secondary = 'https://youraccount-secondary.blob.core.windows.net/' --- youraccount --- yourkey==
据我所知,没有任何类可以做到这一点,但将其更改为字典并不难。 下面举例。
string connString = "DefaultEndpointsProtocol=https;AccountName=foo;AccountKey=bar;EndpointSuffix=core.windows.net";
var connStringArray = connString.Split(';');
var dictionary = new Dictionary<string, string>();
foreach (var item in connStringArray)
{
var itemKeyValue = item.Split('=');
dictionary.Add(itemKeyValue[0], itemKeyValue[1]);
}
然后你可以使用它访问你需要的值。
dictionary["AccountName"]
dictionary["AccountKey"]
为此,我们有来自Microsoft.WindowsAzure.Storage
程序集的CloudStorageAccount
类型。
CloudStorageAccount sa = CloudStorageAccount.Parse(connString);
@David Makogon 的答案当然是最优雅的,但Microsoft.Azure.Storage.Common
包已被弃用(如评论中所述)。 基于@Patrick Mcvay 的回答(由于连接字符串值中可能有“=”,因此有点问题),解析连接字符串的一种简单方法是:
var parsedConnectionString = new Dictionary<string, string>();
foreach (var item in ConnectionString.Split(';'))
{
var idx = item.IndexOf('=');
parsedConnectionString[item.Substring(0, idx)] =
item.Substring(idx + 1, item.Length - idx - 1);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.