abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 00:44 | Humor

    Nové verze webových prohlížečů Chrome a Firefox jsou vydávány každé 4 týdny. Aktuální verze Chrome je 145. Aktuální verze Firefoxu je 148. Od září přejde Chrome na dvoutýdenní cyklus vydávání. V kterém týdnu bude mít Chrome větší číslo verze než Firefox? 😀

    Ladislav Hagara | Komentářů: 0
    včera 21:55 | IT novinky Ladislav Hagara | Komentářů: 0
    včera 13:44 | Komunita

    Bylo spuštěno hlasování o přednáškách a workshopech pro letošní Installfest, jenž proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13.

    Ladislav Hagara | Komentářů: 1
    včera 04:33 | Nová verze

    Byla vydána (Mastodon, 𝕏) třetí RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 0
    2.3. 21:44 | IT novinky

    Apple představil iPhone 17e a iPad Air s čipem M4.

    Ladislav Hagara | Komentářů: 13
    2.3. 21:11 | Zajímavý software

    Byla vydána verze 1.0 editoru kódů Gram. Jedná se o fork editoru Zed bez telemetrie a umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    2.3. 20:33 | IT novinky

    Byla oznámena spolupráce GrapheneOS s Motorolou. Podrobnosti v tiskové zprávě. GrapheneOS (Wikpedie) je varianta Androidu zaměřující se na bezpečnost a soukromí.

    Ladislav Hagara | Komentářů: 0
    2.3. 02:22 | Nová verze

    Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu optimalizovaná pro jednodeskové počítače na platformě ARM a RISC-V, ke stažení ale také pro Intel a AMD, byl vydán ve verzi 26.2.1. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 0
    2.3. 02:11 | Komunita

    Volí se dvě místa v Radě openSUSE. Seznamte se se čtyřmi kandidáty. Členové projektu openSUSE mohou hlasovat od 1. do 8. března. Výsledky budou oznámeny 9. března.

    lkocman | Komentářů: 3
    1.3. 19:22 | IT novinky

    Společnost OpenAI uzavřela dohodu s americkým ministerstvem obrany o poskytování technologií umělé inteligence (AI) pro utajované sítě americké armády. Firma to oznámila několik hodin poté, co prezident Donald Trump nařídil vládě, aby přestala využívat služby společnosti Anthropic.

    Ladislav Hagara | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (6%)
     (0%)
     (11%)
     (27%)
     (2%)
     (5%)
     (1%)
     (13%)
     (25%)
    Celkem 1002 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: Jednoduchy socket server

    12.5.2005 13:52 Elpin
    Jednoduchy socket server
    Přečteno: 327×
    Potreboval bych poradit. Mam tenhleten C++ kod:
    int main( int argn, char **arg ) 
    { 
     int port = atoi( arg[ 1 ] ); 
    
     int sock_listen = socket( AF_INET, SOCK_STREAM, 0 ); 
    
     in_addr addr_any = { INADDR_ANY }; 
     sockaddr_in srv_addr; 
     srv_addr.sin_family = AF_INET; 
     srv_addr.sin_port = htons( port ); 
     srv_addr.sin_addr = addr_any; 
    
     // set socket options to reuse address and port again in short time 
     int opt = 1; 
     setsockopt( sock_listen, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof( opt ) ); 
    
     // assign address and port to socket 
     bind( sock_listen, (const sockaddr * ) &srv_addr, sizeof( srv_addr ) ); 
    
     listen( sock_listen, 1 ); 
    
     int sock_client = 0; 
    
     // go! 
     while ( 1 ) 
     { 
         char buf[ 100 ]; 
    
         fd_set read_wait_set; 
         // set all bits to zero 
         FD_ZERO( &read_wait_set ); 
    
         // wait for stdin 
         FD_SET( STDIN_FILENO, &read_wait_set ); 
    
         // select listen or client socket 
         if ( sock_client ) 
             FD_SET( sock_client, &read_wait_set ); 
         else 
             FD_SET( sock_listen, &read_wait_set ); 
    
         // wait for selected handles 
         if ( select( MAX( sock_client, sock_listen ) + 1, 
                              &read_wait_set, 0, 0, 0 ) < 0 ) break; 
    
         // data on stdin? 
         if ( FD_ISSET( STDIN_FILENO, &read_wait_set ) ) 
         { 
             //  read data from stdin 
             int l = read( STDIN_FILENO, buf, sizeof( buf ) ); 
             if ( l < 0 ) 
                 printf( "Unable to read data from stdin." ); 
             else 
                 printf( "Got %d bytes from stdin.", l ); 
    
             // send data to client 
             l = write( sock_client, buf, l ); 
             if ( l < 0 ) 
                 printf( "Unable send data to client." ); 
             else 
                 printf( "Sent %d bytes to client.", l ); 
         } 
    
         // new connection form client? 
         else if ( FD_ISSET( sock_listen, &read_wait_set ) ) 
         { 
             sockaddr_in rsa; 
             int rsa_size = sizeof( rsa ); 
    
             // accept connection from client 
             sock_client = accept( sock_listen, ( sockaddr * ) &rsa, ( socklen_t * ) &rsa_size ); 
    
             uint lsa = sizeof( srv_addr ); 
    
             // get my identification 
             getsockname( sock_client, ( sockaddr * ) &srv_addr, &lsa ); 
          
             // get client info 
             getpeername( sock_client, ( sockaddr * ) &srv_addr, &lsa ); 
    
             printf( "Peer name: '%s'  port: %d", 
                      inet_ntoa( srv_addr.sin_addr ), ntohs( srv_addr.sin_port ) ); 
    
             printf( "Enter 'quit' to quit server." ); 
         } 
    
         // data from client? 
         else if ( FD_ISSET( sock_client, &read_wait_set ) ) 
         { 
             // read data from socket 
             int l = read( sock_client, buf, sizeof( buf ) ); 
             if ( !l ) 
             { 
                 printf( "Client close socket." ); 
                 close( sock_client ); 
                 sock_client = 0; 
                 break; 
             } 
             else if ( l < 0 ) 
                 printf( "Unable to read data from socket." ); 
             else 
                 printf( "Read %d bytes from socket.", l ); 
    
             // send all data to stdout 
             l = write( STDOUT_FILENO, buf, l ); 
    
             // check, if client ask to close connection 
             if ( !strncasecmp( buf, "close", 5 ) ) 
             { 
                printf( "Client sent 'close' request, connection closed." ); 
                printf( "Now wait for new client." ); 
                 close( sock_client ); 
                 sock_client = 0; 
             } 
         } 
    
         // quit request from server or client 
         if ( !strncasecmp( buf, "quit", 4 ) ) 
         { 
             close( sock_client ); 
             printf( "Quit request entered... exiting now...\n" ); 
             break; 
         } 
     } 
    
     close( sock_listen ); 
    
     return 0; 
    } 
    
    Je to socket server. Prijima pripojeni od klientu a vypise do konzole zpravu, kterou klient napise. Ja bych prave potreboval aby server prijimal spojeni od nekolika klientu najednou a kdyz nejaky klient neco napise, server to vypise do konzole a kdyz neco napise server, vypisou to na svou konzoli vsichni klienti. Zatim jsem jen prisel na to, ze musim vlozit radek "int pid = fork()" do kodu za funkci accept() a nechat otcovsky proces at vyrizuje pripojeni a nechat potomka at dela zbytek, ale stale se mi to nedari! Mohli byste mi poradit? Byl bych vdecny za jakoukoliv pomoc. Predem diky.

    Odpovědi

    12.5.2005 15:38 miso
    Rozbalit Rozbalit vše Re: Jednoduchy socket server
    http://www.root.cz/clanky/sokety-a-c-funkce-poll-a-zaver/
    alebo hladaj funkciu select.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.