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 14:55 | Nová verze

    KiCad (Wikipedie), sada svobodných softwarových nástrojů pro počítačový návrh elektronických zařízení (EDA), byl vydán v nové major verzi 10.0.0 (𝕏). Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    dnes 13:22 | IT novinky

    Letošní Turingovou cenu (2025 ACM A.M. Turing Award, Nobelova cena informatiky) získali Charles H. Bennett a Gilles Brassard za základní přínosy do oboru kvantové informatiky, které převrátily pojetí bezpečné neprolomitelné komunikace a výpočetní techniky. Jejich protokol BB84 z roku 1984 umožnil fyzikálně zaručený bezpečný přenos šifrovacích klíčů, zatímco jejich práce o kvantové teleportaci položila teoretické základy pro budoucí kvantový internet. Jejich práce spojila fyziku s informatikou a ovlivnila celou generaci vědců.

    Ladislav Hagara | Komentářů: 3
    dnes 04:44 | Zajímavý článek

    Firefox 149 dostupný od 24. března přinese bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně (s CZ a SK se zatím nepočítá) a zobrazení dvou webových stránek vedle sebe v jednom panelu (split view). Firefox Labs 149 umožní přidat poznámky k panelům (tab notes, videoukázka).

    Ladislav Hagara | Komentářů: 2
    dnes 00:33 | Nová verze

    Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    dnes 00:11 | Zajímavý software

    Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.

    Ladislav Hagara | Komentářů: 5
    včera 19:22 | Nová verze

    GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.

    Ladislav Hagara | Komentářů: 0
    včera 04:00 | Bezpečnostní upozornění

    Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.

    Ladislav Hagara | Komentářů: 4
    včera 03:33 | Zajímavý software

    Nightingale je open-source karaoke aplikace, která z jakékoliv písničky lokálního alba (včetně videí) dokáže oddělit vokály, získat text a vše přehrát se synchronizací na úrovni jednotlivých slov a hodnocením intonace. Pro separaci vokálů využívá UVR Karaoke model s Demucs od Mety, texty písní stahuje z lrclib.net (LRCLIB), případně extrahuje pomocí whisperX, který rovněž využívá k načasování slov. V případě audiosouborů aplikace na

    … více »
    NUKE GAZA! 🎆 | Komentářů: 2
    18.3. 18:22 | Nová verze

    Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.

    Ladislav Hagara | Komentářů: 32
    18.3. 17:22 | Nová verze

    Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (11%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1119 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    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.