Exchange2013 证书服务管理(三)

说到证书服务,我们大家都知道,一般企业内部都会有个证书服务器,但是有些在外网需要访问的服务需要在第三方证书提供点进行申请,但是都离不开内部CA Server的,今天咱们介绍如何在windows server2012下部署CA从而进行配置及通过内部CA申请Exchange2013证书.

我们首先是部署CA服务器,在此我的DC为我内部环境的CA Server

首先是安装AD证书服务及所需要的角色

image

image

image

image

安装完AD证书服务后,开始进行配置

image

image

正常需要选择”证书办法机构”及”证书颁发机构web注册”即可

image

因为是在域环境下运行的,选择企业根即可.

image

image

image

image

image

image

image

image

image

CA服务部署完成

image

我们知道Exchange2013已将证书服务从Exchange2010的EMC中的服务器配置下移动到了服务器选项下,部署完第一个Exchange组织后系统默认会自动新建三个证书,但是都是自签名证书,所以在此我们需要通过内部的CA服务器进行证书申请工作

image

image

首先打开Exchange管理中心(https://Ex2013-01.ab.com/ECP),切换到”服务器”---“证书”---新建证书

image

选择—创建从证书颁发机构获取证书的请求

image

Exchange证书名称,在此我定义为:Ex2013-certsrv;

image

image

image

image

image

设置保存位置,再次我保存在我的C盘下的cert文件下的命名为cert.req格式的文件内;

image

注意保存的格式必需为.req结尾的

image

通过记事本打开cert.req文件,然后全选

image

通过IE方式浏览CA管理链接;http://abc-dc.abc.com/certsrv ,然后输入有效的用户及密码

image

image

image

image

image

image

建议将证书及证书链都下载下来方便后面用到

image

image

成功将证书及证书链下载并保存到桌面

image

将申请后的证书导入到Exchange2013内即可;我们再次打开证书Exchange管理中心;切换到“服务器”---证书----我们发现多了一个证书,该证书就是我们通过CA申请的证书,该证书的状态是为---搁置,同时也未分配服务;我们需要完成--”搁置“

image

我们现将下载下来的证书拷贝到C盘根目录下的Cert文件夹下,然后单击完成

image

选择刚才通过CA申请的Exchange证书路径,注意以.CER结尾的是证书,以.p7B结尾的是证书链

image

输入刚才保存证书的路径C盘下的Cert目录下;\\Ex2013-01(192.168.100.10)\cert\certsrv1.cer

image

 

 

完成搁置后状态变为续订,下面我们需要的就是为该证书分配服务,定该证书后单击编辑

image

 

 

我们编辑后切换到服务标签

image

我们勾选所需要分配的服务,在此我选择SMTP 、IMAP 、POP、IIS,然后单击保存

image

因为系统默认有一张证书为SMTP服务提供服务,所以提示警告,单击是覆盖即可

image

image

现在申请了非自签名证书,可以将起其他自签名证书删除了

image

image

重新登陆Exchange管理中心

image

image



本文转自 高文龙 51CTO博客,原文链接:http://blog.51cto.com/gaowenlong/1059929,如需转载请自行联系原作者

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 `RestTemplate.exchange` 方法发送 HTTPS 请求时,如果服务器的证书不是由受信任的 CA 签发,那么默认情况下会抛出 `SSLHandshakeException` 异常,说明 SSL 握手失败。为了信任自签名的证书,可以通过以下步骤实现: 1. 创建一个 `RestTemplate` 实例,并设置其 `HttpClient` 配置。 ```java RestTemplate restTemplate = new RestTemplate(); CloseableHttpClient httpClient = HttpClients.custom() .setSSLContext(createSSLContext()) .setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE) .build(); restTemplate.setRequestFactory(new HttpComponentsClientHttpRequestFactory(httpClient)); ``` 2. 创建一个 SSL 上下文对象,并初始化它。 ```java private SSLContext createSSLContext() throws Exception { SSLContext sslContext = SSLContext.getInstance("TLS"); sslContext.init(null, new TrustManager[]{new X509TrustManager() { public X509Certificate[] getAcceptedIssuers() { return null; } public void checkClientTrusted(X509Certificate[] certs, String authType) { } public void checkServerTrusted(X509Certificate[] certs, String authType) { } }}, new SecureRandom()); return sslContext; } ``` 这里创建了一个 `SSLContext` 实例,并初始化它,其中信任管理器(TrustManager)是一个匿名内部类,它会信任所有的证书。在实际情况中,可以根据需要实现自定义的信任管理器,来对证书进行合法性验证。 3. 设置 SSL 主机名验证程序。 ```java HostnameVerifier hostnameVerifier = new NoopHostnameVerifier(); SSLConnectionSocketFactory sslSocketFactory = new SSLConnectionSocketFactory(sslContext, hostnameVerifier); Registry<ConnectionSocketFactory> socketFactoryRegistry = RegistryBuilder.<ConnectionSocketFactory>create() .register("https", sslSocketFactory) .build(); PoolingHttpClientConnectionManager connectionManager = new PoolingHttpClientConnectionManager(socketFactoryRegistry); connectionManager.setMaxTotal(MAX_TOTAL_CONNECTIONS); connectionManager.setDefaultMaxPerRoute(MAX_CONNECTIONS_PER_ROUTE); httpClient = HttpClients.custom() .setConnectionManager(connectionManager) .disableCookieManagement() .build(); ``` 这里创建了一个 `HostnameVerifier` 实例,用于验证 SSL 握手过程中的主机名。为了信任所有主机名,使用了一个 `NoopHostnameVerifier` 实例。实际情况中,可以根据需要实现自定义的主机名验证程序。 4. 定义请求头和请求体。 ```java HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); RequestBody requestBody = new RequestBody(); requestBody.setParam1("value1"); requestBody.setParam2("value2"); ``` 5. 构造一个 `HttpEntity` 实例,包含请求头和请求体。 ```java HttpEntity<RequestBody> requestEntity = new HttpEntity<>(requestBody, headers); ``` 6. 发送 HTTPS 请求,并获取响应结果。 ```java String url = "https://example.com/api"; ResponseEntity<String> responseEntity = restTemplate.exchange(url, HttpMethod.POST, requestEntity, String.class); String responseBody = responseEntity.getBody(); ``` 这里使用 `RestTemplate.exchange` 方法发送 HTTPS 请求,其内部会使用上述配置的 `HttpClient` 实例来发送请求。如果服务证书不被信任,会抛出 `SSLHandshakeException` 异常,如果服务证书被信任,则会返回响应结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值