일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 제넥신
- 스콜피온킹
- 뭉쳐야 찬다
- 조희연
- 고민정
- 이상형 만들기
- 최강욱
- 임영규
- 홍혜걸
- libtins
- 불가피
- 은혜의 강 교회
- 픽크루
- 김영권 아내
- 금리인하
- 성남은혜의강교회
- 폰폰테스트
- 이지혜
- 리리남매
- 김영권
- 킹덤 고근희
- 미국 금리인하
- 스페인 코로나
- 양적완화
- 해킹
- 유튜버 김재석
- 김재석
- 이태원 클라쓰 15회 예고
- 성남 코로나 확진자
- 학교 개학 연기 4월
Archives
- Today
- Total
Dork's port
네트워크 각 헤더의 Next Type 파싱하기. 본문
우리가 네트워크 프로그래밍 하다 보면, 원하는 헤더의 정보를 얻기위해 이더넷 헤더부터 또는 ip헤더(3계층 헤더)부터 데이터를 탐색해 나가야 하는 경우가 있는데 이 작업이 반복적이고 빈번하므로 함수로 만들어 두는 것이 좋다.
그래서 내가 만들어 놓은 함수를 공유 하고자 한다.
아래의 소스코드로 간단하게 주소 헤더의 형태 및 해당 헤더로 포인터를 이동 시킬 수 있다.
bool형으로 true가 리턴 될 경우 type(IPPROTO_TCP 등)에 대한 헤더의 첫 포인터를 가르키게 되며, false일 경우 해당 포인터의 이동이 없다.
또한, TCP의 경우 데이터의 부분을 파싱할 수 있고, data의 길이가 없을 경우 false가 리턴된다,
#include <iostream> #include <netinet/in.h> #include <netinet/ether.h> #include <netinet/ip.h> #include <netinet/tcp.h> bool parseEther(uint8_t** data,int& dataLen,int type) { struct ether_header *ep=(struct ether_header*)*data; if(ntohs(ep->ether_type)==type) { *data=*data+sizeof(struct ether_header); dataLen-=sizeof(struct ether_header); return true; } return false; } bool parseIP(uint8_t** data,int& dataLen, int type) { struct iphdr *iph=(struct iphdr*)*data; if(iph->protocol==type) { *data=*data+(iph->ihl*4); dataLen-=(iph->ihl*4); return true; } return false; } bool parseTCPData(uint8_t **data, int &dataLen) { struct tcphdr* tcph = (struct tcphdr*)*data; *data=*data+(tcph->doff*4); dataLen-=(tcph->doff*4); if(dataLen<=0) return false; else return true; }
'Develop' 카테고리의 다른 글
Pcap Library를 이용한 Packet Capture (0) | 2017.10.18 |
---|---|
Qt Creator 다운로드 하기 (0) | 2017.10.15 |
map 출력하기(C++) (0) | 2017.09.24 |
16진수로 값 출력 및 mac address 출력하기 (C++) (0) | 2017.09.22 |
Linux libpcap 을 이용한 packet capture (0) | 2017.09.22 |
Comments