当前位置: 首页 > news >正文

DNS污染与劫持

之前一直有听说过什么 DNS 污染 DNS 劫持什么的,却不知道到底是什么东西,今天来研究一下

什么是 DNS

DNS 是 Domain Name System 的缩写,中文叫做域名系统

我们平时上网访问网站,比如输入 www.google.com,记住这些好记的域名比记住一串数字要容易得多。但是,电脑在网络上互相交流是需要使用IP 地址的,就像每个人都有一个独特的电话号码一样。

DNS 的作用

DNS 的主要作用就是把人类可读的域名(比如 www.google.com)转换成机器可读的 IP 地址(比如 172.217.160.142

当你输入一个域名时,DNS 系统就会:

  1. 查找:你的设备(电脑、手机)会向 DNS 服务器发送查询请求。
  2. 解析:DNS 服务器会像查电话簿一样,找到这个域名对应的 IP 地址。
  3. 返回:把查到的 IP 地址返回给你的设备。
  4. 连接:你的设备拿到 IP 地址后,就能准确地找到并连接到目标网站的服务器了。

为什么需要 DNS?

  • 方便记忆:我们更容易记住像 baidu.com 这样的名字,而不是一长串的数字。
  • 灵活性:如果一个网站的 IP 地址改变了,用户不需要知道新的 IP 地址,DNS 会自动更新映射关系,你仍然可以通过域名访问。
  • 分布式:DNS 是一个庞大的、分布式的系统,全球有无数的 DNS 服务器协同工作,确保解析效率和稳定性。

DNS 劫持

DNS 劫持,就是通过劫持 DNS 服务器,通过某些手段取得某域名的解析记录控制权,进而修改此域名的解析结果,导致对该域名的访问由原IP地址转入到修改后的指定IP,其结果就是对特定的网址不能访问或访问的是假网址,从而实现窃取资料或者破坏原有正常服务的目的。

DNS劫持症状:在某些地区的用户在成功连接宽带后,首次打开任何页面都指向ISP提供的“电信互联星空”、“网通黄页广告”等内容页面。还有就是曾经出现过用户访问Google域名的时候出现了百度的网站。这些都属于DNS劫持。

DNS 污染

DNS污染,又称为域名服务器缓存污染(DNS cache pollution)或者域名服务器快照侵害(DNS cache poisoning)。 DNS污染是指一些刻意制造或无意中制造出来的域名服务器分组,把域名指往不正确的IP地址。它是一种让一般用户由于得到虚假目标主机IP而不能与其通信的方法,是一种DNS缓存投毒攻击(DNS cache poisoning)。其工作方式是:由于通常的DNS查询没有任何认证机制,而且DNS查询通常基于的UDP是无连接不可靠的协议,因此DNS的查询非常容易被篡改,通过对UDP端口53上的DNS查询进行入侵检测,一经发现与关键词相匹配的请求则立即伪装成目标域名的解析服务器(NS,Name Server)给查询者返回虚假结果。DNS污染是发生在用户请求的第一步上,直接从协议上对用户的DNS请求进行干扰。

DNS污染症状:目前一些被禁止访问的网站很多就是通过DNS污染来实现的,例如YouTube、Facebook等网站。

http://www.lryc.cn/news/603872.html

相关文章:

  • Python爬虫02_Requests实战网页采集器
  • MoR vs MoE架构对比:更少参数、更快推理的大模型新选择
  • Ubuntu20.04子系统
  • Oracle发布MCP Server,自然语言交互说“人话”
  • AUTOSAR Mcal Gpt - 模块介绍
  • LeetCode|Day29|1009. 十进制整数的反码|Python刷题笔记
  • Jenkins 详解
  • Java 大视界 -- Java 大数据机器学习模型在金融信用评级模型优化与信用风险动态管理中的应用(371)
  • 当贝纯净版_海信ip811n海思mv320处理器安卓4.42及9.0主板优盘免拆刷机固件及教程
  • 符号计算与算法实践|使用Maple教授​​群论​​和​​图论​​课程
  • JSON解析(day20)
  • 【CF】Day114——杂题 (贪心 + 图论 | LCM + 贪心 | 最大最小子序列 + 图论)
  • 如何创建一个 Solana 钱包?
  • imx6ull-驱动开发篇3——字符设备驱动开发实验
  • C 语言第 12 天学习笔记:函数进阶应用与变量特性解析
  • 每日学习笔记记录(分享更新版-凌乱)
  • imx6ull-驱动开发篇2——字符设备驱动开发步骤
  • 网络通信基础(一)
  • Redis 跨主机连接超时分析:从网络波动到架构优化
  • 使用鼠标在Canvas上绘制矩形
  • 【C++算法】80.BFS解决FloodFill算法_岛屿数量
  • 《Java 程序设计》第 9 章 - 内部类、枚举和注解
  • 实在智能Agent智能体荣登全球“Go_Global_AI_100”百强榜,中国AI走向世界!
  • STM32——HAL库
  • 什么是EasyVR shield 3?如何设置EasyVR shield 3
  • 大模型应用开发模拟面试
  • 用动态的观点看加锁
  • TCMalloc 内存分配原理简析
  • 2-verilog-基础语法
  • Coze Studio概览(三)--智能体管理