Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Internet (https://www.clubdelphi.com/foros/forumdisplay.php?f=3)
-   -   problemas para averiguar el estado de la conexion (https://www.clubdelphi.com/foros/showthread.php?t=10672)

jorch_yr 26-05-2004 01:41:50

problemas para averiguar el estado de la conexion
 
HOLA!!!

De casualidad alguno save un buen metodo para averiguar el estado de la coneccion (conectado o desconectado).
Tengo conexion ADSL 256 por un modem Cisco 677 que se conecta a la placa de red y tengo Win98 y uso WinPoET.

Probe un monton de metodos y ninguno me dio un buen resultado..

Metodo 1:
usando URL.dll

function InetIsOffline(Flag: Integer): Boolean; stdcall; external 'URL.DLL';

Metodo 2:

Usando: WinInet

procedure TForm1.Button1Click(Sender: TObject);
var conectado:boolean;
begin
conectado:= internetgetconnectedstate(0,0);
label1.Visible:=true;

if conectado then
begin
label1.Caption:='SI';
end
else
begin
label1.Caption:='NO';
end;
end;

El problema que tengo con estos dos metodos es que me dice que estoy Conectado cuando en realidad estoy desconectado.

acertij022 26-05-2004 15:13:48

Código Delphi [-]
function InternetConnected:Boolean;
   function LocalIP:string;
   var
       phe : PHostEnt;
       pptr : PaPInAddr;
       Buffer : array [0..63] of char;
       I : Integer;
       GInitData : TWSADATA;
   begin
       WSAStartup($101, GInitData);
       Result := '';
       GetHostName(Buffer, SizeOf(Buffer));
       phe :=GetHostByName(buffer);
       if phe = nil then
       begin
          Exit;
       end;
       pptr := PaPInAddr(Phe^.h_addr_list);
       I := 0;
       while pptr^[i] <> nil do
       begin
          Application.ProcessMessages;
          result:=StrPas(inet_ntoa(pptr^[i]^));
          Inc(I);
       end;
       WSACleanup;
   end;
var
   S:string;
begin
   S:=Copy(LocalIP,1,3);
   Result:=(S < '255') and (S > '127');
end;


Esta funsión ami me funciona espero que te sea de utilidad

Amilius 27-05-2004 04:51:19

Buen código acertij022, de todas formas tal vez haciendo un "ping" a una direccion que sabemos que siempre estará activa como "www.microsoft.com". Si no está activa: no estás conectado. S sólo fallaría si cayera esa dirección, o sea en un día de fiesta mundial a sí que no importaría mucho. Lo malo es que no sería muy "inmediata" la cosa, un ping se toma su tiempo hasta desistir.

jachguate 27-05-2004 04:54:55

Creo que hacer ping a algunos servidores dará pocos resultados... sobre todo porque varios ataques del tipo DOS se han basado en echo, y muchas redes simplemente lo tienen deshabilitado e incluso filtrado en los firewalls.

Hasta luego.

;)

DarkByte 28-05-2004 08:17:45

El ICMP Flood Trata de un ataque DoS:Denial Of Service o Denegación de Servicio, basado en el consumo de internet que ocupa el obtener el ping y en procesas su respuesta, enviado (como todos los flood) constantemente pings para saturar el servidor.

Estoy seguro que Microsoft no envía reply o respuesta, y me acabo de cercionar ahora mismo de que es así, no lo envía. Microsoft no teme un ataque de una computadora, sino un ataque DDos o Distributed Denial of Service de un gusano que infecte computadoras e ataque cada una con un ICMP Flood (2.000 computadoras, por lo bajo de infección de un gusano nuevo, bajaría el rendimiento de sus servidores), estilo blaster (a diferencia que el blaste atacaba a SCO y que su ataque era Floodear mediante peticiones HTTP):


Jachgute, creí que debía aumentar la información, por si alguien duda de como, con un ping, se podía hacer daño.


La franja horaria es GMT +2. Ahora son las 13:26:04.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi