Foro de elhacker.net

Programación => Programación C/C++ => Mensaje iniciado por: jorgedl en 3 Octubre 2018, 16:42 pm



Título: Envio mensaje por bloques en socket
Publicado por: jorgedl en 3 Octubre 2018, 16:42 pm
Hola, necesito enviar paquetes de datos por bloques a través de un socket. Yo tengo un puntero de tipo uchar con el mensaje completo, y una variable de tipo int con la longitud del mismo.
La conexión del socket ya la tengo hecha perfectamente, solo necesito una ayuda de como lograr ir enviando el mensaje por bloques de 1024 ya que estuve probando con varios ejemplos y con ninguno pude conseguirlo.

Algo así es lo que intento resolver:

BOOL enviarMensaje( UCHAR *sSndData, UINT16 ulSndDataLen)
{

   #define SEND_MAX_SIZE       1024   
   int handle=-1;
   short retVal =-1 ;
   int totalEnviados=0;

   handle=CrearSocket(sTCPAddress,ulTCPPort);
   timeout.tv_sec = 2; //segundos
   timeout.tv_usec = 100; //microsegundos
   setsockopt(handle,SOL_SOCKET,SO_RCVTIMEO,(char*)&timeout,sizeof(timeout));

   timeout.tv_sec = 2;
   timeout.tv_usec = 100;
   setsockopt(handle, SOL_SOCKET,SO_PKTRCVTIMEO,(char*)&timeout,sizeof(timeout));   

   if(handle >=0)
   {
      while(totalEnviados<ulSndDataLen){
         retVal = send(handle,sSndData,SEND_MAX_SIZE,0);
         totalEnviados+= retVal;
       }
       closesocket(handle);
   }
}

Agradezco cualquier ayuda al respecto
Saludos

Jorge


Título: Re: Envio mensaje por bloques en socket
Publicado por: OmarHack en 3 Octubre 2018, 17:52 pm
Los packetes se pueden partir en la transmisión, tcp lo permite. No lo puedes controlar. Tu propio ISP lo puede hacer. Sabiendo esto. Puede que te esté capando el SO.
El kernel te duplica el buffer para dejar sitio. Y también te pone limitaciones y te establece el tamaño por defecto en:
/proc/sys/net/core/wmem_default
/proc/sys/net/core/wmem_max
/proc/sys/net/ipv4/tcp_mem

Puedes cambiarle los valores con el editor de texto.

O usa SO_SNDBUFFORCE para ignorar el cap del OS en wmem_max.