Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Romo, il robot aspirapolvere tutto trasparente
DJI Romo, il robot aspirapolvere tutto trasparente
Anche DJI entra nel panorama delle aziende che propongono una soluzione per la pulizia di casa, facendo leva sulla propria esperienza legata alla mappatura degli ambienti e all'evitamento di ostacoli maturata nel mondo dei droni. Romo è un robot preciso ed efficace, dal design decisamente originale e unico ma che richiede per questo un costo d'acquisto molto elevato
DJI Osmo Nano: la piccola fotocamera alla prova sul campo
DJI Osmo Nano: la piccola fotocamera alla prova sul campo
La nuova fotocamera compatta DJI spicca per l'abbinamento ideale tra le dimensioni ridotte e la qualità d'immagine. Può essere installata in punti di ripresa difficilmente utilizzabili con le tipiche action camera, grazie ad una struttura modulare con modulo ripresa e base con schermo che possono essere scollegati tra di loro. Un prodotto ideale per chi fa riprese sportive, da avere sempre tra le mani
FUJIFILM X-T30 III, la nuova mirrorless compatta
FUJIFILM X-T30 III, la nuova mirrorless compatta
FUJIFILM X-T30 III è la nuvoa fotocamera mirrorless pensata per chi si avvicina alla fotografia e ricerca una soluzione leggera e compatta, da avere sempre a disposizione ma che non porti a rinunce quanto a controllo dell'immagine.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-08-2004, 15:05   #1
emitrax
Junior Member
 
Iscritto dal: Aug 2004
Messaggi: 1
Network Programming: send/recv file

Salve gente... Non riesco a far andare queste funzioni che dovrebbero permettere l'invio e il ricevimento del file da parte di due client di chat.Qui il codice...

int recv_file(char *filename)
{
struct sockaddr_in my_struct, his_client;
FILE *fp;
int my_sock, nb, his_struct_size, n_try = 0;
char *filecrypt, buffer[SIZE_BUF];
struct timeval timeout; //struttura tempo per il timeout
fd_set read_fd;

/* Inizializza a zero l' fdset */
FD_ZERO( &read_fd );

/* Setto il timeout a 5 minuti */
timeout.tv_sec = 300; // secondi
timeout.tv_usec = 0; // microsendi

/* Creo il socket */
if( ( my_sock = socket(AF_INET, SOCK_STREAM, 0) ) < 0 )
{
message( "Bad socket" );
return 0;
}

/* Riempio la struttura sockaddr_in */
memset( &my_struct,0,sizeof(my_struct) );
my_struct.sin_family = AF_INET;
my_struct.sin_port = htons(DCC_PORT);

getpeername( sockt, (SA *) &his_client, &his_struct_size );
my_struct.sin_addr.s_addr = his_client.sin_addr.s_addr;

/* Crea il nome del file da ricevere */

filecrypt = (char *)malloc(strlen(filename) + EXST);
strcpy( filecrypt, filename );
strncat( filecrypt, ".cry" , 4);

if( (fp = fopen( filecrypt , "wb" )) == NULL )
{
message( "Error returned by fopen" );
return 0;
}

/* Mi connetto all'altro client per ricevere il file */
while(1)
{
/* Tenta di connettersi per 3 volte per un totale di 180 secondi*/
if( connect( my_sock, (SA *) &my_struct, sizeof(my_struct) ))
{
if( (errno = ECONNREFUSED) && (n_try <= 3) )
{
/* Aspetta 60 secondi prima di riprovare */
sleep(60);
n_try++;
continue;
}
else
{
message( "Error returned by connect " );
return 0;
}
}
else
break;
}

/* CONNESSO */

/* Ricevo il file */
for( ;; )
{
/* setta il bit di lettura */
FD_SET( my_sock, &read_fd );

/* La select azzera il bit se il socket non e' pronto in lettura */
if( (n_try = select( my_sock + 1, &read_fd, NULL, NULL, &timeout )) == -1 )
{
message( "Error returned by select");
return 0;
}

if( n_try )
{
if( FD_ISSET( my_sock, &read_fd ) )
{
nb = read( my_sock, buffer, sizeof(buffer));
fwrite( buffer, nb, 1, fp );
}
}
else
break; //Sono passati 5 minuti senza ricevere dati
}


/* Chiudo il file */
fclose(fp);

/* Decripta il file ricevuto */
// file_decrypt( filecrypt );

return 1;
}

