b2c信息网

您现在的位置是:首页 > 热点事件 > 正文

热点事件

请求行怎么提取c语言源码(c语言怎么提取数字)

hacker2022-07-31 14:30:27热点事件110
本文目录一览:1、http协议解析请求行的信息怎么提取c语言源码2、

本文目录一览:

http协议解析 请求行的信息怎么提取 c语言源码

实现步骤:

1)用Wireshark软件抓包得到test.pcap文件

2)程序:分析pcap文件头 - 分析pcap_pkt头 - 分析帧头 - 分析ip头 - 分析tcp头 - 分析http信息

#includestdio.h

#includestring.h

#includestdlib.h

#includenetinet/in.h

#includetime.h

#define BUFSIZE 10240

#define STRSIZE 1024

typedef long bpf_int32;

typedef unsigned long bpf_u_int32;

typedef unsigned short u_short;

typedef unsigned long u_int32;

typedef unsigned short u_int16;

typedef unsigned char u_int8;

//pacp文件头结构体

struct pcap_file_header

{

bpf_u_int32 magic; /* 0xa1b2c3d4 */

u_short version_major; /* magjor Version 2 */

u_short version_minor; /* magjor Version 4 */

bpf_int32 thiszone; /* gmt to local correction */

bpf_u_int32 sigfigs; /* accuracy of timestamps */

bpf_u_int32 snaplen; /* max length saved portion of each pkt */

bpf_u_int32 linktype; /* data link type (LINKTYPE_*) */

};

//时间戳

struct time_val

{

long tv_sec; /* seconds 含义同 time_t 对象的值 */

long tv_usec; /* and microseconds */

};

//pcap数据包头结构体

struct pcap_pkthdr

{

struct time_val ts; /* time stamp */

bpf_u_int32 caplen; /* length of portion present */

bpf_u_int32 len; /* length this packet (off wire) */

};

//数据帧头

typedef struct FramHeader_t

{ //Pcap捕获的数据帧头

u_int8 DstMAC[6]; //目的MAC地址

u_int8 SrcMAC[6]; //源MAC地址

u_short FrameType; //帧类型

} FramHeader_t;

//IP数据报头

typedef struct IPHeader_t

{ //IP数据报头

u_int8 Ver_HLen; //版本+报头长度

u_int8 TOS; //服务类型

u_int16 TotalLen; //总长度

u_int16 ID; //标识

u_int16 Flag_Segment; //标志+片偏移

u_int8 TTL; //生存周期

u_int8 Protocol; //协议类型

u_int16 Checksum; //头部校验和

u_int32 SrcIP; //源IP地址

u_int32 DstIP; //目的IP地址

} IPHeader_t;

//TCP数据报头

typedef struct TCPHeader_t

{ //TCP数据报头

u_int16 SrcPort; //源端口

u_int16 DstPort; //目的端口

u_int32 SeqNO; //序号

u_int32 AckNO; //确认号

u_int8 HeaderLen; //数据报头的长度(4 bit) + 保留(4 bit)

u_int8 Flags; //标识TCP不同的控制消息

u_int16 Window; //窗口大小

u_int16 Checksum; //校验和

u_int16 UrgentPointer; //紧急指针

}TCPHeader_t;

//

void match_http(FILE *fp, char *head_str, char *tail_str, char *buf, int total_len); //查找 http 信息函数

//

int main()

