c# – IIS 7.x,添加启用HTTPS的站点:SiteCollection.Add(string
发布时间:2020-12-15 03:58:07 所属栏目:百科 来源:网络整理
导读:我需要以编程方式添加一个IIS 7.x站点,当我们默认使用HTTPS / SSL绑定来创建这个应用程序时,我将陷入困境,usig SiteCollection.Add(string,string,byte[]) overload. 给予https:*:80:test.localhost https:*:443:test.localhost作为bindingInformation
我需要以编程方式添加一个IIS 7.x站点,当我们默认使用HTTPS / SSL绑定来创建这个应用程序时,我将陷入困境,usig
SiteCollection.Add(string,string,byte[]) overload.
给予https:*:80:test.localhost https:*:443:test.localhost作为bindingInformation抛出一个带有此消息的ArgumentException:指定的HTTPS绑定无效. 这个绑定信息有什么问题? 谢谢. 编辑:我正在使用Microsoft.Web.Administration程序集. 解决方法
这是我做了什么来创建https网站,它的工作.当然,我在这里跳过一些代码.
using Microsoft.Web.Administration ... using(var manager = new ServerManager()) { // variables are set in advance... var site = manager.Sites.Add(siteName,siteFolder,siteConfig.Port); var store = new X509Store(StoreName.AuthRoot,StoreLocation.LocalMachine); store.Open(OpenFlags.OpenExistingOnly | OpenFlags.ReadWrite); // certHash is my certificate's hash,byte[] var binding = site.Bindings.Add("*:443:",certHash,store.Name); binding.Protocol = "https"; store.Close(); site.ApplicationDefaults.EnabledProtocols = "http,https"; manager.CommitChanges(); } UPD:证书是通过以下方式从pfx文件创建的: // get certificate from the file string pfx = Directory.GetFiles(folder,"*.pfx",SearchOption.AllDirectories).FirstOrDefault(); var store = new X509Store(StoreName.Root,StoreLocation.LocalMachine); store.Open(OpenFlags.OpenExistingOnly | OpenFlags.ReadWrite); var certificate = new X509Certificate2(pfx,certPassword,X509KeyStorageFlags.Exportable | X509KeyStorageFlags.PersistKeySet); store.Add(certificate); store.Close(); certHash = certificate.GetCertHash(); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |