소켓 질문입니다... 파일전송 관련(리눅스)
글쓴이: kwkimg3100 / 작성시간: 일, 2018/03/18 - 2:35오후
지금 파일을 전송하는 명령어를 만드는 중입니다 그런대
문제점이 무엇이냐면 일단 파일전송이 맘대로입니다 잘보내질때는 잘보내지고 안보내질때는 잘보내지다가 가끔은
open에러가 나더군요(에러나는것도 시간지나면 풀리기도하고 아닐떄는 계속안됩니다)
open에러나기전 출력되는 문구를 보니 서버의 printf("%s -> %s\n", inet_ntoa(cli_sock.sin_addr), file_name);
이부분에서
file_name변수에는 클라이언트에서 보내는 파일제목만 담겨져야하는대 내용까지 다 담겨져서 출력되더군요... 그후로 open에러가 출력됩니다.
fflush로 해봐도 여전히 맘대로입니다
잘될떄는 잘되고 안될때는 open에러나고 무엇이 문제일까요?
그리고 (잘보내질때) 큰파일을 보내면 이것또한 에러나던대 이것또한 왜이러는지... 역시 open부분에서 에러가 납니다.
일주일째 사경을 해매는중입니다.. ㅠㅠ
Forums:
음 ..
서버와 클라이언트 간에는 내가 정확히 전송한 만큼 수신했는지가 보장되어야 합니다.
그걸 서로 미리 약속해 놓은 걸 프로토콜이라고 부르죠.
프로토콜이 안 맞거나 서로 다른 프로토콜을 쓰면 둘 사이에 통신이 되지 않습니다.
client 쪽에서는 send(sock_cli, argv[3], file_name_len, 0); 와 같이 file_name_len 만큼만 데이터를 전송하도록 해놨지만..
server 쪽에서는 read(acc_sock, buf, MAXBUF); 와 같이 무조건 MAXBUF 만큼 읽어들이도록 되어 있습니다.
서로 프로토콜이 맞지 않는거죠.
만약 클라이언트 쪽에서 file_name 을 전송한 후에, 그 다음 파일의 내용을 보낼 때 약간의 delay 가 있었다면..
서버쪽에서는 MAXBUF 만큼 데이터를 읽으려고 시도하다가, 소켓 버퍼에 file_name 만 들어 있으니..
일단은 file_name 만 읽어 들이고 리턴해서.. 정상적으로 동작하는 것 처럼 보였을 겁니다.
그런데 운이 나빠(?) file_name 와 파일 내용이 모두 소켓 버퍼에 들어 있었다면..
서버는 MAXBUF 만큼 읽어들인 후 리턴했을 테니, 파일명과 파일 내용이 혼합되어 있는 것처럼 보이겠죠.
클라이언트에서 몇 번에 나눠서 보냈든지 간에, 서버의 소켓 버퍼에는 보낸 데이터들이 모두 한 줄로 늘어서 있다고 가정하고, 코드를 다시 작성해 보세요.
어디까지가 file_name 이고, 어디서부터 파일 내용으로 간주해야 할 지 조금 생각이 필요할 겁니다.
되면 한다! / feel no sorrow, feel no pain, feel no hurt, there's nothing gained.. only love will then remain.. 『 Mizz 』
감사합니다 새로운걸 배웠네요
여러번 시도해봐야겠지만 일단 큰파일도 넘어가고 아까같은 에러는 없습니다
댓글 달기