详解 HTTPS 概念

Posted Linux无限探索

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了详解 HTTPS 概念相关的知识,希望对你有一定的参考价值。

我们都知道HTTPS能够加密信息,以免敏感信息被第三方获取。所以很多银行网站或电子邮箱等等安全级别较高的服务都会采用HTTPS协议。
HTTPS简介

HTTPS其实是有两部分组成:HTTP SSL / TLS,也就是在HTTP上又加了一层处理加密信息的模块。服务端和客户端的信息传输都会通过TLS进行加密,所以传输的数据都是加密后的数据。具体是如何进行加密,解密,验证的,且看下图。

1. 客户端发起HTTPS请求

这个没什么好说的,就是用户在浏览器里输入一个https网址,然后连接到server的443端口。

2. 服务端的配置

采用HTTPS协议的服务器必须要有一套数字证书,可以自己制作,也可以向组织申请。区别就是自己颁发的证书需要客户端验证通过,才可以继续访问,而使用受信任的公司申请的证书则不会弹出提示页面(startssl就是个不错的选择,有1年的免费服务)。这套证书其实就是一对公钥和私钥。如果对公钥和私钥不太理解,可以想象成一把钥匙和一个锁头,只是全世界只有你一个人有这把钥匙,你可以把锁头给别人,别人可以用这个锁把重要的东西锁起来,然后发给你,因为只有你一个人有这把钥匙,所以只有你才能看到被这把锁锁起来的东西。

3. 传送证书

这个证书其实就是公钥,只是包含了很多信息,如证书的颁发机构,过期时间等等。

4. 客户端解析证书

这部分工作是有客户端的TLS来完成的,首先会验证公钥是否有效,比如颁发机构,过期时间等等,如果发现异常,则会弹出一个警告框,提示证书存在问题。如果证书没有问题,那么就生成一个随即值。然后用证书对该随机值进行加密。就好像上面说的,把随机值用锁头锁起来,这样除非有钥匙,不然看不到被锁住的内容。

5. 传送加密信息

这部分传送的是用证书加密后的随机值,目的就是让服务端得到这个随机值,以后客户端和服务端的通信就可以通过这个随机值来进行加密解密了。

6. 服务段解密信息

服务端用私钥解密后,得到了客户端传过来的随机值(私钥),然后把内容通过该值进行对称加密。所谓对称加密就是,将信息和私钥通过某种算法混合在一起,这样除非知道私钥,不然无法获取内容,而正好客户端和服务端都知道这个私钥,所以只要加密算法够彪悍,私钥够复杂,数据就够安全。

7. 传输加密后的信息

这部分信息是服务段用私钥加密后的信息,可以在客户端被还原

8. 客户端解密信息

客户端用之前生成的私钥解密服务段传过来的信息,于是获取了解密后的内容。整个过程第三方即使监听到了数据,也束手无策。

原文来自:http://www.ttlsa.com/web/https-explain/

本文地址: https://www.linuxprobe.com/https-explain.html编辑:杨鹏飞,审核员:逄增宝

本文原创地址:https://www.linuxprobe.com/https-explain.html

iptables详解

 一.  iptables 概念详解

参考:    iptables概念

   https://www.cnblogs.com/metoy/p/4320813.html

   https://blog.csdn.net/fuzhongfaya/article/details/82022181

1. 组成

  linux的防火墙由netfilter和iptables组成。用户空间的iptables制定防火墙规则内核空间的netfilter实现防火墙功能

    netfilter(内核空间)位于Linux内核中的包过滤防火墙功能体系,称为Linux防火墙的“内核态”。

    iptables(用户空间)位于/sbin/iptables,是用来管理防火墙的命令的工具,为防火墙体系提供过滤规则/策略,决定如何过滤或处理到达防火墙主机的数据包,称为Linux防火墙的“用户态”。

 

2. iptables传输数据包的过程

① 当一个用户数据包进入网卡时,它首先进入PREROUTING链,内核根据数据包目的IP判断是否需要转送出去。 
② 如果数据包就是进入本机的,它就会沿着图向上移动,到达INPUT链。数据包到了INPUT链后,就可以进入用户空间实现对网站的访问。本机上运行的程序可以发送数据包,这些数据包会经过OUTPUT链,然后到达POSTROUTING链输出。 
③ 如果数据包是要转发出去的,且内核允许转发,数据包就会如图所示向右移动,经过FORWARD链,然后到达POSTROUTING链输出。

