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 16:33 | Zajímavý projekt

    Patchouli je open source implementace EMR grafického tabletu (polohovací zařízení). Projekt je hostován na GitLabu.

    Ladislav Hagara | Komentářů: 0
    dnes 14:11 | IT novinky

    Český Nejvyšší soud potvrdil, že česká právní úprava plošného uchování dat o elektronické komunikaci porušuje právo Evropské unie. Pravomocným rozsudkem zamítl dovolání ministerstva průmyslu a obchodu. To se teď musí omluvit novináři Českého rozhlasu Janu Cibulkovi za zásah do práv na ochranu soukromí a osobních údajů. Ve sporu jde o povinnost provozovatelů sítí uchovávat údaje, ze kterých lze odvodit, kdo, s kým a odkud komunikoval.

    Ladislav Hagara | Komentářů: 2
    dnes 02:11 | Komunita

    Google bude vydávat zdrojové kódy Androidu pouze dvakrát ročně. Ve 2. a 4. čtvrtletí.

    Ladislav Hagara | Komentářů: 0
    včera 17:22 | Zajímavý článek

    Bezpečnostní specialista Graham Helton z Low Orbit Security si všímá podezřelých anomálií v BGP, zaznamenaných krátce před vstupem ozbrojených sil USA na území Venezuely, které tam během bleskové speciální vojenské operace úspěšně zatkly venezuelského diktátora Madura za narkoterorismus. BGP (Border Gateway Protocol) je 'dynamický směrovací protokol, který umožňuje routerům automaticky reagovat na změny topologie počítačové sítě' a je v bezpečnostních kruzích znám jako 'notoricky nezabezpečený'.

    NUKE GAZA! 🎆 | Komentářů: 7
    včera 06:11 | Nová verze

    Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu dosáhl 3,58 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 26,32 %. Procesor AMD používá 67,43 % hráčů na Linuxu.

    Ladislav Hagara | Komentářů: 1
    včera 05:55 | IT novinky

    V Las Vegas probíhá veletrh CES (Consumer Electronics Show, Wikipedie). Firmy představují své novinky. Například LEGO představilo systém LEGO SMART Play: chytré kostky SMART Brick, dlaždičky SMART Tagy a SMART minifigurky. Kostka SMART Brick dokáže rozpoznat přítomnost SMART Tagů a SMART minifigurek, které se nacházejí v její blízkosti. Ty kostku SMART Brick aktivují a určí, co má dělat.

    Ladislav Hagara | Komentářů: 0
    6.1. 18:33 | Bezpečnostní upozornění

    Vládní CERT (GovCERT.CZ) upozorňuje (𝕏) na kritickou zranitelnost v jsPDF, CVE-2025-68428. Tato zranitelnost umožňuje neautentizovaným vzdáleným útočníkům číst libovolné soubory z lokálního souborového systému serveru při použití jsPDF v prostředí Node.js. Problém vzniká kvůli nedostatečné validaci vstupu u cest k souborům předávaných několika metodám jsPDF. Útočník může zneužít tuto chybu k exfiltraci citlivých

    … více »
    Ladislav Hagara | Komentářů: 6
    6.1. 16:22 | Komunita

    V úterý 13. ledna 2025 se v pražské kanceláři SUSE v Karlíně uskuteční 5. Mobile Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj a související infrastrukturu. Akci pořádá David Heidelberg.

    … více »
    lkocman | Komentářů: 0
    6.1. 16:00 | Pozvánky

    Už je 14 dní zbývá do začátku osmého ročníku komunitního setkání nejen českých a slovenských správců sítí CSNOG 2026. Registrace na akci je stále otevřená, ale termín uzávěrky se blíží. I proto organizátoři doporučují, aby se zájemci přihlásili brzy, nejlépe ještě tento týden.

    … více »
    VSladek | Komentářů: 0
    6.1. 02:22 | Pozvánky

    Rok 2026 sotva začal, ale už v prvním týdnu se nashromáždilo nezvykle mnoho zajímavostí, událostí a zpráv. Jedno je ale jisté - už ve středu se koná Virtuální Bastlírna - online setkání techniků, bastlířů a ajťáků, kam rozhodně doražte, ideálně s mikrofonem a kamerou a zapojte se do diskuze o zajímavých technických tématech.

    Dějí se i ne zcela šťastné věci – zdražování a nedostupnost RAM a SSD, nedostatek waferů, 3€ clo na každou položku z Číny … více »
    bkralik | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (1%)
     (4%)
     (0%)
     (10%)
     (23%)
     (5%)
     (5%)
     (3%)
     (11%)
     (53%)
    Celkem 278 hlasů
     Komentářů: 7, poslední dnes 15:35
    Rozcestník

    Dotaz: UDP a prijímanie broadcastu

    11.12.2006 07:22 thefox | skóre: 25 | Ťapešovo
    UDP a prijímanie broadcastu
    Přečteno: 381×
    Zdravím,

    Je to na semestrálku. Ak vás zaujíma, prečo to aj tak posielam sem, skrollnite dole.

    Problém: neviem prijať UDP broadcast. Mám 2 programy - server a klient. Klient posiela na port 64000 (to je vlastne jedno) a adresu 255.255.255.255 nejaké dáta. Server číta z portu 64000 (rovnaký ako ten, kde posiela klient) dáta, no žiadne neprečíta.

    Keď klient posiela dáta ako unicast, server ich bez problému prečíta. Neviem, kde robím chybu, bude to nejaká prkotina, dúfam, že niekto bude vedieť (uvítam čokoľvek od polopatistickej rady cez linky na vhodné tutorialy/HOWTO/články až po rébusy (pokiaľ budú zábavné a nezabijú celý deň)) :-).

    Zdrojáky: Klient
    #include <stdio.h>
    #include <sys/socket.h>
    #include <sys/types.h>
    #include <arpa/inet.h>
    #include <unistd.h>
    #include <string.h>
    
    int main() {
    	int sock;
    	struct sockaddr_in remoteaddr;
    	char buffer[] = "Hello, world!"; // text, ktorý posielame
    	int result;
    	int enable;
    
    	// vytvoríme si soket
    	sock = socket(PF_INET, SOCK_DGRAM, 0); 
    
    	if (sock == -1) { perror("socket()"); return(1); }
    
    	// povolíme posielanie broadcast paketov
    	result = setsockopt(sock, SOL_SOCKET, SO_BROADCAST, &enable, sizeof(enable));
    	
    	if (result == -1) { perror("setsockopt()"); close(sock); return(1); }
    
    	// do remoteaddr vložíme IP:PORT prijímateľa
    	remoteaddr.sin_family = AF_INET;
    	remoteaddr.sin_port = htons(64000);
    	remoteaddr.sin_addr.s_addr = inet_addr("255.255.255.255");
    	// keď adresu na riadku vyššie zmením na unicast, server segment bez problému prijme
    
    	// paket odošleme
    	result = sendto(sock, buffer, strlen(buffer), 0, (struct sockaddr *) &remoteaddr, sizeof(remoteaddr));
    
    	if (result == -1) { perror("sendto()"); close(sock); return(1); }
    
    	// uzavrieme soket
    	close(sock);
    	return(0);
    }
    
    server
    #include <stdio.h>
    #include <sys/socket.h>
    #include <sys/types.h>
    #include <arpa/inet.h>
    #include <unistd.h>
    
    int main() {
    	int sock;
    	char buffer[100]; // buffer do ktorého budeme čítať dáta
    	struct sockaddr_in localaddr;
    	struct sockaddr_in source;
    	int source_size;
    	int result;
    
    	// vytvoríme si soket
    	sock = socket(PF_INET, SOCK_DGRAM, 0);
    	
    	if (sock == -1) { perror("socket()"); return(1); }
    
    	// do localaddr vložíme adresu, na ktorú si nabind()ujeme soket
    	localaddr.sin_family = AF_INET;
    	localaddr.sin_port = htons(64000);
    	localaddr.sin_addr.s_addr = inet_addr("0.0.0.0");
    
    	// a vykonáme samotný bind()
    	result = bind(sock, (struct sockaddr *) &localaddr, sizeof(localaddr));
    
    	if (result == -1) { perror("bind()"); close(sock); return(1); }
    
    	// tu sa prijímajú dáta zo siete. Chceme zistiť aj adresu odosielateľa, preto ten
    	// cirkus s source (bez toho to tiež nefunguje)
    	source_size = sizeof(source);
    	
    	recvfrom(sock, buffer, sizeof(buffer), 0, (struct sockaddr *) &source, &source_size);
    	printf("got something: %s\n", buffer);  // viem, že dáta v buffer nie sú null-terminated
    						// to sa ošetrí neskôr
    	close(sock);
    	return(0);
    }
    
    Vykonať niektoré kúsky so setsockopt() v procese servera som skúšal, nepomohlo (aj keď netvrdím, že viem, čo som mal robiť).
    Prečo sa pýtam tu?

    • Pretože už začínam byť bezradný, neprečítal som jednu vygooglenú/manuálovú stránku, uvedomujem si, že asi robím len nejakú fundamentálnu triviálnu chybu, no neviem, akú.
    • Tu na abclinuxu sa nájde dosť veľa sieťových expertov, ktorí možno zbadajú chybu na prvý pohľad a dnešný večer by som strávil robením ostatných vecí :-).

    0118 999 881 999 119 725 3

    Odpovědi

    11.12.2006 12:33 Jirka Chráska
    Rozbalit Rozbalit vše Re: UDP a prijímanie broadcastu
    Dobrý den,

    je potřeba nastavit na socketu, že má reagovat na broadcasty pomocí setsockopt(). Najdete to třeba v knize Advanced Programming in the UNIX Environment 2. vydání W. Richard Stevens, Stephen A. Rago; str. 579-581.
    Zde je opravený a otestovaný server.

    // server.c
    #include <stdio.h>
    #include <sys/socket.h>
    #include <sys/types.h>
    #include <arpa/inet.h>
    #include <unistd.h>
    
    int main() 
    {
    int sock;
    char buffer[100]; // buffer do ktorého budeme èíta» dáta
    struct sockaddr_in localaddr;
    struct sockaddr_in source;
    int source_size;
    int result;
    int broadcast = 1;
    int n;
    // vytvoríme si soket
    sock = socket(PF_INET, SOCK_DGRAM, 0);
    
    if (sock == -1) { perror("socket()"); return(1); }
    // volby pro socket - prijimame broadcast
    if ( setsockopt( sock, SOL_SOCKET, SO_BROADCAST, &broadcast, sizeof(int) ) < 0 ) 
    { 
    perror("setsockopt()"); 
    } 
    
    // do localaddr vloŸíme adresu, na ktorú si nabind()ujeme soket
    localaddr.sin_family = AF_INET;
    localaddr.sin_port = htons(64000);
    localaddr.sin_addr.s_addr = inet_addr("0.0.0.0");
    
    // a vykonáme samotný bind()
    result = bind(sock, (struct sockaddr *) &localaddr, sizeof(localaddr));
    
    if (result == -1) { perror("bind()"); close(sock); return(1); }
    
    // tu sa prijímajú dáta zo siete. Chceme zisti» aj adresu odosielateµa, preto ten
    // cirkus s source (bez toho to tieŸ nefunguje)
    source_size = sizeof(source);
    
    n=recvfrom(sock, buffer, sizeof(buffer), 0, (struct sockaddr *) &source, &source_size);
    if( n > 0 && n <100 ) {
        buffer[n] = '\0';
        printf("got something: %s\n", buffer);  
        }
    // to sa o¹etrí neskôr
    close(sock);
    return(0);
    }
    
    

    11.12.2006 17:46 thefox | skóre: 25 | Ťapešovo
    Rozbalit Rozbalit vše Re: UDP a prijímanie broadcastu
    Zdravím,

    ak je toto otestovaný server, ktorý reaguje na správy odoslané klientom, ktorého som tu napísal, tak bude chyba niekde v mojej konfigurácii. Presne toto som skúšal niekoľkokrát a nepomohlo, ani konkrétne tento zdrojový kód nič nevypíše, keď spustím klienta.

    Neviete náhodou, čím by to mohlo byť?
    0118 999 881 999 119 725 3
    11.12.2006 18:05 thefox | skóre: 25 | Ťapešovo
    Rozbalit Rozbalit vše Re: UDP a prijímanie broadcastu
    /me is banging his head against a nearby wall.

    Hint pre ostatných: povoľte to vo firewalli.

    PEBKAC vládne a je chladný.
    0118 999 881 999 119 725 3
    11.12.2006 18:15 Jirka Chráska
    Rozbalit Rozbalit vše Re: UDP a prijímanie broadcastu
    Já jsem to zkoušel na dvou vnitřních strojích, které pochopitelně žádný firewall nemají. Hlavně, že jste tu malou zákeřnou bestii odhalil a zlikvidoval.

    Pěkný den.

    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.