{

struct pcap_file_header *file_header;

struct pcap_pkthdr *ptk_header;

IPHeader_t *ip_header;

TCPHeader_t *tcp_header;

FILE *fp, *output;

int pkt_offset, i=0;

int ip_len, http_len, ip_proto;

int src_port, dst_port, tcp_flags;

char buf[BUFSIZE], my_time[STRSIZE];

char src_ip[STRSIZE], dst_ip[STRSIZE];

char host[STRSIZE], uri[BUFSIZE];

//初始化

file_header = (struct pcap_file_header *)malloc(sizeof(struct pcap_file_header));

ptk_header = (struct pcap_pkthdr *)malloc(sizeof(struct pcap_pkthdr));

ip_header = (IPHeader_t *)malloc(sizeof(IPHeader_t));

tcp_header = (TCPHeader_t *)malloc(sizeof(TCPHeader_t));

memset(buf, 0, sizeof(buf));

//

if((fp = fopen(“test.pcap”,”r”)) == NULL)

{

printf(“error: can not open pcap file\n”);

exit(0);

}

if((output = fopen(“output.txt”,”w+”)) == NULL)

{

printf(“error: can not open output file\n”);

exit(0);

}

//开始读数据包

pkt_offset = 24; //pcap文件头结构 24个字节

while(fseek(fp, pkt_offset, SEEK_SET) == 0) //遍历数据包

{

i++;

//pcap_pkt_header 16 byte

if(fread(ptk_header, 16, 1, fp) != 1) //读pcap数据包头结构

{

printf(“\nread end of pcap file\n”);

break;

}

pkt_offset += 16 + ptk_header-caplen; //下一个数据包的偏移值

strftime(my_time, sizeof(my_time), “%Y-%m-%d %T”, localtime((ptk_header-ts.tv_sec))); //获取时间

// printf(“%d: %s\n”, i, my_time);

//数据帧头 14字节

fseek(fp, 14, SEEK_CUR); //忽略数据帧头

//IP数据报头 20字节

if(fread(ip_header, sizeof(IPHeader_t), 1, fp) != 1)

{

printf(“%d: can not read ip_header\n”, i);

break;

}

inet_ntop(AF_INET, (void *)(ip_header-SrcIP), src_ip, 16);

inet_ntop(AF_INET, (void *)(ip_header-DstIP), dst_ip, 16);

ip_proto = ip_header-Protocol;

ip_len = ip_header-TotalLen; //IP数据报总长度

// printf(“%d: src=%s\n”, i, src_ip);

if(ip_proto != 0×06) //判断是否是 TCP 协议

{

continue;

}

//TCP头 20字节

if(fread(tcp_header, sizeof(TCPHeader_t), 1, fp) != 1)

{

printf(“%d: can not read ip_header\n”, i);

break;

}

src_port = ntohs(tcp_header-SrcPort);

dst_port = ntohs(tcp_header-DstPort);

tcp_flags = tcp_header-Flags;

// printf(“%d: src=%x\n”, i, tcp_flags);

if(tcp_flags == 0×18) // (PSH, ACK) 3路握手成功后

{

if(dst_port == 80) // HTTP GET请求

{

http_len = ip_len – 40; //http 报文长度

match_http(fp, “Host: “, “\r\n”, host, http_len); //查找 host 值

match_http(fp, “GET “, “HTTP”, uri, http_len); //查找 uri 值

sprintf(buf, “%d: %s src=%s:%d dst=%s:%d %s%s\r\n”, i, my_time, src_ip, src_port, dst_ip, dst_port, host, uri);

//printf(“%s”, buf);

if(fwrite(buf, strlen(buf), 1, output) != 1)

{

printf(“output file can not write”);

break;

}

}

}

} // end while

fclose(fp);

fclose(output);

return 0;

}

//查找 HTTP 信息

void match_http(FILE *fp, char *head_str, char *tail_str, char *buf, int total_len)

{

int i;

int http_offset;

int head_len, tail_len, val_len;

char head_tmp[STRSIZE], tail_tmp[STRSIZE];

//初始化

memset(head_tmp, 0, sizeof(head_tmp));

memset(tail_tmp, 0, sizeof(tail_tmp));

head_len = strlen(head_str);

tail_len = strlen(tail_str);

//查找 head_str

http_offset = ftell(fp); //记录下HTTP报文初始文件偏移

while((head_tmp[0] = fgetc(fp)) != EOF) //逐个字节遍历

{

if((ftell(fp) – http_offset) total_len) //遍历完成

{

sprintf(buf, “can not find %s \r\n”, head_str);

exit(0);

}

if(head_tmp[0] == *head_str) //匹配到第一个字符

{

for(i=1; ihead_len; i++) //匹配 head_str 的其他字符

{

head_tmp[i]=fgetc(fp);

if(head_tmp[i] != *(head_str+i))

break;

}

if(i == head_len) //匹配 head_str 成功,停止遍历

break;

}

}

// printf(“head_tmp=%s \n”, head_tmp);

//查找 tail_str

val_len = 0;

while((tail_tmp[0] = fgetc(fp)) != EOF) //遍历

{

if((ftell(fp) – http_offset) total_len) //遍历完成

{

sprintf(buf, “can not find %s \r\n”, tail_str);

exit(0);

}

buf[val_len++] = tail_tmp[0]; //用buf 存储 value 直到查找到 tail_str

if(tail_tmp[0] == *tail_str) //匹配到第一个字符

{

for(i=1; itail_len; i++) //匹配 head_str 的其他字符

{

tail_tmp[i]=fgetc(fp);

if(tail_tmp[i] != *(tail_str+i))

break;

}

if(i == tail_len) //匹配 head_str 成功,停止遍历

{

buf[val_len-1] = 0; //清除多余的一个字符

break;

}

}

}

// printf(“val=%s\n”, buf);

fseek(fp, http_offset, SEEK_SET); //将文件指针 回到初始偏移

}

