设为首页 收藏本站
查看: 1994|回复: 3

[经验分享] Windows下Tomcat+nginx配置证书实现登录页https访问

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-1-7 08:41:35 | 显示全部楼层 |阅读模式
本帖最后由 gfrv 于 2014-1-7 08:45 编辑

    最近公司出于安全考虑,需要将登录页做成https访问,其他页面仍采用http访问,环境是Linux平台,web服务器采用Tomcat + Nginx。之前没接触过nginx,这两天网上查资料,试了好多,终于有点小成果,特此做一下记录。目前还存在一些问题,希望各位多多指教。下面说一下我的具体做法:

1.将nginx解压到C盘根目录,重命名文件夹为Nginx(版本:1.3.5)。

2.生成自签名证书(采用OpenSSL生成),生成工具下载:绿色版OpenSSL工具.rar自签名测试证书工具.rar

3.将生成的证书文件server.cer和server.key分别都拷贝到Tomcat和Nginx的conf目录下,双击生成的root.cer根证书,然后安装证书,将其安装到受信任的根证书颁发机构(如不安装,访问时浏览器会提示证书错误)。

4.配置Tomcat的server.xml文件和web工程的web.xml文件:

https配置:

1        <Connector port="8443" protocol="org.apache.coyote.http11.Http11AprProtocol"
2                SSLEnabled="true" maxThreads="150"
3                scheme="https" secure="true" disableUploadTimeout="true"
4                enableLookups="false" acceptCount="100" clientAuth="false"
5                SSLCertificateFile="C:/Program Files/Tomcat 6.0/conf/server.cer"
6                SSLCertificateKeyFile="C:/Program Files/Tomcat 6.0/conf/server.key"
7                SSLVerifyClient="none" sslProtocol="TLS" />
虚拟目录配置:

1        <Host name="localhost"  appBase="C:\nginx\html"
2                    unpackWARs="true" autoDeploy="true"
3                    xmlValidation="false" xmlNamespaceAware="false">
web.xml文件中加入如下配置:

01             <!-- 登录页采用https访问 -->
02        <security-constraint>
03            <web-resource-collection>
04                <web-resource-name>SSL</web-resource-name>
05                <url-pattern>/index/*</url-pattern>
06            </web-resource-collection>
07            <user-data-constraint>
08                <transport-guarantee>CONFIDENTIAL</transport-guarantee>
09            </user-data-constraint>
10        </security-constraint>
5.配置Nginx的nginx.conf文件:

01            server {
02                listen       80;
03                server_name  localhost;#域名,可以多个
04         
05                #charset koi8-r;
06         
07                #access_log  logs/host.access.log  main;
08                
09               #配置规则
10                 location / {
11                      if (!-f $request_filename){
12                        rewrite ^/pages/common/(.*)$ /error.jsp;
13                    }
14                    root   yddweb;
15                    #index  index.jsp;
16                      proxy_pass http://localhost:8080;
17                      proxy_set_header Host $host:80;
18                    proxy_set_header X-Real-IP $remote_addr;
19                    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
20                    proxy_set_header Via "nginx";
21               }
22         
23                 location ^~ /pages/$ {
24                    root   yddweb;
25                    #index  index.jsp;
26                      proxy_pass http://localhost:8080;
27                      proxy_set_header Host $host:80;
28                    proxy_set_header X-Real-IP $remote_addr;
29                    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
30                    proxy_set_header Via "nginx";
31                }
32         
33                #location ~ \.(gif|jpg|png|js|css)$ {
34                    #规则
35                #}
36            }
37         
38            # HTTPS server
39            #
40            server {
41                listen       443;
42                server_name  localhost:443;
43         
44                ssl                  on;
45                ssl_certificate      server.cer;#
46                ssl_certificate_key  server.key;
47         
48                ssl_session_timeout  5m;
49         
50                #ssl_protocols  SSLv2 SSLv3 TLSv1;
51                #ssl_ciphers  HIGH:!aNULL:!MD5;
52                #ssl_prefer_server_ciphers   on;
53         
54                #配置规则
55                location ^~ /index/.jsp$ {
56                    root   yddweb;
57                    index  login.jsp;
58                      proxy_pass https://localhost:8443;
59                      proxy_set_header Host $host:443;
60                    proxy_set_header X-Real-IP $remote_addr;
61                    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
62                    proxy_set_header Via "nginx";
63                }
64                location ~ ^/(WEB-INF)/ {
65                    deny all;
66                }
67            }
68        }
6.web工程的截图:

215042_Q5xf_658145.jpg

LoginServlet的代码:

1        HttpSession session = request.getSession(true);
2                String name = request.getParameter("name").trim();
3                session.setAttribute("curuser", name);
4                String url = "http://"+request.getServerName()+request.getContextPath()+"/pages/system/myinfo.jsp";     response.sendRedirect(url);
目前存在的问题(希望各位多多指教):

1.在本机访问https正常,其他机器访问浏览器提示证书错误。

2.location规则的配置,由于本人水平有限,对location规则的配置不是很了解,所以location目前不太会配置(配置要求:index目录下的页面采用https访问,其他页面全部采用http访问)。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-13447-1-1.html 上篇帖子: Nginx https免费SSL证书配置指南 下篇帖子: Ubuntu下配置Nginx HTTPS Windows 证书

尚未签到

发表于 2014-1-7 11:35:11 | 显示全部楼层
个性签名:幸福就是黎明前的第一缕阳光,处于黑夜和白天之间。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

尚未签到

发表于 2014-1-8 00:30:19 | 显示全部楼层
我正游走在无拘无束的自赏自省与自恋之间

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

发表于 2014-1-8 11:09:49 | 显示全部楼层
我把心烧成火焰让怕黑的你拥着温暖入眠

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表