ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript Cookie クロスドメイン アクセス広告プロモーション_JavaScript スキル

JavaScript Cookie クロスドメイン アクセス広告プロモーション_JavaScript スキル

WBOY
WBOYオリジナル
2016-05-16 15:04:392084ブラウズ

実際のアプリケーションでは、上記の方法を使用して、天気予報コンポーネントのクロスドメイン使用を実装できます。もう 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 のクロスドメイン アクセスと広告プロモーションに関するすべての関連知識です。皆様のお役に立てれば幸いです。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。