Saya mencoba membuat layanan VPN yang hanya mampu memfilter lalu lintas web HTTP / S tertentu melalui VPN, dan lalu lintas lain yang tidak cocok dengan kriteria filter dinamis saya harus dikirim melalui gateway default.
Saya tahu jika saya menggunakan OpenVPN, saya bisa merutekan traffic (Layer 2 & 3) IP tertentu melalui VPN dan lainnya melalui gateway default. Tapi saya perlu menyaring lalu lintas yang mirip dengan cara kerja Proxy HTTP. Saya sebenarnya mencoba membuat Server Proxy Web saya sendiri , tetapi yang berfungsi di tingkat sistem dan bukan di tingkat browser. Jadi, bahkan jika pengguna membuat klien browser mereka sendiri dan mencoba mengakses URL tertentu, lalu lintas itu dapat dialihkan melalui VPN. Jadi mengapa saya berpikir untuk membuat VPN yang mampu menangkap semua lalu lintas yang berasal dari host daripada Proxy HTTP sederhana. Tapi sekarang masalahnya adalah bagaimana saya bisa memfilter hanya lalu lintas yang perlu saya kirim melalui VPN dengan memeriksa permintaan HTTP GET / POST. Karena untuk melakukan ini, VPN membutuhkan akses ke data Layer Aplikasi daripada Layer 2 atau Layer 3.
Jadi jika saya meringkas kebutuhan saya, saya mencoba mengembangkan hibrida saya sendiri antara Perangkat Web Proxy + VPN (TUN / TAP) .
- Aplikasi / layanan ini yang dipasang oleh pengguna pada mesin mereka harus dapat mencegat semua lalu lintas yang berasal dari host.
- Itu harus dapat memeriksa permintaan HTTP / HTTPS yang dibuat dari browser atau klien khusus dan hanya ketika permintaan tersebut cocok dengan nama URL tertentu (yaitu www.facebook.com/*, www.linkedin.com/*, * .js, * .swf), lalu lintas itu akan dialihkan melalui VPN.
- Jika permintaan tidak memenuhi persyaratan yang cocok, permintaan akan dikirim melalui gateway internet default pengguna.
- Kondisi pencocokan URL dapat banyak dan diubah kapan saja sehingga tidak sulit dikodekan.
Setiap petunjuk yang baik (kode, dokumentasi untuk plugin OpenVPN yang dapat saya tulis, dll) tentang bagaimana saya dapat mencapai ini, atau saran Jika saya mencoba melakukan ini dengan cara yang salah sangat dihargai.
192.168.12.34
melalui VPN makapush
rute untuk itu ke klien vpn Anda: misalnyapush "route 192.168.12.34"