解决https页面加载http资源报错

为什么会报错?

在这里插入图片描述

HTTPS页面加载HTTP资源会报错的原因是出于安全性考虑。

HTTPS(HyperText Transfer Protocol Secure)是一种通过使用SSL/TLS加密通信来保护数据传输的协议,它确保了客户端和服务器之间的安全连接。

当HTTPS页面尝试加载非加密的HTTP资源时,存在以下问题:

  1. 混合内容警告:浏览器会发出警告,提示用户当前页面包含不安全的非加密内容。这些警告可能降低用户对网站的信任度,并增加恶意攻击或数据泄露等风险。

  2. 被阻止加载:现代浏览器默认情况下不允许从HTTPS页面中加载非加密的HTTP资源。这是为了提高用户隐私和安全性而采取的措施。

  3. 未受到TLS保护:通过HTTP请求发送或接收敏感信息(例如登录凭据、个人身份证明等)时,该信息在传输过程中将没有经过SSL/TLS加密保护,并容易被黑客截获或篡改。

http和https的区别

在这里插入图片描述

HTTP(Hypertext Transfer Protocol)和HTTPS(HTTP Secure)是用于在客户端和服务器之间传输数据的协议。

主要区别如下

  1. 安全性:HTTPS 使用 SSL/TLS 加密来保护数据传输过程中的隐私和完整性,而 HTTP 不提供任何加密机制,因此数据可以以明文形式进行传输。这意味着通过 HTTPS 发送的数据更加安全,更不容易被窃听或篡改。

  2. 网络通信方式:HTTP 使用 TCP/IP 作为底层网络通信协议,在默认情况下使用80端口;而 HTTPS 在 HTTP 的基础上增加了 SSL/TLS 加密层,并使用443端口进行安全连接。

  3. 证书验证:HTTPS 需要使用数字证书对网站身份进行验证,确保与用户交互的是合法可信赖的服务。这样有助于防止中间人攻击、DNS劫持等恶意行为。而 HTTP 不需要证书验证,存在可能被伪装或篡改。

  4. SEO 影响:搜索引擎通常会优先考虑采用 HTTPS 协议的网站,并将其排名提前一些。所以如果您关注搜索引擎优化(SEO),则应该考虑启用 HTTPS。

遵守原则

为了确保整个网页在传输过程中都得到适当地保护,建议遵循以下原则:

  • 使用链接到支持HTTPS连接方式提供服务。
  • 在不可避免使用HTTP资源的情况下,考虑使用代理服务器或其他安全手段来处理请求。

解决方案

需根据是否可访问https资源分两类方案

  1. 报错资源支持https请求访问
  2. 报错资源不支持https请求访问

报错资源支持https请求访问

将所有资源链接更新为使用HTTPS协议。
通过手动替换URL中的http://https://,确保所有资源都以安全的方式加载。

报错资源不支持https请求访问

以上提到的原则中第二条,即可以使用如Nginx解决问题。

在这里插入图片描述

什么是Nginx

Nginx(发音为"engine-x")是一个高性能的开源反向代理服务器和 Web 服务器。它由俄罗斯的软件工程师Igor Sysoev创建,并于2004年首次发布。

Nginx 最初设计用于解决 C10k(每秒处理 10,000 个并发连接)问题,因此具有出色的性能和可扩展性。与传统 Web服务器相比,如 Apache,Nginx 使用异步、非阻塞事件驱动模型来处理并发请求,从而在高负载情况下更加高效地处理大量请求。

除了作为反向代理和 Web 服务器之外,Nginx 还可以用作负载均衡器、缓存服务器、HTTP/HTTPS协议转换器等。它支持多种操作系统,并且有一个强大且灵活的配置语言来定制其行为。

配置Nginx转发

预设问题:http://abc.test.com/ai/1.jpg是一个图片资源,在https环境下访问其路径时会产生报错,并且不支持https访问。

可以按照以下步骤进行配置

  1. 打开 Nginx 配置文件,通常位于 /etc/nginx/nginx.conf/etc/nginx/conf.d/default.conf

  2. http 块中添加一个新的 location 块来处理以 /ai 为前缀的请求。示例如下:

http {# 其他相关设置...server {listen 80;server_name example.com;  # 替换成您的域名location /ai {proxy_pass http://ai.test.com;   # 将请求代理到指定的后端http服务器proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;# 其他相关设置...}# 其他虚拟主机或服务配置...}
}