技术分享图片

 

所以根据上图,我们就能想象出某些常用场景中报文的流向:

到本机某进程的报文:  PREROUTING---->INPUT

由本机转发的报文: PREROUTING--->FORWARD----->POSTROUTING

由本机某进程发出的报文(通常为响应报文):  OUTPUT------->POSTROUTING

 

3.  表、链、规则 

 用户空间的iptables制定相应的规则策略控制内核空间的netfilter处理相应的数据访问控制。

     iptables有四表五链(其实有五表,是后来加进来的),四表分别是下图的的raw,mangle,nat,filter表五链分别是PREROUTING,INPUT,OUTPUT,FORWARD,POSTROUTING链。表有什么用?链又有什么用呢?其实表决定了数据报文处理的方式,而链则决定了数据报文的流经哪些位置。

    你可以从图中看出规则表的优先级:raw-->mangle-->nat-->filter。

 

表:

我们把具有相同功能的规则的集合叫做"表".所以不同功能的规则可以放在不同的表中管理.表决定了数据报文处理的方式.

 

链:

 链(chains)是数据包传播的路径,每一条链其实就是众多规则中的一个检查清单,每一条链中可以有一 条或数条规则。当一个数据包到达一个链时,iptables就会从链中第一条规则开始检查,看该数据包是否满足规则所定义的条件。如果满足,系统就会根据 该条规则所定义的方法处理该数据包;否则iptables将继续检查下一条规则,如果该数据包不符合链中任一条规则,iptables就会根据该链预先定 义的默认策略来处理数据包。

 

表与链的关系:

 

规则表:

1.filter  表中的规则可以被哪些链使用:  INPUT、FORWARD、OUTPUT
作用:过滤数据包  内核模块:iptables_filter.
2.Nat表  表中的规则可以被哪些链使用:PREROUTING、POSTROUTING、OUTPUT
作用:用于网络地址转换(IP、端口) 内核模块:iptable_nat
3.Mangle表  表中的规则可以被哪些链使用:PREROUTING、POSTROUTING、INPUT、OUTPUT、FORWARD
作用:修改数据包的服务类型、TTL、并且可以配置路由实现QOS内核模块:iptable_mangle(别看这个表这么麻烦,咱们设置策略时几乎都不会用到它)
4.Raw表  表中的规则可以被哪些链使用:OUTPUT、PREROUTING
作用:决定数据包是否被状态跟踪机制处理  内核模块:iptable_raw
(这个是REHL4没有的,不过不用怕,用的不多)

 

规则链:

技术分享图片

1.INPUT——进来的数据包应用此规则链中的策略
2.OUTPUT——外出的数据包应用此规则链中的策略
3.FORWARD——转发数据包时应用此规则链中的策略
4.PREROUTING——对数据包作路由选择前应用此链中的规则
(记住!所有的数据包进来的时侯都先由这个链处理)
5.POSTROUTING——对数据包作路由选择后应用此链中的规则
(所有的数据包出来的时侯都先由这个链处理)

 

 

 

技术分享图片

 

    四表的介绍如图(ps:由于现在有五表了,所以我把另一个表也加了进来)。

技术分享图片

 

 五链的介绍如图。

技术分享图片

 

    制作防火墙规则通常有两种基本策略。一是黑名单策略;二是白名单策略。

    黑名单策略指没有被拒绝的流量都可以通过,这种策略下管理员必须针对每一种新出现的攻击,制定新的规则,因此不推荐。

    白名单策略指没有被允许的流量都要拒绝,这种策略比较保守,根据需要,逐渐开放,目前一般都采用白名单策略,推荐。

 

4.  数据经过防火墙流程

 

牢记下图配置iptables.

技术分享图片

二. iptables命令 

1. 制定iptables表规则思路

    (1)选择一张表(此表决定了数据报文处理的方式)

    (2)选择一条链(此链决定了数据报文的流经哪些位置)

    (3)选择合适的条件(此条件决定了对数据报文做何种条件匹配)

    (4)选择处理数据报文的动作,制定相应的防火墙规则。

 

