首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在azure网站中访问上载的证书

在azure网站中访问上载的证书
EN

Stack Overflow用户
提问于 2014-05-23 19:21:25
回答 1查看 15.2K关注 0票数 26

当我使用web角色时,我只是在azure门户中上传证书,我能够看到它.Now,我已经切换到azure中的网站,我在azure管理门户中上传了证书,但我的代码根本看不到它。

有没有一些我们需要做的配置或一些其他的方式来访问上传到azure网站的证书。

这就是我尝试访问上传的证书的方式。

代码语言:javascript
复制
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;
}
EN

回答 1

Stack Overflow用户

发布于 2015-01-07 20:50:46

在Azure WebSite中使用证书的方式与在IIS的本地副本中使用证书的方式不同,甚至在Visual Studio中以调试模式运行网站时也是如此。简而言之,网站不能访问传统意义上的证书存储...这都是在内存中完成的。

首先,一旦您通过Azure门户上传了证书,您需要添加一个名为WEBSITE_LOAD_CERTIFICATES的应用程序设置(也是通过门户),并将其值设置为您上传的证书的指纹。如果您愿意,这可以是多个指纹的逗号分隔列表,甚至可以*加载所有上传的证书。我假设这会强制将证书加载到内存中。

要加载证书,您可以执行以下操作:

代码语言:javascript
复制
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/

票数 81
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23827884

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档