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 13:00 | IT novinky

    Americký provozovatel streamovací platformy Netflix odmítl zvýšit nabídku na převzetí filmových studií a streamovací divize konglomerátu Warner Bros. Discovery (WBD). Netflix to ve čtvrtek oznámil v tiskové zprávě. Jeho krok po několikaměsíčním boji o převzetí otevírá dveře k akvizici WBD mediální skupině Paramount Skydance, a to zhruba za 111 miliard dolarů (2,28 bilionu Kč).

    Ladislav Hagara | Komentářů: 2
    dnes 12:44 | IT novinky

    Americká společnosti Apple přesune část výroby svého malého stolního počítače Mac mini z Asie do Spojených států. Výroba v závodě v Houstonu by měla začít ještě v letošním roce, uvedla firma na svém webu. Apple také plánuje rozšířit svůj závod v Houstonu o nové školicí centrum pro pokročilou výrobu. V Houstonu by měly vzniknout tisíce nových pracovních míst.

    Ladislav Hagara | Komentářů: 8
    dnes 12:11 | Zajímavý článek

    Vědci Biotechnologické společnosti Cortical Labs vytvořili biopočítač nazvaný CL1, který využívá živé lidské mozkové buňky vypěstované z kmenových buněk na čipu. Po úspěchu se hrou PONG se ho nyní snaží naučit hrát DOOM. Neurony přijímají signály podle toho, co se ve hře děje, a jejich reakce jsou převáděny na akce jako pohyb nebo střelba. V tuto chvíli systém hraje velmi špatně, ale dokáže reagovat, trochu se učit a v reálném čase se hrou

    … více »
    karkar | Komentářů: 4
    dnes 01:55 | Nová verze Ladislav Hagara | Komentářů: 0
    včera 21:33 | Nová verze

    Ben Sturmfels oznámil vydání MediaGoblinu 0.15.0. Přehled novinek v poznámkách k vydání. MediaGoblin (Wikipedie) je svobodná multimediální publikační platforma a decentralizovaná alternativa ke službám jako Flickr, YouTube, SoundCloud atd. Ukázka například na LibrePlanet.

    Ladislav Hagara | Komentářů: 0
    včera 15:44 | Zajímavý software

    TerminalPhone (png) je skript v Bashi pro push-to-talk hlasovou a textovou komunikaci přes Tor využívající .onion adresy.

    Ladislav Hagara | Komentářů: 6
    včera 12:22 | IT novinky

    Před dvěma lety zavedli operátoři ochranu proti podvrženým hovorům, kdy volající falšuje čísla anebo se vydává za někoho jiného. Nyní v roce 2026 blokují operátoři díky nasazeným technologiím v průměru 3 miliony pokusů o podvodný hovor měsíčně (tzn., že k propojení na zákazníka vůbec nedojde). Ochrana před tzv. spoofingem je pro zákazníky a zákaznice všech tří operátorů zdarma, ať už jde o mobilní čísla nebo pevné linky.

    Ladislav Hagara | Komentářů: 10
    včera 03:44 | Komunita

    Společnost Meta (Facebook) předává React, React Native a související projekty jako JSX nadaci React Foundation patřící pod Linux Foundation. Zakládajícími členy React Foundation jsou Amazon, Callstack, Expo, Huawei, Meta, Microsoft, Software Mansion a Vercel.

    Ladislav Hagara | Komentářů: 3
    včera 01:22 | IT novinky

    Samsung na akci Galaxy Unpacked February 2026 (YouTube) představil své nové telefony Galaxy S26, S26+ a S26 Ultra a sluchátka Galaxy Buds4 a Buds4 Pro. Telefon Galaxy S26 Ultra má nový typ displeje (Privacy Display) chránící obsah na obrazovce před zvědavými pohledy (YouTube).

    Ladislav Hagara | Komentářů: 11
    včera 00:22 | Nová verze

    Byla vydána grafická knihovna Mesa 26.0.1 s podporou API OpenGL 4.6 a Vulkan 1.4. Je to první stabilní verze po 26.0.0, kde se novinky týkají mj. výkonu ray tracingu na GPU AMD a HoneyKrisp, implementace API Vulkan pro macOS.

    |🇵🇸 | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (6%)
     (0%)
     (11%)
     (27%)
     (2%)
     (5%)
     (2%)
     (13%)
     (26%)
    Celkem 968 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: 326×
    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.