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í
×
    28.11. 18:55 | Humor

    Jak na webu co nejšíleněji zadávat datum? Jak to uživatelům co nejvíce znepříjemnit? V Bad UX World Cup 2025 (YouTube) se vybíraly ty nejšílenější UX návrhy. Vítězným návrhem se stal Perfect Date.

    Ladislav Hagara | Komentářů: 6
    28.11. 12:44 | Zajímavý software

    Společnost Collabora vydala (YouTube) na LibreOffice založený desktopový kancelářský balík Collabora Office. Pro Windows, macOS a Linux. Se stejným uživatelským rozhraním jako Collabora Online. Svůj desktopový kancelářský balík s rozhraním LibreOffice pojmenovala Collabora Office Classic.

    Ladislav Hagara | Komentářů: 5
    28.11. 12:00 | Nová verze

    Glen MacArthur vydal AV Linux (AVL) a MX Moksha (MXM) 25. S linuxovým jádrem Liquorix. AV Linux (Wikipedie) je linuxová distribuce optimalizována pro tvůrce audio a video obsahu. Nejnovější AV Linux vychází z MX Linuxu 25 a Debianu 13 Trixie. AV Linux přichází s desktopovým prostředím Enlightenment 0.27.1 a MX Moksha s prostředím Moksha 0.4.1 (fork Enlightenmentu).

    Ladislav Hagara | Komentářů: 0
    27.11. 17:55 | Nová verze

    Ubuntu pro testování nových verzí vydává měsíční snapshoty. Dnes vyšel 1. snapshot Ubuntu 26.04 LTS (Resolute Raccoon).

    Ladislav Hagara | Komentářů: 0
    27.11. 14:33 | IT novinky

    Zástupci členských států EU se včera shodli na návrhu, který má bojovat proti šíření materiálů na internetu zobrazujících sexuální zneužívání dětí. Nařízení známé pod zkratkou CSAM a přezdívané chat control mělo množství kritiků a dlouho nebyla pro jeho schválení dostatečná podpora. Pro schválení byla potřeba kvalifikovaná většina a dánské předsednictví v Radě EU se snažilo dosáhnout kompromisu. Návrh nakonec po dlouhých týdnech

    … více »
    Ladislav Hagara | Komentářů: 12
    27.11. 12:22 | Zajímavý software

    Britské herní studio Facepunch stojící za počítačovými hrami Garry's Mod a Rust uvolnilo svůj herní engine s&box (Wikipedie) jako open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT. Herní engine s&box je postavený nad proprietárním herním enginem Source 2 od společnosti Valve.

    Ladislav Hagara | Komentářů: 1
    27.11. 04:55 | Komunita

    Vývoj programovacího jazyka Zig byl přesunut z GitHubu na Codeberg. Sponzoring na Every.

    Ladislav Hagara | Komentářů: 6
    27.11. 04:44 | Komunita

    Stejně jako GNOME i KDE Plasma končí s X11. KDE Plasma 6.8 poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.

    Ladislav Hagara | Komentářů: 3
    26.11. 14:55 | IT novinky

    Poslanci Evropského parlamentu dnes vyzvali k výraznému zvýšení ochrany nezletilých na internetu, včetně zákazu vstupu na sociální sítě pro osoby mladší 16 let. Legislativně nezávazná zpráva, kterou dnes odsouhlasil Evropský parlament poměrem 493 hlasů pro ku 92 proti, kromě zavedení věkové hranice 16 let pro využívání sociálních sítí, platforem pro sdílení videí či společníků s umělou inteligencí (AI) vyzývá také k zákazu … více »

    Ladislav Hagara | Komentářů: 54
    26.11. 14:11 | Humor

    Doom v KiCadu nebo na osciloskopu? Žádný problém: KiDoom: Running DOOM on PCB Traces a ScopeDoom: DOOM on an Oscilloscope via Sound Card.

    Ladislav Hagara | Komentářů: 3
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (47%)
     (19%)
     (18%)
     (23%)
     (16%)
     (24%)
     (16%)
     (18%)
    Celkem 417 hlasů
     Komentářů: 17, poslední 19.11. 21:57
    Rozcestník

    Dotaz: Jednoduchy socket server

    12.5.2005 13:52 Elpin
    Jednoduchy socket server
    Přečteno: 318×
    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.