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í
×
včera 13:37 | Bezpečnostní upozornění

Společnost Cloudflare (Wikipedie) na svém blogu potvrdila bezpečnostní problém s její službou. V požadovaných odpovědích od reverzní proxy byla odesílána také data z neinicializované paměti. Útočník tak mohl získat cookies, autentizační tokeny, data posílaná přes HTTP POST a další citlivé informace. Jednalo se o chybu v parsování HTML. Zneužitelná byla od 22. září 2016 do 18. února 2017. Seznam webů, kterých se bezpečnostní problém potenciálně týká na GitHubu.

Ladislav Hagara | Komentářů: 1
včera 08:22 | Nová verze

Byla vydána první beta verze Ubuntu 17.04 s kódovým názvem Zesty Zapus. Ke stažení jsou obrazy Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu GNOME, Ubuntu Kylin, Ubuntu Studio a Xubuntu. Dle plánu by Ubuntu 17.04 mělo vyjít 13. dubna 2017.

Ladislav Hagara | Komentářů: 9
23.2. 17:53 | Bezpečnostní upozornění

Google na svém blogu věnovaném počítačové bezpečnost informuje o nalezení "reálného" způsobu generování kolizí hašovací funkce SHA-1. Podrobnosti a zdrojové kódy budou zveřejněny do 90 dnů. Již dnes lze ale na stránce SHAttered nalézt 2 pdf soubory, jejichž obsah se liší a SHA-1 otisk je stejný (infografika).

Ladislav Hagara | Komentářů: 25
23.2. 17:51 | Nová verze

Vyšla nová verzia open source software na správu a automatizáciu cloudových datacentier Danube Cloud 2.4. Danube Cloud je riešenie postavené na SmartOS, ZFS, KVM a zónach. Obsahuje vlastnosti ako integrovaný monitoring, DNS manažment, zálohy, a samozrejme rozsiahlu dokumentáciu.

dano | Komentářů: 6
23.2. 17:46 | Pozvánky

V Plzni se 3. až 5. března 2017 uskuteční AIMTEChackathon. Je to akce pro vývojáře, grafiky, webdesignéry i veřejnost. Akci provází zajímavé přednášky IT odborníků. Více o programu a možnosti přihlášení na stránkách akce.

cuba | Komentářů: 0
23.2. 01:00 | Nová verze

Známý šifrovaný komunikátor Signal od verze 3.30.0 již nevyžaduje Google Play Services. Autoři tak po letech vyslyšeli volání komunity, která dala vzniknout Google-free forku LibreSignal (dnes již neudržovaný). Oficiální binárky jsou stále distribuované pouze přes Google Play, ale lze použít neoficiální F-Droid repozitář fdroid.eutopia.cz s nezávislými buildy Signalu nebo oficiální binárku stáhnout z Google Play i bez Google účtu

… více »
xm | Komentářů: 7
22.2. 23:14 | Nová verze

Po třech týdnech od vydání první RC verze byla vydána první stabilní verze 17.01.0 linuxové distribuce pro routery a vestavěné systémy LEDE (Linux Embedded Development Environment), forku linuxové distribuce OpenWrt. Přehled novinek v poznámkách k vydání. Dotazy v diskusním fóru.

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

Byly zveřejněny informace o bezpečnostní chybě CVE-2017-6074 v Linuxu zneužitelné k lokální eskalaci práv. Jde o chybu v podpoře DCCP (Datagram Congestion Control Protocol). Do linuxového jádra se dostala v říjnu 2005. V upstreamu byla opravena 17. února (commit). Bezpečnostní chyba byla nalezena pomocí nástroje syzkaller [Hacker News].

Ladislav Hagara | Komentářů: 16
22.2. 15:00 | Zajímavý software

Společnost Valve vydala novou beta verzi SteamVR. Z novinek lze zdůraznit oficiální podporu Linuxu. Další informace o podpoře této platformy pro vývoj virtuální reality v Linuxu v diskusním fóru. Hlášení chyb na GitHubu.

Ladislav Hagara | Komentářů: 0
22.2. 06:00 | Nová verze

Po necelém roce od vydání verze 0.67 byla vydána verze 0.68 populárního telnet a ssh klienta PuTTY. Podrobnosti v přehledu změn. Řešeny jsou také bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 704 hlasů
 Komentářů: 66, poslední 22.2. 18:57
    Rozcestník

    Dotaz: Klient se pripoji k serveru a prijima a odesila data.

    26.5.2005 15:38 VytliNoha | skóre: 1
    Klient se pripoji k serveru a prijima a odesila data.
    Přečteno: 171×
    Zdravicko, progrmauji jednoduchecho klienta ktery se pripoji na server a posila nebo prijima data. Pro odeslani pouzivam send() a pro prijem recv() to cele v nekonecne smicce. Bez prijimani zprav od serveru klient data posila ale kdyz tam pridam recv() tak uz se to kousne po prijeti 1. zpravy od serveru je to tim ze porad ceka u fce recv() co prijde.. Mam to resit pomoci selectu nebo vlaken. Prosim poradte dekuji moc. Coucasny kod:
    
    
    #define BUFSIZE 100
    #define PORT 5555
    
    
    int main(int argc, char *argv[])
    {
        hostent *host;              // Vzdálený počítač;
        sockaddr_in serverSock;     // Vzdálený "konec potrubí"
        int mySocket;               // Soket
        char buf_in[BUFSIZE];          // Přijímací buffer
    	char buf_out[BUFSIZE];		// Odesilaci buffer
    	fd_set inputs, testfds;
        struct timeval timeout;
    	
    	
        // Zjistíme info o vzdáleném počítači
        if ((host = gethostbyname(argv[1])) == NULL)
        {
            printf("Špatná adresa\n");
            return -1;
        }
        // Vytvoříme soket
        if ((mySocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) == -1)
        {
            printf("Nelze vytvořit soket\n");
            return -1;
        }
        // Zaplníme strukturu sockaddr_in
        // 1) Rodina protokolů
        serverSock.sin_family = AF_INET;
        // 2) Číslo portu, ke kterému se připojíme
        serverSock.sin_port = htons(PORT);
        // 3) Nastavení IP adresy, ke které se připojíme
        memcpy(&(serverSock.sin_addr), host->h_addr, host->h_length);
        // Připojení soketu
        if (connect(mySocket, (sockaddr *)&serverSock, sizeof(serverSock)) == -1)
        {
    		printf("Nelze navázat spojení\n");
            return -1;
        }
        // Odeslání dat
    	while(1){
    		fgets(buf_out, BUFSIZE, stdin);
    		buf_out[strlen(buf_out)-1] = '\0';//odstraneni kone radky
    		if(strcmp(buf_out,"LOGOUT")!=0){
    			if (send(mySocket, buf_out, strlen(buf_out), 0) == -1)
        		{
            		printf("Problém s odesláním dat\n");
            		return -1;
        		}
    			// Příjem dat
    			
        		//if((size = recv(mySocket, buf_in, BUFSIZE, 0)) != -1) 
        		//{        
            	//	printf("Přijato: [%s]\n");
        		//}
    		}
    		else{
    			// odhlasime spojeni
    			close(mySocket);
    			exit(0);
    		}
    	}
    		printf("Odeslano\n");
        return 0;
    }
    

    Odpovědi

    Luboš Doležel (Doli) avatar 26.5.2005 16:46 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    Asi pomocí selectu - kdyby tam byla vlákna, tak by např. zatímco píšeš text na jedné straně ti mohl někdo poslat text z druhé strany a dělalo by to pořádný bordel na obrazovce.
    26.5.2005 17:07 VytliNoha | skóre: 1
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    Muzete mi rict co je na tom spatne, data to odesila ale neprijima od serveru. Dekuji moc
    
    #define BUFSIZE 100
    #define PORT 5555
    
    
    int main(int argc, char *argv[])
    {
        hostent *host;              // Vzdálený počítač;
        sockaddr_in serverSock;     // Vzdálený "konec potrubí"
        int mySocket;               // Soket
        char buf_in[BUFSIZE];          // Přijímací buffer
    	char buf_out[BUFSIZE];		// Odesilaci buffer
    	fd_set read, write;
    	
    	FD_ZERO(&read);
    	FD_ZERO(&write);
    
        // Zjistíme info o vzdáleném počítači
        if ((host = gethostbyname(argv[1])) == NULL)
        {
            printf("Špatná adresa\n");
            return -1;
        }
        // Vytvoříme soket
        if ((mySocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) == -1)
        {
            printf("Nelze vytvořit soket\n");
            return -1;
        }
    	else{
    		// Zaplnění množiny sokety
    		FD_SET(mySocket, &read);
    		FD_SET(STDIN_FILENO, &read);
    	}
        // Zaplníme strukturu sockaddr_in
        // 1) Rodina protokolů
        serverSock.sin_family = AF_INET;
        // 2) Číslo portu, ke kterému se připojíme
        serverSock.sin_port = htons(PORT);
        // 3) Nastavení IP adresy, ke které se připojíme
        memcpy(&(serverSock.sin_addr), host->h_addr, host->h_length);
        // Připojení soketu
        if (connect(mySocket, (sockaddr *)&serverSock, sizeof(serverSock)) == -1)
        {
    		printf("Nelze navázat spojení\n");
            return -1;
        }
    	// Zavolám select (V Linuxu musím mít nastavenou proměnnou max.)
    	int ret = select(2, &read, NULL, NULL, NULL);
    	
    	while(1){
    	    if (ret == -1){
    			perror("select()");
    		}
        	else if(ret){
    			// odeslam data
    			if(FD_ISSET(STDIN_FILENO, &read)){
    				fgets(buf_out, BUFSIZE, stdin);
    				buf_out[strlen(buf_out)-1] = '\0';//odstraneni kone radky
    				if(strcmp(buf_out,"LOGOUT")!=0){
    					if (send(mySocket, buf_out, strlen(buf_out), 0) == -1){
    		 				return -1;
    					}
    				}
    				else{
    					// odhlasime spojeni
    					close(mySocket);
    					exit(0);
    				}
    			}
    			//Příjem dat
    			else if(FD_ISSET(mySocket, &read)){
    				if(recv(mySocket, buf_in, BUFSIZE, 0) != -1) {
    					printf("Přijato: [%s]\n");
    				}
    			}
    		}
    	}
    		printf("Odeslano\n");
        return 0;
    }
    
    26.5.2005 17:13 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    // Zavolám select (V Linuxu musím mít nastavenou proměnnou max.)
    Tak si ji nastav... man select, číslo nejvyššího fd plus jedna.
    26.5.2005 17:35 VytliNoha | skóre: 1
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    jako treba na: int ret = select(3, &read, NULL, NULL, NULL); nebo int ret = select( MAX( STDIN_FILENO, mySocket ) + 1, &read, NULL, NULL, NULL);

    druhou variantu mi nechce kompilator zkompilovat"
    26.5.2005 19:22 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    Asi nemá makro MAX, nebo ti vypisuje nějakou jinou chybu
    select(STDIN_FILENO>mySocket ? STDIN_FILENO+1 : MySocket+1, ...
    
    jinak stdin je nula, takže to bude MySocket+1 :-)
    Josef Kufner avatar 26.5.2005 20:26 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    Nebylo by lepší použít makro FD_SETSIZE ?
    ... select(FD_SETSIZE, ...
    Hello world ! Segmentation fault (core dumped)
    26.5.2005 21:38 Voty
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    Mozna spatne koukam, ale rekl bych, ze ten select() by mel byt vevnitr toho nekonecnyho cyklu. Jinak je tam skoro na houby.
    26.5.2005 22:55 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    Nj, to jsem si nevšim :-)
    26.5.2005 23:42 VytliNoha | skóre: 1
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    Tak podle me to mam uplne podle vasich rad a stale to stejne neprijima data od serveru. Kdyz se na dany server pripojim tak data telnet dostava i prijima. Ale kdyz se pripojim pomoci tohoto klienta tak data pouze odesila .-( Nechcete to nekdo otestovat na vase Linuxcackovi

    soucasny kod:
    int main(int argc, char *argv[])
    {
        hostent *host;              // Vzdálený počítač;
        sockaddr_in serverSock;     // Vzdálený "konec potrubí"
        int mySocket;               // Soket
        char buf_in[BUFSIZE];          // Přijímací buffer
    	char buf_out[BUFSIZE];		// Odesilaci buffer
    	fd_set read, write;
    	
    	FD_ZERO(&read);
    	FD_ZERO(&write);
    
        // Zjistíme info o vzdáleném počítači
        if ((host = gethostbyname(argv[1])) == NULL)
        {
            printf("Špatná adresa\n");
            return -1;
        }
        // Vytvoříme soket
        if ((mySocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) == -1)
        {
            printf("Nelze vytvořit soket\n");
            return -1;
        }
    	else{
    		// Zaplnění množiny sokety
    		FD_SET(mySocket, &read);
    		FD_SET(STDIN_FILENO, &read);
    	}
        // Zaplníme strukturu sockaddr_in
        // 1) Rodina protokolů
        serverSock.sin_family = AF_INET;
        // 2) Číslo portu, ke kterému se připojíme
        serverSock.sin_port = htons(PORT);
        // 3) Nastavení IP adresy, ke které se připojíme
        memcpy(&(serverSock.sin_addr), host->h_addr, host->h_length);
        // Připojení soketu
        if (connect(mySocket, (sockaddr *)&serverSock, sizeof(serverSock)) == -1)
        {
    		printf("Nelze navázat spojení\n");
            return -1;
        }
    	while(1){
    		// Zavolám select (V Linuxu musím mít nastavenou proměnnou max.)
    		int ret = select(STDIN_FILENO > mySocket ? STDIN_FILENO+1 : mySocket+1, &read, NULL, NULL, NULL);
    		
    	    if (ret == -1){
    			perror("select()");
    		}
        	else if(ret){
    			// odeslam data
    			if(FD_ISSET(STDIN_FILENO, &read)){
    				fgets(buf_out, BUFSIZE, stdin);
    				buf_out[strlen(buf_out)-1] = '\0';//odstraneni kone radky
    				if(strcmp(buf_out,"LOGOUT")!=0){
    					if (send(mySocket, buf_out, strlen(buf_out), 0) == -1){
    		 				return -1;
    					}
    				}
    				else{
    					// odhlasime spojeni
    					close(mySocket);
    					exit(0);
    				}
    			}
    			//Příjem dat
    			else if(FD_ISSET(mySocket, &read)){
    				if(recv(mySocket, buf_in, BUFSIZE, 0) != -1) {
    					printf("Přijato: [%s]\n", buf_in);
    				}
    			}
    		}
    	}
    		printf("Odeslano\n");
        return 0;
    }
    
    26.5.2005 23:42 VytliNoha | skóre: 1
    Rozbalit Rozbalit vše Re: Klient se pripoji k serveru a prijima a odesila data.
    Tak podle me to mam uplne podle vasich rad a stale to stejne neprijima data od serveru. Kdyz se na dany server pripojim tak data telnet dostava i prijima. Ale kdyz se pripojim pomoci tohoto klienta tak data pouze odesila .-( Nechcete to nekdo otestovat na vase Linuxcackovi

    soucasny kod:
    int main(int argc, char *argv[])
    {
        hostent *host;              // Vzdálený počítač;
        sockaddr_in serverSock;     // Vzdálený "konec potrubí"
        int mySocket;               // Soket
        char buf_in[BUFSIZE];          // Přijímací buffer
    	char buf_out[BUFSIZE];		// Odesilaci buffer
    	fd_set read, write;
    	
    	FD_ZERO(&read);
    	FD_ZERO(&write);
    
        // Zjistíme info o vzdáleném počítači
        if ((host = gethostbyname(argv[1])) == NULL)
        {
            printf("Špatná adresa\n");
            return -1;
        }
        // Vytvoříme soket
        if ((mySocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) == -1)
        {
            printf("Nelze vytvořit soket\n");
            return -1;
        }
    	else{
    		// Zaplnění množiny sokety
    		FD_SET(mySocket, &read);
    		FD_SET(STDIN_FILENO, &read);
    	}
        // Zaplníme strukturu sockaddr_in
        // 1) Rodina protokolů
        serverSock.sin_family = AF_INET;
        // 2) Číslo portu, ke kterému se připojíme
        serverSock.sin_port = htons(PORT);
        // 3) Nastavení IP adresy, ke které se připojíme
        memcpy(&(serverSock.sin_addr), host->h_addr, host->h_length);
        // Připojení soketu
        if (connect(mySocket, (sockaddr *)&serverSock, sizeof(serverSock)) == -1)
        {
    		printf("Nelze navázat spojení\n");
            return -1;
        }
    	while(1){
    		// Zavolám select (V Linuxu musím mít nastavenou proměnnou max.)
    		int ret = select(STDIN_FILENO > mySocket ? STDIN_FILENO+1 : mySocket+1, &read, NULL, NULL, NULL);
    		
    	    if (ret == -1){
    			perror("select()");
    		}
        	else if(ret){
    			// odeslam data
    			if(FD_ISSET(STDIN_FILENO, &read)){
    				fgets(buf_out, BUFSIZE, stdin);
    				buf_out[strlen(buf_out)-1] = '\0';//odstraneni kone radky
    				if(strcmp(buf_out,"LOGOUT")!=0){
    					if (send(mySocket, buf_out, strlen(buf_out), 0) == -1){
    		 				return -1;
    					}
    				}
    				else{
    					// odhlasime spojeni
    					close(mySocket);
    					exit(0);
    				}
    			}
    			//Příjem dat
    			else if(FD_ISSET(mySocket, &read)){
    				if(recv(mySocket, buf_in, BUFSIZE, 0) != -1) {
    					printf("Přijato: [%s]\n", buf_in);
    				}
    			}
    		}
    	}
    		printf("Odeslano\n");
        return 0;
    }
    

    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.