Возможно, при чтении из потокового сокета вы не получаете все байты, которые, как вы думаете, вы получаете. Затем вы пишете файл правильного размера, но только в начале файла будут содержаться какие-либо значимые данные.
Если вы используете TCP (потоковое соединение), когда вы идете читать из сокета в буфер (вы, вероятно, используете массив byte / char), вы получите только все байты, которые доступны в время звонка. Вызов функции чтения вернется немедленно, но буфер, в который записываются данные, будет заполнен только частично.
Чтобы это исправить, вам нужно проверить, сколько байтов было на самом деле прочитано из сокета (обычно вызов чтения вернет это число), а затем повторно считывать из сокета, пока у вас не будет всех байты вам нужны.
Обновление
Что касается вашего кода, то, безусловно, похоже, что вы делаете только один вызов recv()
и не проверяете, чтобы весь файл был передан. Вам нужно будет поместить это в цикл и непрерывно читать данные, пока вы не прочитаете столько, сколько хотите (в данном случае размер всего файла).
Вы также можете решить эту проблему на стороне отправителя. Даже если между вызовами на send
есть команда режима сна, send
будет отправлять только определенное количество данных за вызов. Вам нужно будет поместить send
в цикл и продолжать отправлять данные, пока вы не отправите все данные, которые хотите отправить.
Рассмотрим следующий (непроверенный) псевдо-код для recv
:
int numberOfReceivedBytes=0;
while (numberOfReceivedBytes<fileSize){
numberOfReceivedBytes+=recv(newSocket,buffer + numberOfReceivedBytes,sizeof(*buffer),0)
}
Кроме того, похоже, что когда вы читаете размер файла из сокета, вы можете случайно получить часть самого файла в дополнение к размеру файла. Убедитесь, что вы точно знаете, сколько байтов будет указывать на фактический размер файла, и читайте только столько байтов. Кроме того, atoi
работает только для строкового (ASCII) представления числа. Ваш сервер получает фактический номер.
Для отправки:
int numberOfSentBytes=0;
while (numberOfSentBytes<fileSize){
numberOfSentBytes+=send(newSocket,buffer+numberOfSentBytes,fileSize-numberOfSentBytes+1,0);
}