在上述示例中,当访问以 /ai 开头的 URL(例如:https://abc.test.com/ai/1.jpg)时,Nginx 将会将这些请求通过代理传递给 http://ai.test.com.

  1. 检查 Nginx 配置是否正确: sudo nginx -t

  2. 重新加载或重启 Nginx 服务以使配置生效: sudo service nginx reload 或者 sudo systemctl reload nginx

完成上述配置,Nginx 将会将所有带有前缀为 /ai的URL请求转发到 http://ai.test.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/55132.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

钉钉群消息推送

1. 添加钉钉群机器人 PC端登录(当前版本手机端无法进行推送关键词设置),群设置--> 机器人 --> webhook进行安全设置复制webhook对应的url 2. 群消息推送 钉钉群消息支持纯文本和markdown类型 2.1 调用示例源码 import com.alibaba.…

Python小白学习:超级详细的字典介绍(字典的定义、存储、修改、遍历元素和嵌套)

目录 一、字典简介1.1 创建字典1.2 访问字典中的值1.3 添加键值对1.4 修改字典中的值实例 1.5 删除键值对1.6 由多个类似对象组成的字典1.7 使用get()访问值1.8 练习题 二、遍历字典2.1 遍历所有键值对实例 2.2 遍历字典中的所有键2.3 按照特定顺序遍历字典中的所有键2.4 遍历字…

简要记录下long long 乘 size_t类型是ull

以后注意用到 .size() 都给强制类型转换,力扣上 size_t 是unsigned long,跟longlong 想乘会变成 unsigned long long

Portraiture 4.0.3 for windows/Mac简体中文版(ps人像磨皮滤镜插件)

Imagenomic Portraiture系列插件作为PS磨皮美白必备插件,可以说是最强,今天它更新到了4.0.3版本。但是全网都没有汉化包,经过几个日夜汉化,终于汉化完成可能是全网首个Portraiture 4的汉化包,请大家体验,有…

ROS添加发布者和订阅者机制实现

一. ROS的节点和包 ✨Node: ROS的基本单位,实现某个功能的节点。比如实现超声波传感器就是一个节点,雷达传感器就可以是一个节点 ✨Package: 多个有联系的节点组成的单位,比如你要控制无人机姿态,可能需要…

在java中操作redis_Data

1.引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency> 2.配置Redis数据源 redis:host: ${sky.redis.host}port: ${sky.redis.port}password: ${sk…

GPIO实验

一、GPIO GPIO&#xff08;General-purpose input/output&#xff09;即通用型输入输出&#xff0c;GPIO可以控制连接在其之上的引脚实现信号的输入和输出 芯片的引脚与外部设备相连&#xff0c;从而实现与外部硬件设备的通讯、控制及信号采集等功能 LED实验步骤 最终目的&am…

无涯教程-Perl - do...while 语句函数

与 for 和 while 循环不同&#xff0c;它在循环的顶部测试循环条件&#xff0c;而 do ... while 循环在以下位置检查其条件:循环的底部。 do ... while 循环与while循环相似&#xff0c;除了保证do ... while循环至少执行一次。 do...while - 语法 do {statement(s); }while(…

Devops系统中jira平台迁移

需求:把aws中的devops系统迁移到华为云中,其中主要是jira系统中的数据迁移,主要方法为在华为云中建立一套 与aws相同的devops平台,再把数据库和文件系统中的数据迁移,最后进行测试。 主要涉及到的服务集群CCE、数据库mysql、弹性文件服务SFS、数据复制DRS、弹性负载均衡ELB。 迁…

pytorch学习——如何构建一个神经网络——以手写数字识别为例

目录 一.概念介绍 1.1神经网络核心组件 1.2神经网络结构示意图 1.3使用pytorch构建神经网络的主要工具 二、实现手写数字识别 2.1环境 2.2主要步骤 2.3神经网络结构 2.4准备数据 2.4.1导入模块 2.4.2定义一些超参数 2.4.3下载数据并对数据进行预处理 2.4.4可视化数…

华为QinQ技术的基本qinq和灵活qinq 2种配置案例

基本qinq配置&#xff1a; 运营商pe设备在收到同一个公司的ce发来的的包&#xff0c;统一打上同样的vlan &#xff0c;如上图&#xff0c;同一个家公司两边统一打上vlan 2&#xff0c;等于在原内网vlan 10或20过来的包再统一打上vlan 2的标签&#xff0c;这样传输就不会和其它…

mysql进阶-修改linux服务器中MySQL的字符集

1.背景 linux中mysql8默认的字符集是latin1&#xff0c;在插入中文时会报错&#xff0c;所以一般在配置好mysql时需要修改字符集为utf8【又叫utfmb3,一般开发够用&#xff0c;一个字符用3个字节表示】或者utfmb4【一个字符用4个字节表示&#xff0c;如果存储emoji表情&#xf…