実際のアプリケーションでは、上記の方法を使用して、天気予報コンポーネントのクロスドメイン使用を実装できます。もう 1 つの一般的な方法は、特定の電子商取引企業からの広告を表示することです。この広告は、ユーザーが訪問した製品または協会をスクロールします。あなたの商品にお勧めしたい。
たとえば、Web ページ A には 2 種類の広告が表示されます:
Dongdong の広告に表示されているいくつかの項目は Didi が訪問し、関連する項目が推奨されています
ある商品の広告も基本的には同じように提示されます。
Dongmoubao の製品にアクセスすると、情報が Cookie に保存され、プレゼンテーションは Cookie 内の製品情報に基づいて行われます。
ここで問題が発生します。
A Web ページが置かれているサイトと Dongbao のサイトは、2 つの独立したドメイン名である必要があります。A Web ページ上の Dongbao の Cookie にアクセスすると、ソースが異なるため、Cookie を取得できません。
Web ページ A 自体に製品情報を表示することは不可能であり、不適切です。
当然のことながら、製品情報はクロスドメインで表示される必要があります。解決する必要がある問題は次のとおりです。
1. クロスドメイン サービスによって生成されたスクリプトから Cookie を取得することはできません。
なぜですか? 、クロスドメイン サービスによって生成されたスクリプトは、最終的に Web ページ A で実行されます。クロスドメイン サービスによって生成されたスクリプトでアクセスされる Cookie は、Web ページ A が配置されているサイトの Cookie のみにすることができますが、これは間違っています
2. クロスドメイン サービスのバックグラウンドで Cookie を取得できます
答えは「はい」です。ブラウザが特定のドメイン名/アドレスにリクエストを行う限り、対応する Cookie が送信されます。
それでは、簡単なデモを実装してみましょう
デモアーキテクチャ:node.js+express
1. クロスドメインサービスでは、商品情報を入力し、訪問した内容をシミュレートし、入力後にクッキーに保存するためのページを提供する電子商取引企業として理解できます。
ページ
このコードは、入力と有効期限を Cookie に保存するものです。もちろん、最初にコーディングするだけです。
<!DOCTYPE html> <html> <head> <title>setCookie</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <link rel="stylesheet" href="/stylesheets/style.css"> </head> <body> <h1>看过的商品</h1> <div> <span>商品1</span><input id="s1"> </div> <p></p> <div> <span>商品2</span><input id="s2"> </div> <p></p> <div> <span>商品3</span><input id="s3"> </div> <p></p> <div> <span>商品4</span><input id="s4"> </div> <p></p> <div> <input id="b" type="button" value="保存进cookie" onclick="saveInCookie();"> </div> <script> function saveInCookie(){ //所有商品信息 var eleS1=document.getElementById('s1'); var eleS2=document.getElementById('s2'); var eleS3=document.getElementById('s3'); var eleS4=document.getElementById('s4'); //生成24小时后过期的参数 var date=new Date(); var expiresMSeconds=3*24*3600*1000; date.setTime(date.getTime()+expiresMSeconds); //商品信息全部设置到cookie中 document.cookie='s1='+escape(eleS1.value)+";expires="+date.toGMTString(); document.cookie='s2='+escape(eleS2.value)+";expires="+date.toGMTString(); document.cookie='s3='+escape(eleS3.value)+";expires="+date.toGMTString(); document.cookie='s4='+escape(eleS4.value)+";expires="+date.toGMTString(); alert(document.cookie); } </script> </body> </html>
2. クロスドメイン サービスでは、サーバー側でスクリプトを生成するコードを記述します。スクリプトを生成するときに、ブラウザーによってもたらされた Cookie 内のデータをデコードしてスクリプトに組み込みます。
ここでは、Cookie はリクエスト オブジェクトを通じて取得されます。この方法は他のプラットフォームでは異なる場合がありますが、原理は同じであり、ブラウザーによって取得されます。
router.get('/ad', function (req, res) { //拼接一JS字符串,完成向html页面中输出html标记 printCookies(req.cookies); var s = 'document.write(\'<div style="background-color:red;width:10rem;height:10rem">商品广告'; //将cookie中所有的商品取出,拼到脚本字符串中 for (var p in req.cookies) { s += '<div>' + unescape(req.cookies[p]) + '</div>'; } s+='</div>\');'; console.log(s); res.setHeader('content-type', 'text/javascirpt;charset=utf-8'); res.write(s); res.end(); }); function printCookies(cookies) { console.log('******cookies******'); for (var p in cookies) { console.log(p + '=' + unescape(cookies[p])); } console.log('*******************'); }
3. ローカル Web サイトの Web ページでクロスドメイン サービスにスクリプト リクエストを作成します。
このうち、クロスドメインサービス上で提供されるスクリプトのアドレスはscriptタグを通じて参照されます。
<!DOCTYPE html> <html> <head> <title>test</title> <link rel="stylesheet" href="/stylesheets/style.css"></head> <body> <script src="http://localhost:3001/ad"></script> <h1>航班信息</h1> <h4>航班号:MU532</h4> <h4>起飞:北京</h4> <h4>抵达:上海</h4> </body> </html>
ページを実行すると、下の図に示すように、訪問した製品情報が一覧表示され、小さな広告のように見えます。
これで完了です。
これは、JavaScript Cookie のクロスドメイン アクセスと広告プロモーションに関するすべての関連知識です。皆様のお役に立てれば幸いです。