2、基本语法结构

   结构:

    iptables [ -t 表名 ] 管理选项 [ 链名 ] [ 条件匹配 ] [ -j 目标动作或跳转 ]

   几个注意事项:

    不指定表名时,默认表示filter表,不指定链名时,默认表示该表内所有链,除非设置规则链的缺省策略,否则需要指定匹配条件。

 技术分享图片

技术分享图片

 

 

3. 语法结构解析

3.1 管理选项

链管理

-N, --new-chain chain:新建一个自定义的规则链; -X, --delete-chain [chain]:删除用户自定义的引用计数为0的空链; -F, --flush [chain]:清空指定的规则链上的规则; -E, --rename-chain old-chain new-chain:重命名链; -Z, --zero [chain [rulenum]]:置零计数器; 注意:每个规则都有两个计数器 packets:被本规则所匹配到的所有报文的个数; bytes:被本规则所匹配到的所有报文的大小之和; -P, --policy chain target 制定链表的策略(ACCEPT|DROP|REJECT)

规则管理

 -A, --append chain rule-specification:追加新规则于指定链的尾部; 
    -I, --insert chain [rulenum] rule-specification:插入新规则于指定链的指定位置,默认为首部;
    -R, --replace chain rulenum rule-specification:替换指定的规则为新的规则;
    -D, --delete chain rulenum:根据规则编号删除规则;
    -D, --delete chain rule-specification:根据规则本身删除规则;

规则显示

 -L, --list [chain]:列出规则;
     -v, --verbose:详细信息; 
     -vv 更详细的信息
     -n, --numeric:数字格式显示主机地址和端口号;
     -x, --exact:显示计数器的精确值,而非圆整后的数据;
     --line-numbers:列出规则时,显示其在链上的相应的编号;
     -S, --list-rules [chain]:显示指定链的所有规则;

 

3.2  条件匹配

 条件匹配分为基本匹配和扩展匹配,扩展匹配又分为显示匹配和隐式匹配

    基本匹配的特点是:无需加载扩展模块,匹配规则生效;扩展匹配的特点是:需要加载扩展模块,匹配规则方可生效。

    隐式匹配的特点:使用-p选项指明协议时,无需再同时使用-m选项指明扩展模块以及不需要手动加载扩展模块;  

    显示匹配的特点:必须使用-m选项指明要调用的扩展模块的扩展机制以及需要手动加载扩展模块。

 

基本匹配的使用选项及功能

-p 指定规则协议,tcp udp icmp all
-s 指定数据包的源地址,ip hostname
-d 指定目的地址
-i 输入接口
-o 输出接口                                              
! 取反

 

隐式匹配的使用选项及功能    

-p tcp
  --sport 匹配报文源端口;可以给出多个端口,但只能是连续的端口范围 
  --dport 匹配报文目标端口;可以给出多个端口,但只能是连续的端口范围
  --tcp-flags mask comp 匹配报文中的tcp协议的标志位
-p udp
  --sport 匹配报文源端口;可以给出多个端口,但只能是连续的端口范围
  --dport 匹配报文目标端口;可以给出多个端口,但只能是连续的端口范围
--icmp-type
  0/0echo reply 允许其他主机ping
  8/0echo request 允许ping其他主机

 

显式匹配的使用选项及功能

显式匹配的选项特别多,所以使用思维导图的方式梳理一下。我们可以使用命令:man iptables-extensions查看具体用法。

 技术分享图片

1.multiport(多端口)

     开放多个端口。

技术分享图片

  1. 1

    2

    3

    例子:

            iptables -I INPUT -d 172.16.100.7 -p tcp -m multiport --dports 22,80 -j ACCEPT

            iptables -I OUTPUT -s 172.16.100.7 -p tcp -m multiport --sports 22,80 -j ACCEPT

    2.iprange(ip范围)

     以连续地址块的方式来指明多IP地址匹配条件。

  1. 1

    2

    3

    例子:

        iptables -A INPUT -d 172.16.100.7 -p tcp --dport 23 -m iprange --src-range 172.16.100.1-172.16.100.100 -j ACCEPT

        iptables -A OUTPUT -s 172.16.100.7 -p tcp --sport 23 -m iprange --dst-range 172.16.100.1-172.16.100.100 -j ACCEPT

    3.time(时间范围)

     指定时间范围。

  1. 1

    2

    3

     例子:

            iptables -A INPUT -d 172.16.100.7 -p tcp --dport 901 -m time --weekdays Mon,Tus,Wed,Thu,Fri --timestart 08:00:00 --time-stop 18:00:00 -j ACCEPT

            iptables -A OUTPUT -s 172.16.100.7 -p tcp --sport 901 -j ACCEPT

    4.string(字符串)

     对报文中的应用层数据做字符串模式匹配检测(通过算法实现)。

  1. 1

    2

    3

        --algo {bm|kmp}:字符匹配查找时使用算法

        --string "STRING": 要查找的字符串

        --hex-string “HEX-STRING”: 要查找的字符,先编码成16进制格式

    5.connlimit(连接限制)

     根据每个客户端IP作并发连接数量限制。

1

2

    --connlimit-upto n  连接数小于等于n时匹配

    --connlimit-above n 连接数大于n时匹配

    6.limit(速率限制)

     报文速率控制。  

    7.state(状态)

     追踪本机上的请求和响应之间的数据报文的状态。状态有五种:INVALID, ESTABLISHED, NEW, RELATED, UNTRACKED.

技术分享图片

  1.  法则:

  2.         1、对于进入的状态为ESTABLISHED都应该放行;

  3.         2、对于出去的状态为ESTABLISHED都应该放行;

  4.         3、严格检查进入的状态为NEW的连接;

  5.         4、所有状态为INVALIED都应该拒绝;  

 

3.3  处理动作

    处理动作有内置的处理动作和自定义的处理动作。自定义的处理动作用的比较少,因此只介绍内置的处理动作。

 

ACCEPT:允许数据包通过
 
DROP:直接丢弃数据包,不给出任何回应信息
 
REJECT:拒绝数据包通过,必要时会给数据发送端一个响应信息
 
LOG:在日志文件中记录日志信息,然后将数据包传递给下一条规则
 
QUEUE: 防火墙将数据包移交到用户空间
 
RETURN:防火墙停止执行当前链中的后续Rules,并返回到调用链 
 
REDIRECT:端口重定向  
 
MARK:做防火墙标记
 
DNAT:目标地址转换
 
SNAT:源地址转换   
                                                 
MASQUERADE:地址伪装

 

3.4 保存和载入规则

 CentOS6和CentOS7保存和载入的规则稍有差异。

  CentOS 7

1

2

3

4

    保存:iptables-save > /PATH/TO/SOME_RULE_FILE   

   重载:iptabls-restore < /PATH/FROM/SOME_RULE_FILE    

    -n, --noflush:不清除原有规则    

    -t, --test:仅分析生成规则集,但不提交

 CentOS 6

 

1

2

3

    保存规则:service iptables save   #保存规则于/etc/sysconfig/iptables文件,覆盖保存;   

   重载规则:service iptables restart #默认重载/etc/sysconfig/iptables文件中的规则   

   配置文件:/etc/sysconfig/iptables-config

 

三. iptables 实践应用

更多例子:  https://blog.csdn.net/u012904337/article/details/79507646

1.放行sshd服务

 

iptables -t filter -A INPUT -s 192.168.0.0/24 -d 192.168.0.1 -p tcp --dport 22 -j ACCEPT
 iptables -t filter -A OUTPUT -s 192.168.0.1  -p tcp --sport 22 -j ACCEPT

2.放行httpd/nginx服务

iptables -I OUTPUT -s 192.168.0.1 -p tcp --sport 80 -j ACCEPT
 iptables -I INPUT -d 192.168.0.1 -p tcp --dport 80 -j ACCEPT

3.放行本机端的流入流出

iptables -A  INPUT  -s 127.0.0.1 -d 127.0.0.1 -i lo -j ACCEPT
  iptables -A  OUTPUT  -s 127.0.0.1 -d 127.0.0.1 -o lo -j ACCEPT
  #不放行本机的流入与流出,访问本机的httpd服务,网页会出现Error establishing a database connection。

4.限制ping 192.168.0.1主机的数据包数,平均2/s个,最多不能超过3个

iptables -A INPUT -i ens33 -d 192.168.0.1 -p icmp --icmp-type 8 -m limit --limit 2/second --limit-burst 3 -j ACCEPT

