1. 生成p12证书

生成完成后,下载保存。

2. 将p12文件上传至服务器上的tomcat/keystore/上,此处取名为test.com.p12

3. 修改tomcat/conf/server.xml,增加如下配置:

    <Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"
maxThreads="150" scheme="https" secure="true"
clientAuth="false" sslProtocol="TLS"
keystoreFile="${catalina.base}/keystore/test.com.p12" keystorePass="test12345" keystoreType="PKCS12"
/>

其中keystorePass为生成p12文件时设定的存储密码。

重启tomcat即可生效。

4. 浏览器默认的SSL端口号是443,如果tomcat上述配置中端口号改为443的话,则需要root用户或者sudo启动tomcat。

可选的方案是使用类似nginx这样的软件,配置tcp层的proxy,将443端口转到tomcat的8443端口。

----------------------------- 以上内容是 2014 年写的,以下为 2016年的更新内容 -------------------------------------

最近在startcom上生成的p12有一点问题,在iOS和Android上访问时,被弹出类似“不受信任的证书”的提示。

经过调查,发现现在startcom上生成的证书没有包含CA Certifcate 信息。

tomcat改为用Apr方式配置,具体如下:

1. 下载tomcat native

http://tomcat.apache.org/download-native.cgi

因为openssl版本的原因,此处下载较旧的版本:  tomcat-native-1.1.34-src.tar.gz

2. 编译和安装 (以下使用的操作系统为centOS 6.5)

(1) 安装APR库

yum install apr-devel openssl-devel

(2) 编译

添加环境变量

vi ~/.bash_profile
export CATALINA_HOME=/home/webadmin/tomcat
export LD_LIBRARY_PATH=$CATALINA_HOME/lib
export LD_RUN_PATH=$CATALINA_HOME/lib

进入目录 tomcat-native-1.1.34-src/jni/native,执行configure:

./configure --with-apr=/usr/bin/apr--config \
--with-java-home=/usr/java/jdk1..0_43 \
--with-ssl=yes \
--prefix=$CATALINA_HOME

执行make

make

执行install

make install

编译安装成功后,可以看到tomcat/lib/下已经有相应的文件了:

-rw-r--r--  webadmin webadmin  3月   : libtcnative-.a
-rwxr-xr-x webadmin webadmin 3月 : libtcnative-.la
lrwxrwxrwx webadmin webadmin 3月 : libtcnative-.so -> libtcnative-.so.0.1.
lrwxrwxrwx webadmin webadmin 3月 : libtcnative-.so. -> libtcnative-.so.0.1.
-rwxr-xr-x webadmin webadmin 3月 : libtcnative-.so.0.1.
drwxr-xr-x webadmin webadmin 3月 : pkgconfig

(3) 配置tomcat

conf/server.xml中,配置8443端口:

    <Connector
protocol="org.apache.coyote.http11.Http11AprProtocol"
port="8443" maxThreads="4096"
scheme="https" secure="true" SSLEnabled="true"
SSLCertificateFile="${catalina.base}/keystore/2_test.test.com.crt"
SSLCertificateKeyFile="${catalina.base}/keystore/test.key"
SSLCACertificateFile="${catalina.base}/keystore/1_Intermediate.crt"
SSLVerifyClient="optional" SSLProtocol="all"
ciphers="TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_25
6_CBC_SHA384,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA,TLS_RSA_WITH_AES_128_CBC_SHA256,TLS_RSA_WITH_AES_128_CBC_SHA,TLS_RSA_WITH_
AES_256_CBC_SHA256,TLS_RSA_WITH_AES_256_CBC_SHA"
/>

其中三个文件都是pem格式(开头是 "-----BEGIN CERTIFICATE-----" 或 "-----BEGIN PRIVATE KEY-----")

test.key是在startcom上生成Certificate时的private key , 1_Intermediate.crt, 2_test.test.com.crt,是startcom上“Retreive”按钮点击下载获得的证书文件。

配置修改好以后,重启tomcat即可。

各个配置项的具体说明,请见文档: http://tomcat.apache.org/tomcat-6.0-doc/apr.html

