当我使用web角色时,我只是在azure门户中上传证书,我能够看到它.Now,我已经切换到azure中的网站,我在azure管理门户中上传了证书,但我的代码根本看不到它。
有没有一些我们需要做的配置或一些其他的方式来访问上传到azure网站的证书。
这就是我尝试访问上传的证书的方式。
private List<string> GetAvailableCertificatesFromStore()
{
var list = new List<string>();
var store = new X509Store(StoreName.My,StoreLocation.LocalMachine);
store.Open(OpenFlags.ReadOnly);
try
{
foreach (var cert in store.Certificates)
{
// todo: add friendly name
list.Add(string.Format("{0}", cert.Subject));
}
}
finally
{
store.Close();
}
return list;
}
发布于 2015-01-07 20:50:46
在Azure WebSite中使用证书的方式与在IIS的本地副本中使用证书的方式不同,甚至在Visual Studio中以调试模式运行网站时也是如此。简而言之,网站不能访问传统意义上的证书存储...这都是在内存中完成的。
首先,一旦您通过Azure门户上传了证书,您需要添加一个名为WEBSITE_LOAD_CERTIFICATES的应用程序设置(也是通过门户),并将其值设置为您上传的证书的指纹。如果您愿意,这可以是多个指纹的逗号分隔列表,甚至可以*加载所有上传的证书。我假设这会强制将证书加载到内存中。
要加载证书,您可以执行以下操作:
var store = new X509Store(StoreName.My, StoreLocation.CurrentUser);
store.Open(OpenFlags.ReadOnly);
var certs = store.Certificates.Find(X509FindType.FindByThumbprint, YOUR_THUMBPRINT, false);
如果要确保证书有效,请将“false”更改为“true”。
我在这里找到了这个信息,这比我拥有的更好地解释了它:http://azure.microsoft.com/blog/2014/10/27/using-certificates-in-azure-websites-applications/
https://stackoverflow.com/questions/23827884
复制相似问题