Wie trenne ich eine OpenVPN -Verbindung programmgesteuert?
Frage
Ich erstelle eine WinForms -Anwendung, um eine OpenVPN -Verbindung unter Windows zu starten und zu stoppen. Ich versuche, die gleiche Funktionalität wie OpenVPN -GUI für Windows zu erreichen (http://openvpn.se/) bietet aber meine eigene .NET -basierte Benutzeroberfläche.
Ich beginne die Verbindung mit dem folgenden Ansatz:
Process openVpnProcess = new Process();
openVpnProcess.StartInfo.CreateNoWindow = true;
openVpnProcess.EnableRaisingEvents = true;
openVpnProcess.StartInfo.Arguments = "--config client.ovpn";
openVpnProcess.StartInfo.FileName = "openvpn.exe";
openVpnProcess.StartInfo.WorkingDirectory = @"C:\Program Files\OpenVPN\config";
openVpnProcess.Start();
Dies ruft OpenVPN.exe auf und die Verbindung wird erfolgreich hergestellt.
Ich kann jedoch keine Möglichkeit bestimmen, die Verbindung nach dem Herstellen von Verknüpfungen zu beenden. Ich habe versucht, Process.kill () zu verwenden
foreach (var p in Process.GetProcessesByName("openvpn"))
{
p.Kill();
}
Dies tötet den Prozess ab, stellt jedoch den anfänglichen Routing -Status nicht wieder her. Effektiv kann ich nicht auf das Netzwerk zugreifen, wenn ich meine LAN -Karte manuell deaktiviere/aktiviere.
Ausgabe von 'OpenVPN --how-net', bevor die VPN-Verbindung hergestellt wird:
SYSTEM ROUTING TABLE
0.0.0.0 0.0.0.0 10.31.0.254 p=0 i=1376258 t=4 pr=3 a=21 h=0 m=1/-1/-1/-1/-1
10.31.0.0 255.255.240.0 10.31.10.235 p=0 i=1376258 t=3 pr=2 a=26 h=0 m=20/-1/-1/-1/-1
10.31.10.235 255.255.255.255 127.0.0.1 p=0 i=1 t=3 pr=2 a=26 h=0 m=20/-1/-1/-1/-1
10.255.255.255 255.255.255.255 10.31.10.235 p=0 i=1376258 t=3 pr=2 a=26 h=0 m=20/-1/-1/-1/-1
127.0.0.0 255.0.0.0 127.0.0.1 p=0 i=1 t=3 pr=2 a=116753 h=0 m=1/-1/-1/-1/-1
224.0.0.0 240.0.0.0 10.31.10.235 p=0 i=1376258 t=3 pr=2 a=26 h=0 m=20/-1/-1/-1/-1
255.255.255.255 255.255.255.255 10.31.10.235 p=0 i=1376258 t=3 pr=2 a=26 h=0 m=1/-1/-1/-1/-1
255.255.255.255 255.255.255.255 10.31.10.235 p=0 i=1441796 t=3 pr=2 a=4 h=0 m=1/-1/-1/-1/-1
SYSTEM ADAPTER LIST
TAP-Win32 Adapter V8
Index = 1441796
GUID = {013AB57F-DFE6-4FD9-B25E-9589E77DA4EB}
IP = 0.0.0.0/0.0.0.0
MAC = 00:ff:01:3a:b5:7f
GATEWAY =
DHCP SERV = 172.16.0.0
DHCP LEASE OBTAINED = Tue Jul 07 16:35:20 2009
DHCP LEASE EXPIRES = Wed Jul 07 16:35:20 2010
D-Link DFE-538TX 10/100 Adapter
Index = 1376258
GUID = {FB6051A1-E970-4F46-BB85-F442A194BA3D}
IP = 10.31.10.235/255.255.240.0
MAC = 00:08:a1:65:70:93
GATEWAY = 10.31.0.254/0.0.0.0
"OpenVPN --show-net" nach der VPN-Verbindung wurde mit Process.kill () geschlossen:
SYSTEM ROUTING TABLE
10.31.0.0 255.255.240.0 10.31.10.235 p=0 i=1376258 t=3 pr=2 a=106 h=0 m=20/-1/-1/-1/-1
10.31.10.235 255.255.255.255 127.0.0.1 p=0 i=1 t=3 pr=2 a=106 h=0 m=20/-1/-1/-1/-1
10.255.255.255 255.255.255.255 10.31.10.235 p=0 i=1376258 t=3 pr=2 a=106 h=0 m=20/-1/-1/-1/-1
127.0.0.0 255.0.0.0 127.0.0.1 p=0 i=1 t=3 pr=2 a=116833 h=0 m=1/-1/-1/-1/-1
208.94.64.10 255.255.255.255 10.31.0.254 p=0 i=1376258 t=4 pr=3 a=21 h=0 m=1/-1/-1/-1/-1
224.0.0.0 240.0.0.0 10.31.10.235 p=0 i=1376258 t=3 pr=2 a=106 h=0 m=20/-1/-1/-1/-1
255.255.255.255 255.255.255.255 10.31.10.235 p=0 i=1376258 t=3 pr=2 a=106 h=0 m=1/-1/-1/-1/-1
255.255.255.255 255.255.255.255 10.31.10.235 p=0 i=1441796 t=3 pr=2 a=84 h=0 m=1/-1/-1/-1/-1
SYSTEM ADAPTER LIST
TAP-Win32 Adapter V8
Index = 1441796
GUID = {013AB57F-DFE6-4FD9-B25E-9589E77DA4EB}
IP = 0.0.0.0/0.0.0.0
MAC = 00:ff:01:3a:b5:7f
GATEWAY =
DHCP SERV = 172.16.0.0
DHCP LEASE OBTAINED = Tue Jul 07 17:02:30 2009
DHCP LEASE EXPIRES = Wed Jul 07 17:02:30 2010
D-Link DFE-538TX 10/100 Adapter
Index = 1376258
GUID = {FB6051A1-E970-4F46-BB85-F442A194BA3D}
IP = 10.31.10.235/255.255.240.0
MAC = 00:08:a1:65:70:93
GATEWAY =
Ich habe auch versucht, den Prozess zu senden WM_CLOSE / WM_QUIT / WM_ENDMESSAGE
Nachrichten, aber diese haben kein Ergebnis erzielt.
const int WM_CLOSE = 0x10;
const int WM_QUIT = 0x12;
const int WM_ENDSESSION = 0x0016;
[DllImport("user32.dll")]
public static extern int SendMessage(int hwnd, int msg, int wparam, int lparam);
foreach (var p in Process.GetProcessesByName("openvpn"))
{
SendMessage(p.Handle.ToInt32(), WM_CLOSE, 0, 0);
SendMessage(p.Handle.ToInt32(), WM_QUIT, 0, 0);
SendMessage(p.Handle.ToInt32(), WM_ENDSESSION, 0, 0);
}
Weitere Informationen zur entsprechenden Lösung: Siehe Anweisungen im Abschnitt mit dem Titel " Verwenden der Verwaltungsschnittstelle in Kontrolle eines laufenden OpenVPN -Prozesss.
Weitere Informationen zur Verwendung Telnet aus C#.
Lösung
Ich habe dies nicht unter Windows ausprobiert, aber Sie können die verwenden OpenVPN -Verwaltungsschnittstelle zu senden a SIGTERM
Signal mit dem signal
Befehl. Sie müssen die Konfigurationseinträge für Verwaltungsschnittstellen natürlich in Ihre Konfigurationsdatei aufnehmen.
Weitere Informationen in der OpenVPN Man Page
Möglicherweise möchten Sie den Weg betrachten Openvpn-admin macht Dinge. Es funktioniert unter Windows und Linux und entwickelt sich mit Mono.
Andere Tipps
Sie senden Nachrichten an den Prozesshandle - diese sind jedoch Fenster Nachrichten, deshalb müssen sie an a gesendet werden Fenster handhaben.
BEARBEITEN
Wenn Sie den Vorgang bereits erhalten haben, können Sie Folgendes ausprobieren:
foreach (var p in Process.GetProcessesByName("openvpn"))
{
p.CloseMainWindow();
}
oder
[DllImport("user32.dll")]
public static extern int SendMessage(IntPtr hwnd, int msg, int wparam, int lparam);
foreach (var p in Process.GetProcessesByName("openvpn"))
{
IntPtr hWnd = p.MainWindowHandle;
// Send message to hWnd (mind SendMessage's changed signature)
}