Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

PHP Post Data Over VPN

I need to connect to a webservice which is behind of a VPN via PHP. My server is Debian Linux (Squeeze).

  1. Is it possible to accomplish this via PHP on Linux?
  2. Is it risky to do this if it is possible? (When VPN connection hangs etc., does the operating system or any other what-so-over handles the situation)
  3. I have only one network card, therefore I really wonder whether it is possible to keep server online for normal users while "posting data over an accomplished VPN connection in the background".

Although my question seems to a conceptual question, any specific help is also welcome.

Server OS : Debian Linux Squeeze (x64)
Web Server : Apache HTTP
PHP Version: 5.3
Framework: Symfony 1.4

like image 373
Lashae Avatar asked Aug 03 '12 15:08

Lashae


2 Answers

VPNs are at a network layer below PHP, PHP won't know or care that the connection is over a VPN or a normal connection. It's handled by the network stack.

If you use a permanent one (e.g. IPSEC) then PHP doesn't need to create the connection, it's just there to use when PHP connects to an IP address that is in the VPN. It is selected to use by the network layer when it does the routing, not by PHP. This is true even if you create the VPN on demand, as jderda suggested using exec() or similar. But a permanent connection is better (IPSEC).

So to answer your questions:

  1. The question doesn't make sense, the only way PHP could do this is using PPTP or similar and exec() to bring the connection up, but better to use IPSEC
  2. If the VPN connection hangs/dies PHP won't get a connection to the remote end and will timeout the connection.
  3. Yes it is.
like image 167
Mark Avatar answered Oct 18 '22 02:10

Mark


From PHP point of view, the VPN is just a plain network connection. It does not require additional handling.

If you want to dynamicaly estabilish a VPN connection, you'll probably need to use exec() and some commandline tool for estabilishing a connection. But as such connection doesn't interfere with normal network communication (as long as it's properly configured, with other subnet ip range), you should estabilish it once and keep it active for PHP and other apps to use.

like image 30
jderda Avatar answered Oct 18 '22 02:10

jderda