关于HTTPS网页不能发起HTTP协议请求(OpenSSL 生成密钥方法)

本文主要是介绍关于HTTPS网页不能发起HTTP协议请求(OpenSSL 生成密钥方法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

场景描述

当 HTTPS 协议的网站中使用了 HTTP 协议的资源,Chrome 浏览器会发出警告

# Warning:
Mixed Content: The page at 'https://aaa' was loaded over HTTPS, but requested an insecure image 'http://bbb'. This content should also be served over HTTPS
# 混合内容:'https://aaa' 页面已通过 HTTPS 加载,但是请求了不安全的图片 'http://bbb'。此内容应该也通过 HTTPS 提供

注意:这是警告,页面还是会正常展示,但是 Ajax 请求地址必须是 HTTPS 协议。

模拟场景:搭建 HTTPS 站点

通过 http-server 或 serve 可以很容易开启一个 HTTP 协议的 web 站点,但要开启一个 HTTPS 协议的站点,还需要 SSL 密钥和证书。

OpenSSL 创建 SSL 密钥和证书工具

OpenSSL 工具可以创建 SSL 密钥和证书。

安装参考:windows安装OpenSSL

使用官方安装包,步骤很繁琐,所以推荐别人做的便捷版安装包:http://slproweb.com/products/Win32OpenSSL.html

在这里插入图片描述

我下载的是 Light 版本,只需一直下一步即可安装。

在这里插入图片描述

配置环境变量:

在这里插入图片描述

在这里插入图片描述

测试:

openssl version
# OpenSSL 1.1.1i  8 Dec 2020

生成证书和密钥

OpenSSL 官方手册

# 生成一个证书密钥对 key.pem 和 cert.pem,有效期约10年(准确地说是3650天)
openssl req -newkey rsa:2048 -new -nodes -x509 -days 3650 -keyout key.pem -out cert.pem
# 会询问地区、机构、名称信息,可随意写

执行完成后,会在命令行目录下生成两个文件:

  • 证书 cert.pem
  • 密钥 key.pem

开启 HTTPS 协议的 web 服务

创建两个web站点目录:

├─ http	# 用于开启一个http协议的站点(端口3000),存放静态资源
│   ├─ data.json		# 存储测试数据,用于 Ajax 请求
│   └─ image.jpg		# 静态资源文件
└─ https # 用于开启一个https协议的站点(端口5000),用于加载http协议的资源├─ cert.pem			# SSL 证书├─ index.html		# 站点首页└─ key.pem			# SSL 密钥

http/data.json

{"foo": "bar"
}

https/index.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><title>Document</title></head><body><h1>加载 HTTP 协议的图片</h1><img src="http://localhost:3000/image.jpg" width="300" /><script src="https://cdn.jsdelivr.net/npm/axios@0.21.1/dist/axios.min.js"></script><script>// 发起 HTTP 协议的 Ajax 请求axios({method: 'GET',url: 'http://localhost:3000/data.json',})</script></body>
</html>

本例使用 serve 开启服务。

# 全局安装 serve
# npm i -g serve# 开启 https 协议的 web 服务,监听5000端口,指定ssl证书和密钥
serve ./https -l 5000 --ssl-cert ./https/cert.pem --ssl-key ./https/key.pem# 新打开一个命令行窗口
# 开启 http 协议的 web 服务,监听3000端口
serve ./http -l 3000# 使用 Chrome 浏览器访问 https://localhost:5000

在这里插入图片描述

原因

当连接到一个提供无效证书的网站时,较旧的浏览器会使用一个对话框询问用户是否继续,而较新的浏览器会在整个窗口中显示警告。

Google Chrome、Internet Explorer、Firefox等浏览器在网站含有由加密(HTTPS)和未加密(HTTP)内容组成的混合内容时,会发出警告。

所以这个报错和警告,是浏览器为了安全性对于 混合内容 做出的处理行为。

混合内容

一个含有 HTTP 明文内容的 HTTPS 页面 称为 混合内容(mixed content)。

反之,在 HTTP 页面包含 HTTPS 资源则没有问题。

混合内容的类型及风险

混合内容有两种类型:被动/显示型混合内容(mixed passive/display content)主动型混合内容(mixed active content)

两者的区别在于内容遭中间人攻击篡改后,其最坏情况下的威胁程度。

如果是被动型混合内容,威胁程度低(可能有错误内容、或者用户的 cookie 操作窃取)。

如果是主动型混合内容,威胁就可能会变成网络钓鱼、敏感资料泄漏、被重定向到恶意网站等等。

  • 被动型混合内容
    • 指在 HTTPS 页面中,但无法改变其他部分的 HTTP 内容。
    • 例如:
      • <img><audio><video>src属性)
      • <object>(如果 <object>发起 HTTP 请求)
  • 主动型混合内容
    • 指有权访问HTTPS 页面的 Document 对象的内容。
    • 这种内容可以改变 HTTPS 页面行为、窃取用户敏感信息、拦截 HTTP 协议的请求、篡改或恶意植入JS代码等。
    • 例如:
      • <script>(src 属性)
      • <link>href属性)
      • <iframe>(src 属性)
      • XMLHttpRequest (Ajax 请求)

浏览器策略

基于混合内容的风险,浏览器会在网站含有混合内容时,会在控制台显示警告或错误提示,并阻止主动型混合内容。

Chrome 81 后,被动型混合内容地址将自动由 http:// 升级为 https://,如果无法通过 https:// 加载,则Chrome 会阻止它们。

更多详细参考

  • 混合内容 - MDN
  • 混合内容 & https 升级攻略
  • What is mixed content?
  • Chrome 81 正式发布 !消灭混合内容最后一步~
  • HTTPS - wiki

这篇关于关于HTTPS网页不能发起HTTP协议请求(OpenSSL 生成密钥方法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097967

相关文章

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

Mybatis Plus Join使用方法示例详解

《MybatisPlusJoin使用方法示例详解》:本文主要介绍MybatisPlusJoin使用方法示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录1、pom文件2、yaml配置文件3、分页插件4、示例代码:5、测试代码6、和PageHelper结合6

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

C#之List集合去重复对象的实现方法

《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存