nginx配置ssl证书实现http和https同时使用且实现80和443端口并存

19 篇文章 2 订阅
18 篇文章 3 订阅

问题背景


       首先一台服务器上同时搭建的有war、jar以及php等多个项目,要求其中个别项目实现https请求,但又保留原有http请求的有效性。

       解决思路,先实现https请求,再来区分具体实现的项目。

获取ssl证书


       ssl证书有分免费和收费版,根据自己需求自行百度。无论通过什么渠道获取,我们这里只需要两个文件(**.pem和**.key),这里的星星一般是你的域名。

       阿里云申请DigiCert 免费版 SSL,选择如下才会出现,隐藏的比较深,不容易找。

申请地址:https://common-buy.aliyun.com/?commodityCode=cas#/buy
在这里插入图片描述

nginx配置


nginx配置ssl证书

server {
        listen       80;
        listen       443 ssl;
        server_name augesion.top;
        charset UTF-8;
        ssl_certificate   cert/4277028.pem;#ssl证书,把ssl证书放cert目录下,cert在nginx的conf目录下
        ssl_certificate_key  cert/4277028.key;#ssl证书key
        ssl_session_timeout 5m;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_prefer_server_ciphers on; 
        #其余省略。。。
        }

       以上解决https请求的同时也实现80端口和443并存,那么如何实现只对个别项目进行https请求呢?

location /demo1 {
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto https;
            proxy_pass http://127.0.0.1:8080/demo1;
            proxy_redirect http:// https://;
        }

       在server 里添加以上设置即可实现,多个项目直接照葫芦画瓢就好。

跨域问题
       nginx中解决跨域问题简单例子,在server的location上加一下配置。

	add_header Access-Control-Allow-Origin *;
	add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
	add_header Access-Control-Allow-Headers '*';
	if ($request_method = 'OPTIONS') {
        return 204;
    }

实际效果

server {
        listen       80;
        listen       443 ssl;
        server_name augesion.top;
        charset UTF-8;
        ssl_certificate   cert/4277028.pem;#ssl证书,把ssl证书放cert目录下,cert在nginx的conf目录下
        ssl_certificate_key  cert/4277028.key;#ssl证书key
        ssl_session_timeout 5m;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_prefer_server_ciphers on; 

		location /demo1 {
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto https;
            proxy_pass http://127.0.0.1:8080/demo1;
            proxy_redirect http:// https://;
            add_header Access-Control-Allow-Origin *;
			add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
			add_header Access-Control-Allow-Headers '*';
			if ($request_method = 'OPTIONS') {
		        return 204;
		    }
        }        

        }

有一种极简的结尾,可能只是因为懒,就像大家向往这的极简生活、、、

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

玉念聿辉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值