elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Trabajando con las ramas de git (tercera parte)


  Mostrar Mensajes
Páginas: [1]
1  Programación / Programación C/C++ / Re: ¿Socket cerrado? en: 22 Diciembre 2011, 14:03 pm
La primera idea ya la he puesto en práctica, pero nada. La segunda es demasiado enrevesada para lo que quiero hacer, pero gracias.

Os dejo el código que tengo y un resumen del problema:
Código
  1. #include <sys/socket.h>
  2. #include <arpa/inet.h>
  3. #include <stdio.h>
  4. #include <stdlib.h>
  5. #include <string.h>
  6. #include <time.h>
  7.  
  8. int sockfd, newsock;
  9.  
  10. int main (int argc, char *argv [])
  11. {
  12. printf ("Code 0.1 - Dealer 2011\n");
  13. if (argc != 2) { printf ("Use: %s <port>\n\n", argv [0]); return 1; }
  14.  
  15. int cont = 0;
  16. struct sockaddr_in client, host;
  17. char buffer [1024];
  18. int size=sizeof (client);
  19.  
  20. sockfd=socket (2, 1 ,  0);
  21. host.sin_family=AF_INET;
  22. host.sin_port=htons (atoi (argv [1]));
  23. host.sin_addr.s_addr=0;
  24. bind (sockfd, (struct sockaddr*)&host, sizeof (struct sockaddr));
  25. listen (sockfd, 1);
  26.  
  27. while (1)
  28. {
  29. newsock=accept (sockfd, (struct sockaddr*)&client, &size);
  30. printf ("Got connection from %s:%d\n", inet_ntoa (client.sin_addr), ntohs (client.sin_port));
  31.  
  32. while (cont != -1)
  33. {
  34. time_t now=time (0);
  35. struct tm *ahora;
  36. ahora=localtime ((const time_t*)&now);
  37. strftime (buffer, 1024, "%d/%m/%Y %H:%M:%S \n" , ahora);
  38. buffer [strlen (buffer)] = 0;
  39. cont=send (newsock, &buffer, strlen (buffer), 0);
  40. sleep (1);
  41. }
  42.  
  43. printf ("Finishing connection from %s:%d\n\n", inet_ntoa (client.sin_addr), ntohs (client.sin_port));
  44. close (newsock);
  45. }
  46. close (sockfd);
  47. return 0;
  48. }
  49.  
Código:
$ gcc -o serv serv.c
$ ./serv 31337
Code 0.1 - Dealer 2011
Got connection from 127.0.0.1:48677
$
$ gdb -q serv
Leyendo símbolos desde /home/juanra/Escritorio/serv...(no se encontraron símbolos de depuración)hecho.
(gdb) r 31337
Starting program: /home/juanra/Escritorio/serv 31337
Code 0.1 - Dealer 2011
Got connection from 127.0.0.1:48678

