LINUX 入门 6

LINUX 入门 6

day10 20240505 耗时:41min

day10 20240506 耗时:155min

课程链接地址

第6章 DNS协议与请求

1 DNS协议分析与项目介绍

  1. 自己去看教程 快速扫了一下,还是结合实践去看概念有感觉

    回答以下几个问题:

    1. dns作用
    2. dns分层
    3. 服务类型:授权型、递归型recursion
    4. dns协议——结构,服务器去解析,解析过程,报文格式

    DNS互联网开发重要组件,domain name system:翻译域名domain name为IP地址

    windows下win+R
    cmd
    nslookup www.baidu.com 查看网址的ip 14.215.177.38和39
    

​ 我貌似不行,一直timeout,第二天试了以下又行了

  1. wireshark 对dns解析

    自己官网装一下就行,下载巨慢,用迅雷下就行

    选Ethernet以太网 这个网卡网络适配器,but好像没有,wlan有,敲网址以后

    前两条query,后一条response

    在这里插入图片描述

    在这里插入图片描述

    看协议报文格式——recursion递归型查询,头部正文等等,去看教程,有点印象,看过的八股里有

2 DNS请求头定义与域名查询原则

域名查询 类似 Huffman树结构+多栈

0voice.com的name:60voice3com

// 查协议报文格式
struct dns_header{// 长度固定unsigned short id;unsigned short flags;unsigned short questions;unsigned short answer;unsigned short authority;unsigned short additional;
};struct dns_question {// 长度不固定int length;unsigned short qtype;unsigned short qclass;unsigned char *name; // 
};

3 DNS header填充与函数实现

  1. wireshark看到的一坨——物理层、数据链路层、网络层、传输层、DNS层
  2. query和response的transaction ID不变
  3. htons:将主机字节顺序转换为网络字节顺序的函数,其中 “htons” 代表 “host to network short”。在网络编程中,字节顺序是一个重要的概念,因为不同的计算机体系结构可能采用不同的字节顺序(即大端序12 | 34和小端序13 | 24),而网络协议通常要求使用特定的字节顺序进行通信,以确保数据在不同计算机之间正确解释。
// 2 client send to dns server 填充header
int dns_create_header(struct dns_header *header){// 先判断传进来的参数,习惯!!!if(header ==NULL) return -1;memset(header, 0, sizeof(struct dns_header)); //接着,使用 memset 函数将传入的 header 指针所指向的内存区域全部设置为 0。这个操作通常用于初始化内存,确保结构体中的所有字段都被正确初始化为 0。// random, 下面两行一起产生的,多线程,不安全,先srandom产生种子,在其他地方random()调用会出问题srandom(time(NULL)); //提供一个随机种子,限定随机值的范围; 现在距离1970年的秒数,所以随机值很大!// srandom(100); //产生0-99的值!header->id = random();header->flags = htons(0x100);header->questions = 1; //每次查一个DNS
}

4 DNS question填充与函数实现

不要开2倍速,听也听不清,很暴躁,越听越暴躁 1.25可以

  1. size_t: size_t 是一种用于表示内存大小的数据类型,通常用于与内存相关的操作,比如数组索引、内存分配等。它的大小在不同的系统中可能有所不同,但通常被定义为无符号整数类型。

    在 C 语言中,size_t 类型通常是 typedefunsigned int 或者 unsigned long 的别名,取决于具体的编译器和系统架构。在 32 位系统中,通常为 unsigned int,而在 64 位系统中通常为 unsigned long

  2. strncpy(a,b,长度) strcpy()遇到\0才结束 b给a

