热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

HTTPS的頁面發送不了HTTP要求?——關於夾雜內容

我們都曉得HTTPS的頁面是發送不了HTTP要求的,那末是什麼緣由致使HTTPS頁面不能發送HTTP要求呢?如果有發送的需求,怎樣才發送?近來恰好遇到了這個題目,而且搜了半天沒搜到

我們都曉得HTTPS的頁面是發送不了HTTP要求的,那末是什麼緣由致使HTTPS頁面不能發送HTTP要求呢?如果有發送的需求,怎樣才發送?近來恰好遇到了這個題目,而且搜了半天沒搜到靠譜的答案,所以有了本文。

1. 故事劈頭

我在《Jquery ajax, Axios, Fetch區分之我見》中提到過,Fetch作為一種不同於XHR的要求體式格局,展現了它更多API,以及相符ES範例的優越遠景;更不必說它能夠支撐POST跨域。恰好工作上有效post要領上報結果數據的要求,我小手一揮,不必背景兄弟們麻煩了,我能夠搞定,把結果上報換成了Fetch,美滋滋。

過了一段時間,背景跑過來講,如今還有些其他HTTP站點的數據上報。我試了一下,挪動端根本就沒有發出這個要求,這……

2. 為何HTTPS頁面發送不了HTTP要求

有些人說是跨域題目,真的是如許嗎?

同源戰略:1. 協定雷同 2. 域名雷同 3.端口雷同

只管HTTPS接見HTTP確切不相符同源戰略中的協定雷同,然則在當代瀏覽器里,縱然是域名雷同的要求,也是會出現以下報錯,而不是跨域報錯。

《HTTPS的頁面發送不了HTTP要求?——關於夾雜內容》

這也很好明白,畢竟夾雜內容的平安戰略是在瀏覽器端剖斷的,而是不是能跨域要看服務器返回的Response頭,要求都被瀏覽器block掉了,也就不存在是不是跨域的題目。

那什麼是夾雜內容?

夾雜內容:初始 HTML 內容經由過程平安的 HTTPS 銜接加載,但其他資本(比方,圖象、視頻、樣式表、劇本)則經由過程不平安的 HTTP 銜接加載[1]。由於頁面經由過程 HTTPS 加載的初始要求是平安的,然則又加載了不平安的HTTP內容,因而稱之為夾雜內容。

由於HTTPS的S自身就是Secure的意義,當代瀏覽器最初會針對此範例的內容顯現正告,以向用戶表明此頁面包含不平安的資本。然則縱然顯現正告,頁面也已加載,用戶的平安依然受到了要挾。所以沒過多久,Chrome和Firefox就直接阻斷掉了這類的要求。

這就是HTTPS頁面為何發送不了HTTP的緣由。

2. 打破體式格局

只管如今主流瀏覽器都已block掉了HTTPS頁面上的HTTP要求,然則我們照樣能夠經由過程被動夾雜內容來發送get要求。

被動夾雜內容:指的是不與頁面其餘部分舉行交互的內容,包含圖象、視頻和音頻內容 ,以及沒法與頁面其餘部分舉行交互的其他資本。

主動夾雜內容: 指的是能與頁面交互的內容,包含瀏覽器可下載和實行的劇本、樣式表、iframe、flash 資本及其他代碼。[1]

由於進擊者能夠經由過程不平安的HTTP內容來進擊平安的HTTPS頁面,所以這類要求被嚴厲阻斷掉了————這也是為何我們的Fetch要求被幹掉了。所以我們能夠在必不得已的情況下,用img.src的體式格局來發送要求。固然,要求要領只能是get。

sendHttpRequest: () => {
const img = new Image();
img.src = 'http://xxx.com//你的要求'
}

這時候,瀏覽器只會在控制台報warning,而不會block我們的要求。

總結

出於HTTPS的平安戰略,瀏覽器會阻斷HTTPS上的非平安要求(HTTP)要求,然則我們能夠運用被動夾雜內容的體式格局來逾越這個平安戰略。

參考文章:

  1. 《什麼是夾雜內容》