Program received signal SIGPIPE, Broken pipe.
0x0012d422 in __kernel_vsyscall ()
(gdb)
Código:
$ nc -vv 127.0.0.1 31337
Connection to 127.0.0.1 31337 port [tcp/*] succeeded!
22/12/2011 13:57:09
22/12/2011 13:57:10
22/12/2011 13:57:11
22/12/2011 13:57:12
22/12/2011 13:57:13
^C
$ nc -vv 127.0.0.1 31337
Connection to 127.0.0.1 31337 port [tcp/*] succeeded!
22/12/2011 13:57:33
22/12/2011 13:57:34
22/12/2011 13:57:35
22/12/2011 13:57:36
^C
$
A ver: El primer code es el código del servidor. El segundo es la terminal desde la que se ejecuta code. El tercero muestra los procesos de netcat, que se conecta al servidor corriendo en la segunda terminal, y que tras pocos segundos recibe una interrupción ^C para interrumpir la conexión. En el momento de la interrupción, la idea es que la segunda terminal (la del servidor) mostrase un mensaje diciendo que la conexión se ha finalizado. Ahora, el problema es que al cortar desde netcat la conexión, hay un error que nos muestra el GDB al correr el servidor desde el depurador. Dice que el error es por "broken pipe". Tras varias pruebas, he visto que el "error" se producía cuando se cortaba la conexión y la ejecución del programa llega a la revisión del while. ¿Por qué? ¿Alguna idea?
PS: Evidentemente, los dos programas (servidor y nc) corren a la vez. Un saludo. Dealer
2  Programación / Programación C/C++ / ¿Socket cerrado? en: 20 Diciembre 2011, 23:20 pm
¡Buenas de nuevo! Estaba haciendo probaturas con sockets en C, Linux, y se me ha ocurrido una pregunta.
¿Cómo puedo detectar que el cliente/host ha perdido la conexión? Pongo un ejemplo: Tengo un programa que se conecta a cierta IP con cierto puerto. Ahora, al conectarse, recibe datos del servidor. Si corto la conexión de este programa, ¿cómo puedo hacer que el servidor "reaccione"? Hay que tener en cuenta que el programa no envía datos, sólo recibe. ¿Qué se os ocurre?

Un saludo. Dealer.
3  Programación / Programación C/C++ / Re: [AYUDA] Programar un calculador de IVA en C++ en: 20 Diciembre 2011, 21:39 pm
Soy un novato en esto de la programación y después de leerme guias y cosas, me han propuesto crear (programar) algo, he pensado en esto del IVA (si es muy complejo para un principiante decidmelo porfavor)
Pues eso, me gustaria que me recomendarais alguna guia más para principiantes (podeis tratarme como nivel 0) y algun consejo o paso a seguir para empezar en esto.
PD: El programa que he de usar para la programación del mismo es: "Dev- C++"

Bueno, pues para empezar, para calcular el 18% de una cantidad no hace falta tener una guía. Segundo, infravalorarte no va a hacer que la gente diga "Ohh, que modesto! Vamos a ayudarle!". Una cosa es ser humilde y otra es infravalorarse a sí mismo. Tercero, considero que a programar se aprende programando, así que te dejo un código rápido y tú miras cómo funciona. Cuarto, lo siento pero lo voy a hacer en C, pero no creo tengas problemas a la hora de pasarlo a C++. Quinto, Dev-C++ utiliza gcc, así que puedes compilar el programa con gcc, no necesariamente con Dev-C++. Sexto, deja de usar Dev-C++. Es horrible.

Código
  1. #include <stdio.h>
  2.  
  3. int main ()
  4. {
  5. printf ("Introduzca un numero entero: ");
  6. float a; scanf ("%f", &a); a=a*1.18;
  7. printf ("El numero introducido +IVA es %f.\n\n", a);
  8. return 0;
  9. }
  10.  

Código:
$ gcc -o code code.c
$ ./code
Introduzca un numero entero: 12
El numero introducido +IVA es 14.1600000.

$

A partir de esto, puedes mejorarlo haciendo una función para esta tarea, pasando el entero por los argumentos de main... Hasta aquí la teoría, ahora toca poner en juego la creatividad. Un saludo. Dealer.
4  Programación / Programación C/C++ / Comenzando... en: 20 Diciembre 2011, 21:23 pm
Buenas noches! Para comenzar mi participación en este foro, les dejo esta función que hice el otro día en casita:

Código
  1. int fctrs (int n, int x [])
  2. {
  3. int a = n, i=1, cont=0;
  4. x [cont] = 1; cont++;
  5.  
  6. for (i=2; i < n; i++)
  7. while (a%i == 0) { a=a/i; x [cont] = i; cont++; }
  8. x [cont] = 0;
  9. return cont;
  10. }
  11.  

N es un entero a descomponer en números primos. X [] es un vector en el que se almacenan los factores primos de N. Devuelve un número entero que corresponde al número de factores primos que tiene este número. Es poco, pero llevo un tiempo sin programar absolutamente nada, y voy poco a poco. Además, hasta que los Reyes me traigan un pendrive nuevo no voy a poder programar al 100% :P (uso Guadalinex, y para algunas cosas necesito root :/).
Un saludo. Dealer.
Páginas: [1]
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines