1. シナリオ最近、Web ベースのプラグイン システムに似たものに取り組んでおり、サードパーティ アプリケーションのコードを実行するために js サンドボックスを操作しています。 2. サンドボックスの基本機能実装前に(正確にはいくつかの解決策を研究した後)、サンドボックスは エクスポートインターフェースIEventEmitter { /** * リスニングイベント * @param チャネル * @param ハンドル */ on(チャネル: 文字列、ハンドル: (データ: any) => void): void; /** * リスニングをキャンセル * @param チャネル */ offByChannel(チャンネル: 文字列): void; /** * トリガーイベント * @param チャネル * @param データ */ 出力(チャネル: 文字列、データ: 任意): void; } /** * 基本的な js vm 機能 */ エクスポートインターフェースIJavaScriptShadowboxはIEventEmitterを拡張します{ /** * 任意のコードを実行する * @param code */ eval(コード: 文字列): void; /** * インスタンスを破棄する */ 破棄(): void; } 通信機能に加えて、次の 2 つの追加方法が必要です。
JavaScript サンドボックス図: 以下では 3. iframeの実装正直に言うと、Web のサンドボックスについて話すとき、最初に思い浮かぶのはおそらく もちろん、jsコードをhtmlでラップして実行することもできます。 関数 evalByIframe(コード: 文字列) { const html = `<!DOCTYPE html><body><script>$[code]</script></body></html>`; 定数 iframe = document.createElement("iframe"); iframeの幅 = "0"; iframe.height = "0"; iframe.style.display = "なし"; document.body.appendChild(iframe); const blob = new Blob([html], { type: "text/html" }); iframe.src = URL.createObjectURL(blob); iframe を返します。 } evalByIframe(` document.body.innerHTML = 'こんにちは世界' console.log('location.href: ', location.href) console.log('localStorage: ',localStorage) `); しかし、
4. Webワーカーの実装基本的に、 関数 evalByWebWorker(コード: 文字列) { const blob = new Blob([code], { type: "application/javascript" }); url を URL.createObjectURL(blob) に変換します。 新しい Worker(url) を返します。 } WebWorkerによる評価(` console.log('location.href: ', location.href) // console.log('localStorage: ', localStorage) `); しかし同時に、
5. Quickjsの実装
quickjs とは何ですか?これは JavaScript ランタイムです。最も一般的に使用されるランタイムはブラウザと 非同期関数evalByQuickJS(コード:文字列) { const quickJS = getQuickJS() を待機します。 定数 vm = quickJS.createVm(); 定数 res = vm.dump(vm.unwrapResult(vm.evalCode(code))); vm.dispose(); res を返します。 } console.log(evalByQuickJS(`1+1`) を待機します); アドバンテージ:
欠点:
6. 結論最終的に、インターフェースに基づいて Web Worker と QuickJS の EventEmitter を実装し、いつでも切り替えられる機能をサポートすることを選択しました。 JavaScript サンドボックスの探索に関するこの記事はこれで終わりです。JavaScript サンドボックスに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
1. instanceofの使用法instanceof演算子は、コンストラクター関数のprototy...
シェルを起動する頻度は非常に低いですが。 。 。しかし、書くたびに、多くの jar ファイル パスを...
以前にも同じような記事を書いたことがありますが、js スクリプトを使用しており、ファイルパスを表示で...
1. 何ですか マークアップ言語として、CSSは比較的シンプルな構文とユーザーに対する要件が低いが、...
目次質問伸ばす問題を解決する要約する質問プロジェクトの要件に従って、以下の州地図で個々の都市を(異な...
目次1.まずネットワークカードの設定ディレクトリに入る2. ifcfg-ens33ネットワークカード...
いくつかの記事を読んだ後、ようやく MySQL で row_number() ソートを実装する方法が...
なお、この記事では、単に 20.04 ソースに変更する方法を説明するのではなく、20.04 に基づい...
ffmpeg は非常に強力なオーディオおよびビデオ処理ツールです。公式 Web サイトは http:...
html-webpack-pluginプラグインを使用してページを開始すると、htmlページをメモリ...
Mysql-connector-java ドライバのバージョンの問題私のデータベースのバージョンは ...
Springboot プロジェクトを開始するには、次の 3 つの方法があります。 1. メインメソッ...
この記事の例は MySQL 5.0 以降で実行されます。ユーザー権限を付与するための MySQL コ...
目次背景1. 思考分析2. ページ構成2.1 HTML レイヤー2.2 CSS レイヤー2.3 JS...
これが何を指しているのかをどのように判断するのでしょうか? ①グローバル環境で呼び出された場合はwi...