실제 응용에서는 위의 방법을 사용하여 일기 예보 구성 요소의 교차 도메인 사용을 구현할 수 있습니다. 또 다른 일반적인 방법은 특정 전자 상거래 회사의 광고를 표시하는 것입니다. 이 광고는 방문한 제품이나 협회를 통해 스크롤됩니다. 귀하의 제품을 추천하고 싶습니다.
예를 들어 웹페이지 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 쿠키 크로스 도메인 액세스 및 광고 프로모션에 대한 모든 관련 지식이 도움이 되기를 바랍니다.