推荐阅读
  • 在JavaWeb开发中,文件上传是一个常见的需求。无论是通过表单还是其他方式上传文件,都必须使用POST请求。前端部分通常采用HTML表单来实现文件选择和提交功能。后端则利用Apache Commons FileUpload库来处理上传的文件,该库提供了强大的文件解析和存储能力,能够高效地处理各种文件类型。此外,为了提高系统的安全性和稳定性,还需要对上传文件的大小、格式等进行严格的校验和限制。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 为开发者提供了一系列实用的参考网站和资源链接,包括HTML速查手册( 和 ),帮助开发者快速查找和学习相关技术知识。此外,还涵盖了其他重要的开发工具和文档,为编程工作提供全面支持。 ... [详细]
  • 本文详细探讨了 jQuery 中 `ajaxSubmit` 方法的使用技巧及其应用场景。首先,介绍了如何正确引入必要的脚本文件,如 `jquery.form.js` 和 `jquery-1.8.0.min.js`。接着,通过具体示例展示了如何利用 `ajaxSubmit` 方法实现表单的异步提交,包括数据的发送、接收和处理。此外,还讨论了该方法在不同场景下的应用,如文件上传、表单验证和动态更新页面内容等,提供了丰富的代码示例和最佳实践建议。 ... [详细]
  • 本文探讨了如何利用 jQuery 的 JSONP 技术实现跨域调用外部 Web 服务。通过详细解析 JSONP 的工作原理及其在 jQuery 中的应用,本文提供了实用的代码示例和最佳实践,帮助开发者解决跨域请求中的常见问题。 ... [详细]
  • 《精通 jQuery》第六章:深入解析与实战应用
    《精通 jQuery》第六章:深入解析与实战应用本章详细探讨了 Ajax 技术的核心机制及其实际应用。Ajax 通过 XMLHttpRequest 对象实现客户端与服务器之间的异步数据交换,从而在不重新加载整个页面的情况下更新部分内容。这种技术不仅提升了用户体验,还提高了应用的响应速度和效率。此外,本章还介绍了如何利用 jQuery 简化 Ajax 操作,并提供了多个实战案例,帮助读者更好地理解和掌握这一重要技术。 ... [详细]
  • Node.js 教程第五讲:深入解析 EventEmitter(事件监听与发射机制)
    本文将深入探讨 Node.js 中的 EventEmitter 模块,详细介绍其在事件监听与发射机制中的应用。内容涵盖事件驱动的基本概念、如何在 Node.js 中注册和触发自定义事件,以及 EventEmitter 的核心 API 和使用方法。通过本教程,读者将能够全面理解并熟练运用 EventEmitter 进行高效的事件处理。 ... [详细]
  • javascript分页类支持页码格式
    前端时间因为项目需要,要对一个产品下所有的附属图片进行分页显示,没考虑ajax一张张请求,所以干脆一次性全部把图片out,然 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 秒建一个后台管理系统?用这5个开源免费的Java项目就够了
    秒建一个后台管理系统?用这5个开源免费的Java项目就够了 ... [详细]
  • 在PHP中如何正确调用JavaScript变量及定义PHP变量的方法详解 ... [详细]
  • 在处理大规模数据数组时,优化分页组件对于提高页面加载速度和用户体验至关重要。本文探讨了如何通过高效的分页策略,减少数据渲染的负担,提升应用性能。具体方法包括懒加载、虚拟滚动和数据预取等技术,这些技术能够显著降低内存占用和提升响应速度。通过实际案例分析,展示了这些优化措施的有效性和可行性。 ... [详细]
  • C++ 异步编程中获取线程执行结果的方法与技巧及其在前端开发中的应用探讨
    本文探讨了C++异步编程中获取线程执行结果的方法与技巧,并深入分析了这些技术在前端开发中的应用。通过对比不同的异步编程模型,本文详细介绍了如何高效地处理多线程任务,确保程序的稳定性和性能。同时,文章还结合实际案例,展示了这些方法在前端异步编程中的具体实现和优化策略。 ... [详细]
  • 如何在页面底部添加倾斜样式效果? ... [详细]
  • 在深入研究 React 项目的过程中,特别是在探索 react-router 源码时,我发现了其中蕴含的中间件概念。这激发了我对中间件的进一步思考与整理。本文将详细探讨 Redux 中间件的原理及其在实际项目中的应用,帮助读者更好地理解和使用这一强大工具。通过具体示例和代码解析,我们将揭示中间件如何提升应用的状态管理和异步操作处理能力。 ... [详细]
author-avatar
道貌岸然小皇猪_497_603
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有