https服务简介

第1章 HTTPs安全访问

HTTP中的s代表的时secuer更安全的访问

访问页面有三点安全问题是需要考虑的

(1) 数据的机密性 数据在传输时明文传输的话被人截取就会知道传输的信息 造成数据的外露不安全

(2) 数据的完整性 数据被第三方截取后会 如果被篡改了 将会造成互联通讯双方所表达的意思不一致 , 因此对于不完整的数据信息 接收方应该进行判断 如果完整性验证错误,就拒绝接收相应信息数据

(3) 身份验证问题

网络传输数据时 有种情况是传输的双方是第一次建立连接,进行通讯 既然是第一次连接 如何确认网站身份就是关键 如果一开始连接的对象就是错误的 那么之后传输的信息也都不是预期想要的(可能是被改变的病毒信息)

HTTPS安全访问加密方式

(1) 数据机密性 利用对称加密算法进行加密 先将数据信息进行加密 在利用公钥和密钥保护加密算法信息 实现数据机密性

(2) 数据完整性 利用对称加密算法进行加密 先将数据生成特征码 在利用公钥私钥保护好特征码 利用特征码验证数据完整性 私钥存放在服务器上公钥进行分发

(3) 身份认证问题 利用非对称加密算法 用户访问时会得到网站的证书信息 通过向CA证书颁发机构进行验证 确定站点的合法性

第2章 实现HTTPs安全访问网站

虚拟环境创建

第一步: 创建私钥和公钥(证书)信息

在nginx目录下创建

创建私钥文件

cd /etc/nginx/

openssl genrsa -idea -out server.key 2048
genrsa         创建什么类型私钥
idea           需要给私钥文件设置密码
out            创建生成一个私钥文件
2048           生成密钥加密位数  一般为1024/2048 (2的倍数)

创建证书

openssl req -days 36500 -x509 -sha256 -nodes -newkey rsa:2048 -keyout server.key -out server.crt

req     --- 创建一个证书文件

days    --- 证书文件有效期(默认  天)

x509    --- 证书文件格式

sha256  --- 指定生成证书算法

nodes   --- 去除私钥的密码生成证书

keyout  --- 指定加载私钥文件

out     --- 生成的证书信息

交互信息过程

(1) 国家

(2) 地区

(3) 公司

(4) 组织

(5) 主机名

(6) 邮箱地址

第二步: 编写nginx服务配置文件 开启HTTPs功能 并加载私钥公钥

利用ssl模块进行开启 这里实体机和虚拟机差不多

配置例子

ssl_certificate ssl_key/server.crt; 加载指定目录下指定公钥

ssl_certificate_key ssl_key/server.key; 加载指定目录下指定私钥

利用这两条模块进行加载公钥和私钥

[root@web02 nginx]# cat /etc/nginx/conf.d/www.conf

访问请求进行HTTP访问跳转HTTPS功能配置

server {

 listen 80;

 server_name www.oldboy.com;

 rewrite ^/(.*)$ https://$host/$1 redirect;   进行匹配跳转  将匹配到的HTTP请求临时跳转成HTTPS

}

server {

 listen 443 ssl;                      指定监控HTTPS服务端口 443 ssl代表开启https服务

 server_name www.oldboy.com;

 root /html/www;

 index index.html;

 ssl_certificate     server.crt;       在server下编写加载的私钥公钥路径

 ssl_certificate_key server.key;

}

最后重启nginx服务 测试是否进行跳转

负载均衡实现HTTPs访问(静态)

两者方式能够实现访问负载均衡 进行跳转

方式一 全网服务器都配置证书和私钥信息

当用户进行访问时 lb负载服务器进行跳转 跳转成https 然后将https请求抛给后端web节点 后端需要配置监听443端口 并开启ssl (https服务)

负载均衡服务器配置实例

Nginx配置的负载均衡服务器 进行https跳转过程

upstream oldboy {         指定用户组  并指定抛送端口为443(https服务端口)

 server 10.0.0.7:443;

 server 10.0.0.8:443;

 server 10.0.0.9:443;

}                                                                     

server {

 listen 80;               指定监听接收http请求的端口

 server_name localhost;

 rewrite ^/(.*)$ https://$host/$1 redirect;  
                          指定将http请求跳转成https请求  并不修改URI信息

}

