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

Po téměř dvou letech byla vydána nová verze 4.0 linuxové distribuce Audiophile Linux (též AP-Linux-V4). Tato distribuce vychází z Arch Linuxu, používá systemd, správce oken Fluxbox a vlastní real-time jádro pro nižší latence. Z novinek můžeme jmenovat podporu nových procesorů Intel Skylake a Kaby Lake nebo možnost instalace vedle jiných OS na stejný disk. Pokud se zajímáte o přehrávání hudby v Linuxu, doporučuji návštěvu webu této

… více »
Blaazen | Komentářů: 0
včera 18:55 | Nová verze

Byla vydána nová stabilní verze 1.9 (1.9.818.44) webového prohlížeče Vivaldi (Wikipedie). Z novinek vývojáři zdůrazňují podporu nového vyhledávače Ecosia. Ten z příjmů z reklam podporuje výsadbu stromů po celém světě (YouTube). Nově lze přeskupovat ikonky rozšíření nebo řadit poznámky. Nejnovější Vivaldi je postaveno na Chromiu 58.0.3029.82.

Ladislav Hagara | Komentářů: 10
včera 17:00 | Nová verze

Byla vydána verze 3.7.0 svobodného systému pro správu obsahu (CMS) Joomla!. V oznámení o vydání (YouTube) se píše o 700 vylepšeních. Opraveno bylo také 8 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 0
včera 08:22 | Komunita

Grsecurity (Wikipedie) je sada bezpečnostních patchů pro linuxové jádro (porovnání se SELinuxem, AppArmorem a KSPP). Od září 2015 nejsou stabilní verze těchto patchů volně k dispozici. Dle včerejšího oznámení (FAQ) nejsou s okamžitou platností volně k dispozici už ani jejich testovací verze.

Ladislav Hagara | Komentářů: 43
26.4. 23:33 | Komunita

OpenBSD 6.1 vyšlo již 11. dubna. Po dvou týdnech byla vydána i oficiální píseň. Její název je Winter of 95 a k dispozici je ve formátech MP3 a OGG.

Ladislav Hagara | Komentářů: 0
26.4. 18:55 | Nová verze

Byla vydána verze 2017.1 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux. S vydáním verze 2016.1 se Kali Linux stal průběžně aktualizovanou distribucí. Aktualizovat jej lze pomocí příkazů "apt update; apt dist-upgrade; reboot".

Ladislav Hagara | Komentářů: 0
26.4. 18:22 | Nová verze

Po téměř pěti letech od vydání verze 2.00 byla vydána nová stabilní verze 2.02 systémového zavaděče GNU GRUB (GRand Unified Bootloader). Přehled novinek v souboru NEWS.

Ladislav Hagara | Komentářů: 16
26.4. 17:55 | Komunita

Vývojáři Debianu oznámili, že od 1. listopadu letošního roku nebudou jejich archivy dostupné pomocí protokolu FTP. Již v lednu oznámil ukončení podpory FTP kernel.org (The Linux Kernel Archives).

Ladislav Hagara | Komentářů: 28
26.4. 17:00 | Bezpečnostní upozornění

V oblíbeném webmailu postaveném na PHP SquirrelMail (Wikipedie) byla nalezena bezpečnostní chyba CVE-2017-7692, jež může být útočníkem zneužita ke spuštění libovolných příkazů a kompletnímu ovládnutí dotčeného serveru. Zranitelnost se týká pouze instancí, kde je pro transport používán Sendmail.

Ladislav Hagara | Komentářů: 3
26.4. 13:11 | Zajímavý článek

Soudní dvůr Evropské unie rozhodl (tisková zpráva) ve věci C-527/15: Prodej multimediálního přehrávače, který umožňuje zdarma a jednoduše zhlédnout na televizní obrazovce filmy protiprávně zpřístupněné na internetu, může představovat porušení autorského práva.

Ladislav Hagara | Komentářů: 32
Chystáte se pořídit CPU AMD Ryzen?
 (4%)
 (34%)
 (1%)
 (6%)
 (45%)
 (9%)
Celkem 334 hlasů
 Komentářů: 50, poslední včera 04:06
    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: 325×
    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.