
私は、主に JavaScript ですが、Firefox や Chrome にあるようなアドオンがほとんどである、完全にブラウザ内で動作する P2P VPN を構築しようとしています。基本的には Hola VPN と同じものです。
私を困惑させているのは、xmlhttprequest's
アクセスしているサーバー/Web サイトによる明示的な承認がなければ、クロスドメイン リクエストには対応していないため、別のピアからのリクエストをリダイレクト/プロキシできる唯一の方法であるということです。Hola VPN はどのようにしてこれを回避できるのでしょうか? 誰か知っていますか?
念のため言っておきますが、私はオープンエンドの質問をしようとしているわけではありません。しかし、このジレンマには答えが 1 つまたは 2 つしかありません。しかし、そう思われる場合は、編集して答えを減らす必要があるかどうかお知らせください。
答え1
Hola が何をするのかはわかりませんが、おそらく最善の選択肢は、拡張機能の権限に VPN ドメインを追加し、chrome.webRequest と xmlhttprequest を使用してそこにリクエストを送信することだと思います。
これにより、リクエストを送信できますが、CORS と権限の問題により、P2P VPN の反対側では同じ方法では実行できません。Chrome アプリは以前は raw ソケットをサポートしていましたが、非推奨になりました。
現在のブラウザ API では、ネイティブ アプリを作成する必要があります。ネイティブ メッセージングを介して通信するブラウザ拡張機能を維持することも、拡張機能を完全に削除して両方の部分をアプリにまとめることもできます (これは、P2P VPN である PenguinProxy で行ったことです)。