<br />原文: http://research.microsoft.com/~helenw/papers/subspace.pdf window.name 転送技術はもともと、クッキーのいくつかの欠点 (ドメイン名ごとに 4 x 20 Kb の制限、データは文字列のみ、クッキーの設定と取得の構文が複雑など) を解決するために Thomas Frank によって発明されました (詳細については、原文「クッキーなしのセッション変数」を参照してください)。その後、Kris Zyp はこの方法に基づいて window.name 転送を強化し、Dojo (dojox.io.windowName) に導入して、クロスドメイン データ転送の問題を解決しました。 window.name の優れた点:名前の値は、異なるページ (異なるドメインでも) を読み込んだ後も保持され、非常に長い名前の値 (2 MB) をサポートできます。 window.name 伝送技術の基本原理と手順は次のとおりです。 ![]() name はブラウザ環境の global/window オブジェクトのプロパティであり、フレームに新しいページが読み込まれると、name のプロパティ値は変更されません。 iframe にリソースを読み込むと、ターゲット ページはフレームの name 属性を設定します。この名前属性値を取得して、Web サービスによって送信された情報にアクセスできます。ただし、name 属性は同じドメイン名を持つフレームにのみアクセスできます。つまり、name 属性にアクセスするには、リモート Web サービス ページが読み込まれた後、フレームを元のドメインに戻す必要があります。同一生成元ポリシーにより、他のフレームが名前属性にアクセスすることはできません。名前属性を取得したら、フレームを破棄します。 最上位レベルでは、name 属性は安全ではなく、name 属性に設定されたすべての情報は後続のすべてのページで利用できます。ただし、windowName モジュールは常に iframe 内のリソースを読み込み、データが取得されるか、最上位レベルの新しいページを参照すると、iframe は破棄されるため、他のページは window.name プロパティにアクセスできなくなります。 基本的な実装コードは YUI に基づいており、Kejun によって書かれた例から派生しています。 (関数(){ var YUD = YAHOO.util.Dom、YUE = YAHOO.util.Event; データリクエスト = { _doc: ドキュメント、 cfg: { プロキシ URL: 'proxy.html' } }; dataRequest.send = function(sUrl, fnCallBack){ if(!sUrl || typeof sUrl !== '文字列'){ 戻る; } sUrl = (sUrl.indexOf('?') > 0 ? '&' : '?') 'windowname=true'; var frame = this._doc.createElement('iframe'), state = 0, self = this; this._doc.body.appendChild(フレーム); frame.style.display = 'なし'; var clear = 関数(){ 試す{ frame.contentWindow.document.write(); フレームのコンテンツウィンドウを閉じます。 self._doc.body.removeChild(フレーム); }キャッチ(e){} }; var getData = 関数(){ 試す{ var da = frame.contentWindow.name; }キャッチ(e){} クリア(); if(fnCallBack && typeof fnCallBack === 'function'){ fnCallBack(da); } }; YUE.on(フレーム、'load'、関数(){ if(状態 === 1){ データを取得します。 } そうでない場合(状態 === 0){ 状態 = 1; frame.contentWindow.location = self.cfg.proxyUrl; } }); フレーム.src = sUrl; }; })(); |
>>: element-uiのアップロードコンポーネントでファイルやその他のパラメータを転送する際の問題を分析する
まずコードを書いて (int i=0;i<1000;i++){ (int j=0;j<5...
オンラインで多くの記事を検索しましたが、解決策は見つかりませんでした。次のように、tomcat7-m...
W3C では、さまざまなタグの規定を設定するだけでなく、Web ページの作成者が実際に W3C 規...
1. 前提条件1. プロジェクトが展開されました2. Dockerはすでにインストールされている2...
昨日 HTML を少し学んだばかりで、JD.com の検索バーを作るのが待ちきれませんでした。 作っ...
サブスクリプションメッセージテンプレートを選択または作成するWeChat アプレットにログインし、「...
目次1. 基本を理解する2. システム環境を確認する3. ftpコマンドをインストールする[オプショ...
1. はじめに先ほど、ウェブページの急速な発展について紹介しました。今回は、より深い内容についてお...
記録として、将来使用される可能性があり、困っている友人も使用できます。 BBはもうやめて、まずはレン...
現在の日付 + 時刻 (日付 + 時刻) を取得する関数: now() mysql> now(...
JavaScriptは、参考のためにランダムな点呼Webページを作成します。具体的な内容は次のとお...
目次依存関係をインストールする構成使用1.アイコン検索ページに入る2. 使用したいアイコンの英語名を...
vsftpd の概要vsftpd は「very secure FTP daemon」の略称で、セキ...
Web 標準について議論するときに必ず話題になるのは、構造とプレゼンテーションを分離することの重要性...
目次インデックス プッシュダウンとは何ですか?インデックスプッシュダウン最適化の原理インデックスプッ...