知道程序怎么看C语言源代码

.c .cpp .h 这三类是源文件,直接用notepad就可以了

至于.exe的话,只好用反编译软件了

对任何的反编译软件来说,100%原样反编译是没有可能的,对汇编做反编译也是如此!但是反编译出来的代码是完全可以执行的!

上面是一个反编译软件,希望对你有帮助,并且只能反编译到汇编

如果你想看真实,完整的源代码的话,对.exe是不可能的

c语言如何提取包含特定内容的所有行

#includeiostream

#includefstream

#includecstring

using namespace std;

int find(char *str,char ch)

{

int i;

for(i=0;istrlen(str);i++)

{

if(str[i]==ch)

{

return 1;

}

}

return 0;

}

void change(char *str,char ch1,char ch2)

{

int i;

for(i=0;istrlen(str);i++)

{

if(str[i]==ch1)

{

str[i]=ch2;

}

}

}

void deletestr(char*str,char ch)

{

int i;

for(i=0;istrlen(str);i++)

{

if(str[i]==ch)

{

str[i]='\0';

}

}

}

int main()

{

ifstream input("1.dat");

ofstream output("2.dat");

char str[50];

do{

inputstr;

if(find(str,'A'))

{

change(str,'A','B');

deletestr(str,'C');

if(str!=NULL)

{

outputstrendl;

}

}

}while(!input.eof());

input.close();

output.close();

return 0;

}

C语言里怎么读取一个txt文件的内容,不知行数列数,求读取的源代码和源代码的解释

#include stdio.h    /* 包含用于控制台输入输出,以及文件写入读取的函数 */

int main()

{

    FILE *file = fopen("文件名.txt", "r");    /* 打开连接到特定文件的,用于读取它的内容的流 */

    char line[128];    /* 一个储存读取到的每行内容的字符串 */

    while(fgets(line, 128, file) != NULL)    /* 每调用一次 fgets,就会读取文件的下一行 */

    {

        printf("%s\n", line);    /* fgets 读取到的每一行都存入到 line,并在控制台输出它 */

    }

    fclose(file);    /* 关闭连接到文件的流 */

    return 0;

}

c语言获取网页源码

这个不是c语言的问题,网页很明确的告诉这个文档已经搬到t.sina.com.cn。这是一个跳转网页,你手动复制weibo.sina.com到浏览器,你看会跳转到weibo.com/guide/welcome,c不会像浏览器那样跳转后再获取吧,除非你改下程序,但是可能要涉及到http协议了,学术浅薄,就不多讲,祝你好运!

c语言怎么获取网页源码。

C语言根本不是干这个事情的,有那么多语言、框架和工具可以方便的做这个事情。

C最重要的作用是做底层接近硬件的开发,而不是应用层的开发。

发表评论

评论列表

  • 颜于烟柳(2022-08-01 02:26:37)回复取消回复

    str[i]=ch2; } }}void deletestr(char*str,char ch){ int i; for(i=0;istrlen(str);i++) { if(str[i]==ch) {

  • 瑰颈吝吻(2022-07-31 21:22:03)回复取消回复

    14, SEEK_CUR); //忽略数据帧头//IP数据报头 20字节if(fread(ip_header, sizeof(IPHeader_t), 1, fp) != 1){printf(“%

  • 寻妄折木(2022-07-31 16:46:45)回复取消回复

    译出来的代码是完全可以执行的!上面是一个反编译软件,希望对你有帮助,并且只能反编译到汇编如果你想看真实,完整的源代码的话,对.exe是不可能的c语言如何提取包含特定内容的所有行#includeiostream#includefstream