간단한 udp send 프로그램이 안돌아가네요.
아래와 같은 간단한 udp send 프로그램을 만들었습니다.
프로그램 실행 방법은..
udp_send [local_bind_port] [dest_ip] [dest_port] [file_to_open]
와 같구요..
기능은, 프로그램 실행시 마지막 인자로 설정한 파일을 읽어서,
dest_ip, port로 전송하는 것입니다.
말 그대로 간단하죠.
근데 이 간단한 코드가 돌아가질 않아서 미치겠네요.
돌려 보면, sendto가 실패나고, 그 실패 메시지를 출력해 보면,
Invalid Argument로 나옵니다. (strerror(errno) 이용해서 출력해 봤습니다)
어디가 문제인지 조언 부탁 드립니다.
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <string.h>
#include <stdlib.h>
#include <arpa/inet.h>
#include <errno.h>
int main(int n_arg_c, char* pasz_args[])
{
int n_sid, len;
FILE *fptr;
char msg[2048];
if (n_arg_c != 5)
{
printf("udp_sender [bind_port] [dest_IP] [dest_port] [FILE NAME]\n");
return -1;
}
fptr = fopen(pasz_args[4], "r");
if (fptr == NULL)
{
printf("Failure to open file - %s\n", pasz_args[4]);
return -1;
}
len = fread(msg, 1, sizeof(msg), fptr);
printf("Success to read file , size : %d\n", len);
n_sid = socket(PF_INET, SOCK_DGRAM, 0);
if (n_sid == -1)
{
printf("socket creation failure\n");
return -1;
}
int nRet;
sockaddr_in dest_addr,bind_addr;
memset(&dest_addr, 0, sizeof(sockaddr_in));
dest_addr.sin_family = PF_INET;
dest_addr.sin_port = htons(atoi(pasz_args[3]));
dest_addr.sin_addr.s_addr = inet_addr(pasz_args[2]);
memset(&bind_addr, 0, sizeof(sockaddr_in));
bind_addr.sin_family = PF_INET;
bind_addr.sin_port = htons(atoi(pasz_args[1]));
bind_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
if (-1 == bind(n_sid, (sockaddr*)&bind_addr, sizeof(sockaddr_in)))
{
printf("bind failure\n");
return -1;
}
printf("Sending Pakcet , Dest:%d.%d.%d.%d:%d\n", \
dest_addr.sin_addr.s_addr & 0xFF,
dest_addr.sin_addr.s_addr >> 8 & 0xFF,
dest_addr.sin_addr.s_addr >> 16 & 0xFF,
dest_addr.sin_addr.s_addr >> 24 & 0xFF, ntohs(dest_addr.sin_port));
if (-1 == (nRet = sendto(n_sid, msg, len, 0, (sockaddr*)&dest_addr, sizeof(sockaddr_in))))
{
printf("Failure to send , %s\n", strerror(errno));
//printf("Failure to send packet\n");
}
else if (nRet < len)
{
printf("Sent Size : %d\n", nRet);
}
else
{
printf("Success to send\nsize:%d\n%s\n", nRet, msg);
}
int nVal = sizeof(sockaddr_in);
if (0 < recvfrom(n_sid, msg, sizeof(msg), 0, (sockaddr*)&dest_addr, (socklen_t*)&nVal))
{
printf("success to receive \n%s\n", msg);
}
return 0;
}
프로그램이 묘(?)하긴 한데, 일단 자신의 루프백에서 원격지로 보낼 수
프로그램이 묘(?)하긴 한데, 일단 자신의 루프백에서 원격지로 보낼 수 없겠지요?
127.0.0.1 => 실제 ip주소
단지, 자신의 컴퓨터에서는 루프백으로 보낼 수 있겠습니다.(vice versa)
이를 테면,
$ 실행파일명 4444 127.0.0.1 7777 하면 될것이고....
그러나, 자신의 loopback에서 원격지 ip로 보낼 수 없습니다. (당근)
$ 실행파일명 4444 X.X.X.X 7777 하면 안될것이고....
(가정, X.X.X.X는 실행파일이 돌고 있는 컴퓨터의 IP주소가 아닌 임의의 IP주소이다)
* 하드코딩되어 있는 "127.0.0.1"을 손보라는 얘기지요.
* 코드가 좀 묘하게 구성되어 있군요.( 예제들을 더 찾아보고, 살펴보라는 얘기)
댓글 달기