tomcat配置SSL证书(使用startSSL申请到的证书)的更多相关文章

  1. 华为云服务器为Tomcat配置SSL

    近期由于开发小程序需要在云服务器上配置https访问协议,也遇到了一点小问题,把配置过程记录一下:SSL 证书申请下来之后会有 .jks .crt .pfx .pem为后缀的文件(如何申请SSL证书这 ...

  2. TOMCAT配置SSL认证为HTTPS协议服务

     1 . 问题概述 很多安全性要求较高的系统,都会使用安全套接字层(SSL)进行信息交换, Sun为了解决在Internet上的实现安全信息传输的解决方案.它实现了SSL和TSL(传输层安全)协议 ...

  3. 单点登录 SSO, 自动登录 , java 加密,ssl原理, Tomcat配置SSL

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 单点登录的英文简称为SSO(single sign on),单点登录功能使得用户只要登录 ...

  4. Tomcat配置SSL

    Tomcat配置SSL 查询网上资料配置如下: <Connector port="8443" protocol="HTTP/1.1" maxThreads ...

  5. 实战Tomcat配置SSL,使用openssl制作证书

    制作证书以及Tomcat配置 搭建openssl环境,下载openssl并设置环境变量方便命令行的使用: 修改openssl配置文件,设置dir目录,如设置dir=e:/temp/openssl_ca ...

  6. Tomcat配置SSL证书(PFX证书)

    公司项目,应该是阿里云服务器 在windows2008 R2搭建的 Tomcat部署SSL证书,本文以PFX证书为例. 配置好之后开始 一.什么是SSL(证书)? SSL证书服务(Alibaba Cl ...

  7. apache Tomcat配置SSL(https)步骤

    Tomcat配置https 1      生成Server端安全证书 要实现通信加密,首先要在本地准备一份符合X.509标准的Server端安全证书.如果有条件的话,可以向权威CA申请一份经过认证的安 ...

  8. linux apache Tomcat配置SSL(https)步骤

    https简介 它是由Netscape开发并内置于其浏览器中,用于对数据进行压缩和解压操作,并返回网络上传送回的结果.HTTPS实际上应用了Netscape的安全套接字层(SSL)作为HTTP应用层的 ...

  9. tomcat配置SSL双向认证

    一.SSL简单介绍 SSL(Secure Sockets Layer 安全套接层)就是一种协议(规范),用于保障客户端和服务器端通信的安全,以免通信时传输的信息被窃取或者修改. 怎样保障数据传输安全? ...

随机推荐

  1. 链接后加"/"与不加"/"的区别

    1.http://www.abc.com/abc2.http://www.abc.com/abc/ 当Web服务器接收到对某个末尾不含斜杠的url请求时,例如“http://www.abc.com/a ...

  2. Java开发搜索引擎爬虫

    package com.peidon.html; import java.io.BufferedReader; import java.io.File; import java.io.FileOutp ...

  3. 使用engine关键字指定该表使用哪个engine

    建表及插入数据语句:mysql> create table salary(userid int,salary decimal(9,2));Query OK, 0 rows affected (0 ...

  4. 【转】jquery iframe取得元素与自适应高度

    今天没事来总结一下iframe在jquery中怎么操作的,下面我来给各位介绍jquery 获取iframe子/父页面的元素及iframe在jquery高度自适应实现方法,各位朋友可参考. jquery ...

  5. 代理模式 & Java原生动态代理技术 & CGLib动态代理技术

    第一部分.代理模式  代理模式是常用的java设计模式,他的特征是代理类与委托类有同样的接口,代理类主要负责为委托类预处理消息.过滤消息.把消息转发给委托类,以及事后处理消息等.代理类与委托类之间通常 ...

  6. IOS第16天(2,Quartz2D下载进度条)

    *************自定义下载的view的方法 #import "HMProgressView.h" @interface HMProgressView() @propert ...

  7. iTop各数据表联系图(持续更新中)

  8. Linux ACL管理详解

    转自: http://linuxguest.blog.51cto.com/195664/124107 1. 为什么要使用ACL先让我们来简单地复习一下Linux的file permission.在li ...

  9. a标签实用方法详解

    a:link { color: black } /* 未访问时的状态 */ a:visited { color: blue } /* 已访问过的状态 */ a:hover { color: red } ...

  10. python 安装 twisted 库

    pip 安装twisted库需要先安装依赖包,不然报"error: command 'gcc' failed with exit status 1" # yum install g ...