/* invia il file collegandosi alla porta DCC_SEND */
int send_file(char *pathfile)
{
struct sockaddr_in my_struct;
char *file_to_send = NULL;
char buffer[SIZE_BUF];
FILE *fp;
int sock_fd, listen_fd, n = 0;
size_t len_buf;

/*Toglie lo /n finale */
pathfile[ strlen(pathfile) - 1 ] = '\' ;

/* Salta gli spazi */
while( isspace(pathfile[n]) )
n++;

/* Cripta il file */
// if( !file_crypt( &pathfile[n] ) )
// return 0;

/* Creo il socket */
if( ( listen_fd = socket(AF_INET, SOCK_STREAM, 0) ) < 0 )
{
message( "Bad socket" );
return 0;
}

/* Riempio la struttura sockaddr_in */
memset(&my_struct,0,sizeof(my_struct));
my_struct.sin_family = AF_INET;
my_struct.sin_port = htons( DCC_PORT );
my_struct.sin_addr.s_addr = htonl( INADDR_ANY );

/* Associo il socket alla struttura */
if( bind( listen_fd, (SA *) &my_struct, sizeof(my_struct) ) < 0 )
{
message( " Error returnd by bind " );
return 0;
}

/* Si mette in ascolto */
if( listen( listen_fd, 1 ) < 0 )
{
message( "Error returned by listen " );
return 0;
}

/* Aspetta una connessione ( in teoria potrebbe anche non rientrare ) */
if( (sock_fd = accept( listen_fd, (SA *) NULL, NULL ) ) < 0 )
{
message( "Error returned by accept " );
return 0;
}

/* CONNESSIONE RIUSCITA */

/* Chiudo il socket che era in ascolto */
close(listen_fd);

file_to_send = (char *)malloc(strlen(&pathfile[n]) + EXST);

strcpy(file_to_send, &pathfile[n]);
// strcat(file_to_send, ".cry");

/* Apre il file criptato */
if( (fp = fopen( file_to_send, "rb" ) ) == NULL )
{
message( " Error while reopening encrypted file " );
return 0;
}

/* Invia il file */
while( !feof(fp) )
{
len_buf = fread( buffer, SIZE_BUF, 1, fp );
write( sock_fd, buffer, len_buf );
}

/* Chiudo il file */
fclose(fp);

return 1;
}

In pratrica la connessione avviene..... ma il lato che invia sembra che stacchi immediatamente la connessione.Qualcuno puoi aiutarmi?! Spero che aver pastato tutto questo codice non sia un problema.

Regards
Emitrax

Ultima modifica di emitrax : 04-08-2004 alle 15:09.
emitrax è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Romo, il robot aspirapolvere tutto trasparente DJI Romo, il robot aspirapolvere tutto trasparen...
DJI Osmo Nano: la piccola fotocamera alla prova sul campo DJI Osmo Nano: la piccola fotocamera alla prova ...
FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
Oracle AI World 2025: l'IA cambia tutto, a partire dai dati Oracle AI World 2025: l'IA cambia tutto, a parti...
Micron e millisecondi: la piattaforma ServiceNow guida l'infrastruttura IT di Aston Martin F1 Micron e millisecondi: la piattaforma ServiceNow...
Final Fantasy 7 Remake Part 3: arrivano ...
Elon Musk vuole 1.000 miliardi: il consi...
Il pixel più piccolo al mondo: un...
Windows 11: le 5 opzioni che Microsoft n...
Cuffie wireless PlayStation PULSE Elite ...
Un milione di utenti mostra disagio su C...
Un datacenter sottomarino alimentato da ...
iOS 26.1: è in arrivo il backup a...
Xbox Next Gen, non chiamatela console: s...
.Next On Tour Italia: innovazione, sempl...
PS Plus novembre: svelato in anticipo il...
'Gli elettroni sono il nuovo petrolio': ...
Amazon freme, non ce la fa ad aspettare ...
Hisense HS2100 240W a soli 75,90€ su Ama...
Addio personal trainer: il coach via AI ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 13:31.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v