FTP 데몬을 포팅 중에 있는데 문제가 발생했습니다.
안녕하세요
FTP데몬을 조금 개조해서 사용하는데요 logdaemon-5.9버전을 개조했습니다.
리눅스에서 수정을 하고 유닉스상(썬 솔라리스 5.9)에서 포팅을 하고 있는데요 문제가 발생했습니다.
ls, get,put 명령이 안됩니다.
pwd나 cd 등 다른부분은 되는데 위에 3가지 정도가 안되서 한참 찾아 다녔습니다.
그러다가 이번에 문제를 알게 됐는데요
FTP 데몬의 main문안에는 getpeername()를 사용해서 접속하는 소켓의 주소를 알아내는데요
리눅스와 유닉스 상에서 결과 값이 다르게 저장이 됩니다.
if (getpeername(0, (struct sockaddr *)&his_addr, &addrlen) < 0) { syslog(LOG_ERR, "getpeername (%s): %m",argv[0]); exit(1); }
저장된 값을 보면 (his_addr)
리눅스
his_addr.port[7457]
his_addr.sin_addr.s_addr[-503207744]
his_addr.sin_famly[2]
유닉스
his_addr.port[8466]
his_addr.sin_addr.s_addr[0]
his_addr.sin_famly[26]
위의 결과를 보면 ftp에 접속하는 운영체제는 윈도우고 접속한 주소도 같지만
port는 다른걸 그냥 넘긴다고 치지만 s_addr, 접속한 클라이언트의 주소가 0으로 되어있습니다.
에러가 나는 상황도 아닌데 저렇게 저장이 되는게 이상하네요
또한 sin_family같은 경우에도 서로 값이 다른데요
리눅스의 경우는 AF_INET으로 셋팅이 되는데 반해
유닉스에서는 AF_INET6으로 셋팅이 되어 있습니다...
왜이렇게 다른결과가 나올까요 특히 주소가 저장이 안되어서 구동중에 ls 명령이 안되고 있는거 같습니다.
이부분은 어떻게 처리를 해주면 좋을까요 아시는분 답변 좀 부탁 드리겠습니다.
댓글 달기