>  기사  >  웹 프론트엔드  >  JavaScript 쿠키 크로스 도메인 액세스 광고 프로모션_javascript 기술

JavaScript 쿠키 크로스 도메인 액세스 광고 프로모션_javascript 기술

WBOY
WBOY원래의
2016-05-16 15:04:391988검색

실제 응용에서는 위의 방법을 사용하여 일기 예보 구성 요소의 교차 도메인 사용을 구현할 수 있습니다. 또 다른 일반적인 방법은 특정 전자 상거래 회사의 광고를 표시하는 것입니다. 이 광고는 방문한 제품이나 협회를 통해 스크롤됩니다. 귀하의 제품을 추천하고 싶습니다.

예를 들어 웹페이지 A에는 두 가지 유형의 광고가 표시됩니다.

동동의 광고에 나온 것들 중 디디가 직접 방문하고 관련 추천을 받은 것들

특정 제품의 광고는 기본적으로 같은 방식으로 표현됩니다.

동무바오 상품 접속 시 해당 정보는 쿠키에 저장되며, 쿠키에 포함된 상품 정보를 기반으로 소개가 진행됩니다.

여기서 문제가 발생합니다.

A 웹페이지가 위치한 사이트와 Dongbao 사이트는 두 개의 독립적인 도메인 이름이어야 합니다. A 웹페이지에서 Dongbao 쿠키에 접속하면 출처가 다르기 때문에 이를 얻을 수 없습니다.

A웹페이지 자체에 상품정보를 표시하는 것은 불가능하며 부적절합니다.

물론, 제품 정보는 크로스 도메인 방식으로 제시되어야 합니다. 해결해야 할 문제는 다음과 같습니다.

1. 크로스 도메인 서비스에서 생성된 스크립트에서는 쿠키를 얻을 수 없습니다.

왜요? , 크로스 도메인 서비스에 의해 생성된 스크립트는 결국 웹 페이지 A에서 실행됩니다. 크로스 도메인 서비스에 의해 생성된 스크립트에서 액세스되는 쿠키는 웹 페이지 A가 위치한 사이트의 쿠키만 될 수 있으며 이는 잘못된 것입니다.

2. 크로스도메인 서비스 백그라운드에서는 쿠키를 얻을 수 있습니다

대답은 '예'입니다. 브라우저가 특정 도메인 이름/주소를 요청하면 해당 쿠키를 가져옵니다.

그럼 간단한 데모를 구현해보겠습니다

데모 아키텍처: node.js+express

1. 크로스도메인 서비스에서는 상품정보를 입력하고, 방문한 내용을 시뮬레이션하고, 입력 후 쿠키에 저장하는 페이지를 제공하는 전자상거래 회사로 이해할 수 있습니다.

페이지

코드는 입력과 만료 시간을 쿠키에 저장하는 것입니다. 물론 먼저 코딩하면 됩니다.

<!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. 크로스 도메인 서비스에서는 서버가 스크립트를 생성할 수 있도록 코드를 작성합니다. 스크립트 생성 시 브라우저에서 가져온 쿠키의 데이터를 디코딩하여 스크립트에 넣습니다.

여기서 쿠키는 요청 객체를 통해 검색됩니다. 플랫폼에 따라 방법이 다를 수 있지만 원칙은 동일하며 브라우저가 쿠키를 가져옵니다.

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. 로컬 웹사이트의 A 웹페이지에서 크로스 도메인 서비스에 스크립트를 요청합니다.

그 중 크로스도메인 서비스에서 제공하는 스크립트의 주소는 스크립트 태그를 통해 참조됩니다.

<!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 쿠키 크로스 도메인 액세스 및 광고 프로모션에 대한 모든 관련 지식이 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.