server {

 listen 443 ssl;                  监听端口为443 并把SSL(https)服务开启

 server_name localhost;           因为要做负载处理  所以这里随意填  保持模块格式

 ssl_certificate  server.crt;     指定要加载的公钥路径

 ssl_certificate_key server.key;  指定要加载的私钥路径

 location / {                     固定格式进行负载均衡

 proxy_pass https://oldboy;   
                                  指定向后端抛送的是https请求

 proxy_set_header Host $host;

 proxy_set_header X-Forwarded-For $remote_addr;

 }

}

第二步 配置web服务器上web服务配置文件

server {

 listen 443 ssl;                 指定监听443端口抛过来的https请求 ssl代表开启https服务

 server_name www.oldboy.com;

 root /html/www;

 index index.html;

 ssl_certificate  server.crt;    指定加载的公钥私钥地址信息

 ssl_certificate_key server.key;

}

方式二 负载均衡服务器配置https跳转 但是向后端抛送时发送的时http请求

负载均衡服务器配置过程

upstream oldboy {

 #server 10.0.0.7:443;

 server 10.0.0.8:80;

 #server 10.0.0.9:80;

}                                                                     

server {

 listen 80;

 server_name localhost;

 rewrite ^/(.*)$ https://$host/$1 redirect;

}

server {

 listen 443 ssl;

 server_name localhost;

 ssl_certificate  server.crt;

 ssl_certificate_key server.key;

 location / {

 proxy_pass http://oldboy;    
                     指定向后端抛送时  抛送http请求

 proxy_set_header Host $host;

 proxy_set_header X-Forwarded-For $remote_addr;

 }

}

第二步 配置web服务器上web服务配置文件

server {               基础配置即可  接收http请求处理后返回回去

 listen 80;

 server_name www.oldboy.com www.jd.com;

 root /html/www;

 index index.html;

}

重启服务后进行测试 查看是否能够访问

负载均衡实现https访问动态页面

实现方法和静态转换https服务差不多

废话不多说 直接上代码 还是主要的就那几个

第一个历程: 修改配置文件信息

修改负载均衡配置文件: 基本和原来的没啥区别

upstream oldboy {

server 10.0.0.8:443;

 }

server {

 listen 80;

 server_name localhost;

 rewrite ^/(.*)$ https://$host/$1 redirect;

}

server {

 listen 443 ssl;

 server_name localhost;

 ssl_certificate server.crt;

 ssl_certificate_key server.key;

 location / {

 proxy_pass  https://oldboy; 
                        注意: 向后端抛送的是 https请求

 proxy_set_header Host $host;

 proxy_set_header X-Forwarded-For $remote_addr;

 }

 }

web服务器配置过程

server {

 listen 443 ssl;                  指定监控https服务的443端口 ssl开启https服务

 server_name blog.oldboy.com;     指定域名

 ssl_certificate server.crt;      在server下指定证书和密钥地址

 ssl_certificate_key server.key;

 location / {

 root /html/blog;

 index index.php index.html;

 }

 location ~ \.php$ {

 root /html/blog;

 fastcgi_pass 127.0.0.1:9000;

 fastcgi_index index.php;

 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

fastcgi_param HTTPS on;    指定开启https服务  在动态网页传参中设置

 include fastcgi_params;

 }

}

第二个历程: 修改wordpress后台信息

修改地址为 https://blog.oldboy.com

第三个历程: 重启nginx程序

第3章 phpcmsV9数据库修改https

数据库配置https跳转

(1) 默认数据库指向网站信息存放位置

mysql> select domain from phpcmsv9.v9_site;

+-------------------------+

| domain |

+-------------------------+

| http://www.oldboy.com/ |

+-------------------------+

1 row in set (0.00 sec)

(2) 数据库中修改指向网站信息为https使用命令

mysql> update phpcmsv9.v9_site set domain = 'https://www.oldboy.com/';

修改数据库指向网站信息

第4章 wordpress做https跳转

https跳转配置

在后台修改URL为https访问 再把nginx配置文件修改

image.png

可在数据库内输入命令查看是否修改成功

mysql> select * from wp_options where option_id="1"; 查看表内的第一行内容

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,529评论 5 475
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,015评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,409评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,385评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,387评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,466评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,880评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,528评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,727评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,528评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,602评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,302评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,873评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,890评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,132评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,777评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,310评论 2 342

推荐阅读更多精彩内容