分类 知识百科 下的文章

App Transport Security(ATS)是苹果在iOS 9及更高版本中引入的一项安全特性,旨在强制应用通过HTTPS(而不是HTTP)连接网络服务,以确保数据传输的安全。以下是ATS的一些关键点:

  1. 默认启用:在iOS 9及以上版本中,默认启用ATS,要求应用的所有网络请求都必须通过HTTPS进行。
  2. 安全要求:ATS要求应用的HTTPS连接必须满足以下条件:

    • 必须使用TLS 1.2版本的加密协议。
    • 必须使用AES-128或AES-256对称加密算法。
    • 必须支持正向保密(Forward Secrecy),使用ECDSA密钥交换。
    • 服务端的叶证书签名密钥必须符合特定要求。
  3. 自定义配置:如果需要,开发者可以在应用的Info.plist文件中自定义ATS配置,例如允许特定的不安全连接或为特定域名设置例外。
  4. 影响:从2017年1月1日起,苹果要求所有新上线或更新的应用都必须支持ATS安全标准。
  5. 适配ATS:如果应用需要访问非ATS安全标准的服务,可以在Info.plist中添加例外,但在审核时需要提供合理的理由。
  6. 性能和安全性:ATS通过减少连接次数和强制使用加密连接,可以提高应用的性能并增强安全性。
  7. 证书透明度:ATS还支持Certificate Transparency,要求服务器证书必须有有效的签名证书透明度时间戳。

确保服务器满足ATS最低要求
服务器必须使用受信任的CA签发的证书,主要包括:

具有完整的数字签名,表明证书未被篡改。
证书没有过期。
证书域名与访问域名匹配。
该​​证书必须由证书颁发机构 (CA) 颁发。如iOS 中可用的受信任根证书列表中所示。
ATS 需要的安全检查:

服务器证书必须使用至少 2048 位的 (RSA) 密钥或至少 256 位的椭圆曲线加密 (ECC) 密钥进行签名。
证书必须使用具有至少 256 位(即 SHA-256 或更大)的摘要长度(有时称为指纹)的安全散列算法 2 (SHA-2 )。
连接必须使用传输层安全 (TLS) 协议版本 1.2 或更高版本。
必须使用 AES-128 或 AES-256 对称密码交换数据。
链路必须通过椭圆曲线 Diffie-Hellman Ephemeral (ECDHE) 密钥交换支持完美前向保密 (PFS)。

ECC SSL证书,即椭圆曲线密码学(Elliptic Curve Cryptography)SSL证书,是一种基于椭圆曲线密码学的数字证书。以下是ECC SSL证书的优点和缺点:

优点:

  1. 更小的密钥大小:ECC证书的一个显著优势是,与RSA证书相比,它能够以更小的密钥提供强大的安全性。例如,256位的ECC密钥提供的安全性与3072位的RSA密钥相当。
  2. 更好的性能:由于密钥更小,计算速度更快,这为移动设备和低功耗系统带来更好的网络性能和更快的安全连接。
  3. 更高的安全性:ECC被认为更安全,因为它所基于的离散对数问题比RSA使用的因式分解整数问题更复杂,更难以被攻击。
  4. 降低资源消耗:ECC SSL证书占用的物理空间小,带宽消耗低,改进了服务器到浏览器的性能。

缺点:

  1. 较高的复杂性:ECC实施起来更为复杂,需要仔细配置才能确保安全。配置错误的系统可能无法提供预期的保护级别。
  2. 较低的兼容性:尽管大多数现代操作系统和Web浏览器都支持ECC算法,但一些老旧的系统和Web托管控制面板可能不支持ECC算法。
  3. 专利问题:部分ECC算法已申请专利,这最初减缓了其采用速度。不过,许多关键专利现已过期。
  4. 量子计算威胁:与其他公钥密码系统一样,ECC也容易受到大规模量子计算机的攻击(尽管这种攻击程度不如RSA)。
  5. 有限采用:尽管ECC有诸多优点,但在某些领域并未像RSA那样得到广泛采用,这可能导致兼容性问题。

ECC SSL证书是一种使用椭圆曲线加密技术(Elliptic Curve Cryptography, ECC)的数字证书,它在互联网上提供安全通信。以下是ECC SSL证书的一些关键特点和定义:

  1. 椭圆曲线加密技术:ECC是一种基于有限域上椭圆曲线数学结构的公钥加密法。与传统的RSA算法不同,ECC利用椭圆曲线的特性来创建安全的加密密钥。
  2. 较小的密钥大小:ECC的一个显著优势是,与RSA证书相比,它能以较小的密钥大小提供强大的安全性。例如,256位ECC密钥的安全性与3072位RSA密钥相当。
  3. 性能:由于密钥更小,ECC提供了更快的计算速度,从而为移动设备和低功耗系统带来更好的网络性能和更快的安全连接。
  4. 安全性:ECC被认为更安全,因为它所基于的离散对数问题比RSA使用的大整数因式分解问题更复杂。
  5. 工作原理:ECC证书的工作原理与传统SSL证书类似,但使用的是椭圆曲线加密算法,而不是RSA算法。它们在客户端和网络服务器之间建立安全连接,确保数据传输的加密和完整性。
  6. 兼容性和复杂性:ECC的实施更为复杂,需要仔细配置以确保安全。并非所有的系统和应用程序都支持ECC,但随着越来越多的平台采用ECC,兼容性问题逐渐减少。