如何配置iptables

a) 1. 删除现有规则
iptables -F
b) 2. 配置默认链策略
iptables -P INPUT DROP
iptables -P FORWARD DROP
iptables -P OUTPUT DROP
c) 3. 允许远程主机进行SSH连接
iptables -A INPUT -i eth0 -p tcp –dport 22 -m state –state NEW,ESTABLISHED -j ACCEPT
iptables -A OUTPUT -o eth0 -p tcp –sport 22 -m state –state ESTABLISHED -j ACCEPT
d) 4. 允许本地主机进行SSH连接
iptables -A OUTPUT -o eth0 -p tcp –dport 22 -m state –state NEW,ESTABLISHED -j ACCEPT
iptables -A INPUT -i eth0 -p tcp –sport 22 -m state –state ESTABLISHED -j ACCEPT
e) 5. 允许HTTP请求
iptables -A INPUT -i eth0 -p tcp –dport 80 -m state –state NEW,ESTABLISHED -j ACCEPT
iptables -A OUTPUT -o eth0 -p tcp –sport 80 -m state –state ESTABLISHED -j ACCEPT

iptables初始化脚本

#!/bin/bash
  
echo &quot;Setting firewall . . . . start&quot;
  
#--------RULESET INIT----------#
iptables -F
iptables -X
iptables -P INPUT DROP
iptables -P OUTPUT ACCEPT
iptables -P FORWARD ACCEPT
iptables -A INPUT -s 127.0.0.1 -d 127.0.0.1 -j ACCEPT
#------------------------------#
iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
iptables -A INPUT -i eth0 -p tcp ! --syn -j ACCEPT
iptables -A OUTPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
iptables -A FORWARD -m state --state ESTABLISHED,RELATED -j ACCEPT
#------------------------------#
#zabbix
iptables -A INPUT -p tcp --destination-port 10050 -j ACCEPT
iptables -A INPUT -p udp --destination-port 10051 -j ACCEPT
iptables -A OUTPUT -p tcp --destination-port 10050 -j ACCEPT
iptables -A OUTPUT -p udp --destination-port 10051 -j ACCEPT
#for web
iptables -A INPUT -p tcp --destination-port 21 -j ACCEPT
iptables -A INPUT -p tcp --destination-port 80 -j ACCEPT
iptables -A OUTPUT -p tcp --destination-port 80 -j ACCEPT
iptables -A OUTPUT -p tcp --destination-port 21 -j ACCEPT
#for mysql
iptables -A INPUT -p tcp --destination-port 3306 -j ACCEPT
iptables -A OUTPUT -p tcp --destination-port 3306 -j ACCEPT
#for mail
iptables -A INPUT -p tcp --destination-port 25 -j ACCEPT
iptables -A OUTPUT -p tcp --destination-port 25 -j ACCEPT
iptables -A OUTPUT -p tcp --destination-port 110 -j ACCEPT
#for ssh
iptables -A INPUT -p tcp -s any/0 --destination-port 22 -j ACCEPT
iptables -N icmp_allowed
iptables -A icmp_allowed -p ICMP --icmp-type 11 -j ACCEPT
iptables -A icmp_allowed -p ICMP --icmp-type 8 -j ACCEPT
iptables -A icmp_allowed -p ICMP -j DROP
iptables -A OUTPUT -p icmp -j ACCEPT
iptables -A INPUT -p icmp -j ACCEPT
iptables -A FORWARD -p tcp --tcp-flags SYN,ACK,FIN,RST RST -m limit --limit 1/s -j ACCEPT
iptables -A FORWARD -p icmp --icmp-type echo-request -m limit --limit 1/s -j ACCEPT
iptables -A FORWARD -p tcp --syn -m limit --limit 1/s -j ACCEPT
/etc/init.d/iptables save

 

以上是关于详解 HTTPS 概念的主要内容,如果未能解决你的问题,请参考以下文章

iptables详解

详解 vue 组件三大核心概念

002/区块链核心概念与原理详解(Mooc)

[云原生专题-29]:K8S - 核心概念 - 名字空间/命名空间概念详解与主要操作案例

详解虚拟化之KVM概念架构功能常用工具及部署

PHP回调函数及匿名函数概念与用法详解