// hostname:www.0voice.com 
// name:3www6voice3com0
int dns_create_question(struct dns_question *question, const char *hostname){if(question == NULL || hostname == NULL) return -1;memset(question, 0, sizeof(struct dns_question));question->name = (char*)malloc(strlen(hostname));if(question->name == NULL) return -2;question->length = strlen(hostname) + 2;question->qtype = htons(1); //变成Aquestion->qclass = htons(1);// name转换,一段段截const char delim[2] = "."; //字符数组2个.char *qname = question->name;char *hostname_dup = strdup(hostname); //复制duplicate,自带malloc,返回一个动态的非常量!!char *token = strtok(hostname_dup,delim); //截取token, 按分隔符delim截while(token != NULL){// 第一组wwwsize_t len = strlen(token);//取这段长度,size_t: 是一种用于表示内存大小的数据类型,*qname = len;qname++; //第一个放长度strncpy(qname, token, len + 1);//最后的\0结束符也copyqname += len;//指针移到结尾// 更新token,后面2组0voice comtoken = strtok(NULL, delim); //0voice.com第一次截要hostname_dup,第二次就接着截,所以线程不安全,因为保存了上一次截取的会错乱}free(hostname_dup);}

5 DNS协议 UDP编程的实现

如何发射到DNS服务器(改不了),只能改client端。DNS类似广播,UDP:基于无连接,只管发不管收到吗

  1. AF_INET是一种常见的网络地址家族,它用于IPv4(Internet Protocol version 4)地址。在网络编程中,AF_INET常用于创建和处理IPv4套接字(socket)。它指示使用IPv4地址格式来进行通信。
  2. SOCK_DGRAM是一种套接字类型,用于在网络编程中进行数据报式(Datagram)通信。该类型的套接字提供了无连接、不可靠的数据传输服务。每个发送的数据包被视为一个独立的实体,可能会以任意顺序到达目标地址,并且也不能保证可靠交付或按顺序交付。UDP(User Datagram Protocol)就是使用SOCK_DGRAM套接字类型进行通信的协议之一。与TCP相比,UDP具有更低的开销和延迟,适用于对实时性要求较高但不需要可靠性和顺序性保证的应用场景。
  3. sendto(fd, request, length, 0, servaddr, addr_len);
  • fd:套接字文件描述符。
  • request:要发送的数据报内容。
  • length:要发送的数据报长度。
  • 0:标志位,用于指定额外的选项。在此处设置为0表示没有额外选项。
  • servaddr:目标地址信息,通常是一个结构体类型,包含目标IP地址和端口号等信息。
  • addr_len:目标地址信息结构体的大小。

UDP编程比较格式化,没啥为什么比较固定了

// 3 udp
int dns_client_commit(const char *domain){// AF_INET是一种常见的网络地址家族,它用于IPv4(Internet Protocol version 4)地址。在网络编程中,AF_INET常用于创建和处理IPv4套接字(socket)。它指示使用IPv4地址格式来进行通信。int sockfd = socket(AF_INET, SOCK_DGRAM, 0); //client发的forward fdif(sockfd < 0) return -1;// 结构体的定义这么多年基本这么写,比较固定struct sockaddr_in servaddr = {0};servaddr.sin_family = AF_INET;servaddr.sin_port = htons(DNS_SERVER_PORT);servaddr.sin_addr = inet_addr(DNS_SERVER_IP);int ret = connect(sockfd, (struct sockaddr*)&servaddr, sizeof(servaddr));printf("connect : %d\n", ret);struct dns_header header = {0};dns_create_header(&header);struct dns_question = {0};dns_create_question(&question, domain);char request[1024] = {0};int length = dns_build_request(&header, &question, request);// requestint slen = sendto(fd, request, length, 0, servaddr, sizof(struct sockaddr));// recvfrom在这里阻塞,send和recieve在一起char response[1024] = {0};struct sockaddr_in addr;size_t addr_len = sizeof(struct sockaddr_in);int n = recvfrom(sockfd, response,sizeof(response), 0, (struct sockaddr*)&addr, (socklen_t*)&addr_len);printf("recvfrom: %d, %s\n", n , response);return n;
}

6 DNS build_requestion的实现

connect()类似连接前开路的,在tcp三次握手有用,udp没那么有用,可能在sendto前用

云里雾里的有点,太多库函数和数据类型 <sys/socket.h> <netinet/in.h> <unistd.h>不认识

#include <stdio.h>
#include <string.h>
#include <stdlib.h>#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <time.h>#define DNS_SERVER_PORT 53
#define DNS_SERVER_IP "114.114.114.114"//  协议包组织打包,已有header question合并到request
int dns_build_request(struct dns_header *header, struct dns_question *question, char *request, int rlen){if(header == NULL || question  == NULL || request == NULL) return -1;memset(request, 0, rlen);// header-->requestmemcpy(request, header, sizeof(struct dns_header)); //header复制到requestint offset = sizeof(struct dns_header);// question-> request    memcpy(request + offset,question->name, question->length); // request +offset这里offset += question->length;memcpy(request+offset, &question->qtype, sizeof(question->qtype));offset += sizeof(question->qtype);memcpy(request+offset, &question->qclass, sizeof(question->qclass));offset += sizeof(question->qclass);return offset;}int main(int argc, char* argv[]){if(argc <2) return -1;dns_client_commit(argv[1]);
}

7 调试

爆了一堆错,一个个改

gcc -o dns dns.c 
./dns www.0voice.com

我打印了connect : 0没有打印接收recvfrom的东西,说明连接服务器是成功了

记住一句话

按DNS协议发送数据,就会按DNS协议返回数据,所以根本没法数据

问题处在:dns_create_header

// header->questions = 1; //每次查一个DNS

header->questions = htons(1); // 要转成网络字节序

输出

recvfrom: 48, %ځ�
%ځ�www0voicecom�m+�y
5ffffffdaffffff81ffffff80010100003777777630766f6963653636f6d00101ffffffc0c01010016d042bffffff8b791b

8 DNS相应response解析

这里没敲,只看了操作和效果

is_pointer是否一帧,dns_parse_name和dns_parse_response就是翻译上面一坨乱码字符和16进制的形式

UDP好处,比TCP好处

  1. UDP传输快,对带宽无限制,比如迅雷下载 整个局域网就你下
  2. UDP响应速度快,游戏里服务器对客户端响应快!还有下载文件的时候

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

PLC学习笔记

PLC学习笔记 前言一、一些基操知识二、GX works2编程2.1 位逻辑1.2 中间寄存器1.3 PLC的扫描方式 总结 前言 我这个人真的是太渴望知识了~ 一、一些基操知识 一般X表示输入&#xff0c;Y表示输出。一般八个为一组X0~X7M表示中间寄存器&#xff0c;M0~M7时间T、计数C 二、GX …

Centos 7.9 配置VNCServer实现远程vnc连接

文章目录 1、Centos安装图形界面1.1、安装X Windows System图形界面1.2、安装GNOME图形界面 2、VNC SERVER配置2.1、VNC SERVER安装2.2、VNC SERVER配置1&#xff09;创建vnc配置文件2&#xff09;修改配置文件内容3&#xff09;完整配置文件参考 2.3、设置vnc密码2.4、配置防火…

C#语言核心

一、面向对象基本概念 万物皆对象&#xff0c;用程序来抽象&#xff08;形容&#xff09;对象&#xff0c;用面向对象的思想来编程 用中文去形容一类对象&#xff0c;把一类对象的共同点提取出来&#xff0c;然后用程序语言把它翻译过来&#xff0c;带着对象的概念在程序中使…

OCR文本识别模型CRNN

CRNN网络结构 论文地址&#xff1a;https://arxiv.org/pdf/1507.05717 参考&#xff1a;https://blog.csdn.net/xiaosongshine/article/details/112198145 git:https://github.com/shuyeah2356/crnn.pytorch CRNN文本识别实现端到端的不定长文本识别。 CRNN网络把包含三部分&…

IOS离线打包uniapp的信息时报错如下的解决方法

IOS离线打包uniapp的信息时报错如下的解决方法 问题描述&#xff1a; Extract app intents metadata 0.1 seconds XExtractAppIntentsMetadata(in target HBuilder from project HBuilder-Hello)cd /Users/whb/space/vpt/vptios/HBuilder-Hello/Applications/Xcode.app/Conte…

分布式与一致性协议之ZAB协议(六)

ZAB协议 成员发现 成员发现是通过跟随者和领导者交互来完成的&#xff0c;目标是确保大多数节点对领导者的关系没有异议&#xff0c;也就是确立领导者的领导地位。成员发现的实现流程如图所示。 1.领导者选举结束&#xff0c;节点进入跟随者状态或者领导者状态后&#xff0…

如何获得一个Oracle 23ai数据库(RPM安装)

准确的说&#xff0c;是Oracle 23ai Free Developer版&#xff0c;因为企业版目前只在云上&#xff08;OCI和Azure&#xff09;和ECC上提供。 方法包括3种&#xff0c;本文介绍第2种&#xff1a; Virtual ApplianceRPM安装Docker RPM安装支持Linux 8和Linux 9。由于官方的Vi…

Elastic 通过 AI 驱动的安全分析改变 SIEM 游戏

作者&#xff1a;Santosh Krishnan, Jennifer Ellard 借助由搜索 AI 提供支持的新攻击发现功能&#xff0c;优先考虑攻击&#xff0c;而不是警报。 传统的安全信息与事件管理系统&#xff08;SIEM&#xff09;在很大程度上依赖屏幕背后的人类才能取得成功。警报、仪表盘、威胁…

【busybox记录】【shell指令】join

目录 内容来源&#xff1a; 【GUN】【join】指令介绍 【busybox】【join】指令介绍 【linux】【join】指令介绍 使用示例&#xff1a; 打印两个文件的共有行 - 默认输出 可以对字母排序 可以对数字排序 可以对字符串排序 打印两个文件的共有行 - 输出文件1或者文件2中…

SQL注入实例(sqli-labs/less-1)

初始网页 从网页可知传递的参数名为 id&#xff0c;并且为数字类型 1、得知数据表有多少列 1.1 使用联合查询查找列数&#xff08;效率低&#xff09; http://localhost/sqli-labs-master/Less-1/?id1 union select 1,2 -- 1.2 使用order by查找列数&#xff08;效率高&…

【MySQL】MySQL基本知识点

目录 1.SQL分类&#xff1a; 2.DDL-数据库操作 3.DDL-表操作-创建 4.DDL-表操作-查询 5.DDL-表操作-数据类型 6.DDL-表操作-修改 1.SQL分类&#xff1a; 2.DDL-数据库操作 3.DDL-表操作-创建 注意&#xff1a;里面的符号全部要切换为英文状态 4.DDL-表操作-查询 5.DDL…

网络安全之动态路由入门

动态路由协议有几种&#xff1a;RIP,OSPF,EIGRP,ISIS,BGP 动态路由工作原理&#xff1a; 例如&#xff1a; 若A区域运行的协议与B中的不同&#xff0c;数据从1到4走A区域还是走B区域&#xff0c;则看A,B两区域的优先级&#xff08;priority preference或AD——管理距离&#…

个股期权是什么期权?个股期权什么时候推出?

今天期权懂带你了解个股期权是什么期权&#xff1f;个股期权什么时候推出&#xff1f;期权也称选择权&#xff0c;是指期权的买方有权在约定的期限内&#xff0c;按照事先确定的价格&#xff0c;买入或卖出一定数量某种特定商品或金融指标的权利。 个股期权是什么期权&#xff…

后端开发面经系列 -- 滴滴C++一面面经

滴滴C一面面经 公众号&#xff1a;阿Q技术站 来源&#xff1a;https://www.nowcoder.com/feed/main/detail/38cf9704ef084e27903d2204352835ef 1、const在C和C区别&#xff0c;const定义的类成员变量如何初始化&#xff1f; 区别 C中的const&#xff1a; 在C中&#xff0c;c…

【Redis分布式缓存】分片集群

Redis 分片集群 搭建分片集群 集群结构 分片集群需要的节点数量较多&#xff0c;这里我们搭建一个最小的分片集群&#xff0c;包含3个master节点&#xff0c;每个master包含一个slave节点&#xff0c;结构如下&#xff1a; 这里我们会在同一台虚拟机中开启6个redis实例&…

计算机毕业设计Python+Vue.js天气预测系统 中国气象质量采集与可视化 天气数据分析 天气可视化 天气大数据 天气爬虫 大数据毕业设计

摘要 随着科技技术的不断发展&#xff0c;人民物质生活质量不断提高&#xff0c;我们越来越关注身边的气象、空气等地理环境。对于普通居民我们会选择合适的气象进行出游&#xff0c;提高精神层面的生活质量&#xff1b;对于企业会关注气象变换状况&#xff0c;来定制相关的生产…

91、动态规划-不同的路径

思路&#xff1a; 首先我们可以使用暴力递归解法&#xff0c;无非就是每次向下或者向右看看是否有解法&#xff0c;代码如下&#xff1a; public class Solution {public int uniquePaths(int m, int n) {return findPaths(0, 0, m, n);}private int findPaths(int i, int j,…

解决Python中的 `ModuleNotFoundError: No module named ‘fcmeans‘` 错误

ModuleNotFoundError: No module named fcmeans 解决Python中的 ModuleNotFoundError: No module named fcmeans 错误如何解决这个错误fcmeans 库简介应用实例 解决Python中的 ModuleNotFoundError: No module named fcmeans 错误 在进行数据科学或机器学习项目时&#xff0c;…

【CTF Web】XCTF GFSJ0477 backup Writeup(备份文件+源码泄漏+目录扫描)

backup X老师忘记删除备份文件&#xff0c;他派小宁同学去把备份文件找出来,一起来帮小宁同学吧&#xff01; 解法 使用 dirsearch 扫描目录。 dirsearch -u http://61.147.171.105:49361/下载&#xff1a; http://61.147.171.105:64289/index.php.bak打开 index.php.bak&am…

【机器学习系统的构建】从模型开发的过程讲清楚K-Fold 交叉验证 (Cross-Validation)的原理和应用

0、前言 最近在学习集成学习的时候了解到了k折交叉验证&#xff0c;其实在之前学习吴恩达老师的课程中也学过交叉验证&#xff0c;但是当时也不是很明白。这次借着自己的疑问以及网上搜找资料&#xff0c;终于把交叉验证给弄明白了。 在弄清楚前&#xff0c;我有这样几个疑问…