ECC SSL 证书与 RSA SSL 证书
ECC SSL 证书还是 RSA SSL 证书?应该选择哪一个呢? 这两种算法都是完全安全的,并且它们被全球数百万的网络服务器使用,只是RSA兼容老旧设备。

但是,两者之间有一个关键区别。ECC SSL 证书通过应用长度更短的密钥提供与 RSA 相同的加密强度。举个例子,256 位 ECC 为您提供与 3072 位密钥相同的加密强度(比目前使用的 2048 位密钥长 50%)。因此,ECC SSL 证书需要较少的计算能力,最终体现在加密速度上。它提高了网络性能,并且可以在大容量网站的速度方面产生重大影响。

HTTP(超文本传输协议)和HTTPS(安全超文本传输协议)是两种用于在互联网上传输数据的协议,它们之间的主要区别在于安全性和加密。以下是HTTP和HTTPS之间的一些关键区别:

  1. 安全性

    • HTTP:是未加密的协议,数据在传输过程中以明文形式发送,容易受到窃听和中间人攻击。
    • HTTPS:在HTTP的基础上增加了SSL/TLS协议,提供了数据加密、完整性校验和身份认证,保护数据传输的安全。
  2. 端口

    • HTTP:默认使用80端口。
    • HTTPS:默认使用443端口。
  3. 证书

    • HTTP:不需要证书。
    • HTTPS:需要SSL/TLS证书,这些证书由受信任的证书颁发机构(CA)签发。
  4. 浏览器显示

    • HTTP:在浏览器地址栏中显示普通的“http://”。
    • HTTPS:在浏览器地址栏中显示“https://”,并且通常有一个锁形图标,表示连接是安全的。
  5. 搜索引擎优化(SEO)

    • HTTP:Google等搜索引擎可能会降低没有使用HTTPS的网站的排名。
    • HTTPS:使用HTTPS的网站可能会获得更好的搜索引擎排名,因为搜索引擎倾向于优先展示更安全的网站。
  6. 性能

    • HTTP:性能略优于HTTPS,因为不需要加密和解密数据。
    • HTTPS:由于加密和解密的开销,性能可能略低于HTTP,但这种差异对于大多数应用来说是可以忽略不计的。
  7. 成本

    • HTTP:没有额外成本。
    • HTTPS:可能需要购买SSL/TLS证书,尤其是对于付费证书,这会带来一定的成本。
  8. 信任和信誉

    • HTTP:由于数据传输不安全,可能会降低用户对网站的信任。
    • HTTPS:增强了用户对网站的信任,因为数据传输是加密的,用户信息更安全。

  1. 密钥空间计算

    • 对于对称加密,密钥空间是可能的密钥数量。对于一个n位的密钥,可能的密钥数量是(2^n)。
    • 对于128位密钥,密钥空间是(2^{128})。
    • 对于256位密钥,密钥空间是(2^{256})。
  2. 密钥空间比较

    • (2^{256})远大于(2^{128})。具体来说,(2^{256})是(2^{128})的(2^{128})倍。
    • 这意味着256位密钥的密钥空间比128位密钥的密钥空间大得多,因此更难找到正确的密钥。
  3. 破解难度

    • 破解加密通常涉及尝试所有可能的密钥,直到找到正确的一个。这被称为暴力破解攻击。
    • 由于256位密钥的密钥空间比128位密钥的密钥空间大得多,因此暴力破解256位加密的计算成本要高得多。
  4. 计算能力需求

    • 随着计算技术的进步,暴力破解加密的计算能力也在增加。
    • 然而,即使考虑到计算能力的提升,破解256位加密所需的时间仍然远远超出了当前技术的能力范围。
  5. 实际安全性

    • 128位加密在今天仍然被认为是安全的,但随着计算能力的提高,它可能会变得更加脆弱。
    • 256位加密目前被认为非常安全,并且预计在未来几十年内仍将保持安全。
  6. 结论

    • 256位加密比128位加密提供更高的安全性,因为它有更大的密钥空间,使得暴力破解攻击在实际中变得不可行。

因此,256位加密在安全性方面明显优于128位加密。最终答案是: