PHP+JavaScript實現Cookie的讀寫、互動操作方法詳解

來源:互聯網
上載者:User
這篇文章主要介紹了PHP與JavaScript針對Cookie的讀寫、互動操作方法,結合執行個體形式分析了php與javascript設定cookie、php讀取php及js設定的cookie、js讀取php及js設定的cookie等相關操作技巧,需要的朋友可以參考下

本文執行個體講述了PHP與JavaScript針對Cookie的讀寫、互動操作方法。分享給大家供大家參考,具體如下:

下面的例子列出幾種情形互動情境,列出JS和php互動的方法。總結下,以免日後再為cookie問題困擾。

<?php setcookie('php_cn_ck','php_中文_cookie'); setcookie('php_en_ck','php_english_cookie');?>

<script src="cookie.js"></script><script> Cookies.set('js_cn_ck','js_中文_cookie',5000); Cookies.set('js_en_ck','js_english_cookie');</script>

PHP cookie已經設定:
php_cn_ck=php_中文_cookie
php_en_ck=php_english_cookie

JS cookie已經設定:
js_cn_ck=js_中文_cookie
js_en_ck=js_english_cookie

讀取cookie

一 讀取php傳送的中英文cookie

1 php讀取php設定php cookie

<?php include('function.php'); $php_cn_ck=$_COOKIE['php_cn_ck']; $un_php_cn_ck=unescape($php_cn_ck); echo "解碼前的中文cookie:php_cn_ck=$php_cn_ck<br><br>"; echo "解碼後的中文cookie:un_php_cn_ck=$un_php_cn_ck<br><br>"; $php_en_ck=$_COOKIE['php_en_ck']; echo "英文cookie無需解碼:php_en_ck=$php_en_ck<br><br>";?>

2 js讀取php設定cookie

<script src="cookie.js"></script><script> php_cn_ck=Cookies.get('php_cn_ck'); un_php_cn_ck = decodeURIComponent (escape(php_cn_ck)); document.write("解碼前的中文cookie :php_cn_ck="+php_cn_ck+"<Br><br>"); document.write("解碼後的中文cookie :un_php_cn_ck="+un_php_cn_ck+"<Br><br>"); php_en_ck=Cookies.get('php_en_ck'); document.write("英文cookie無需解碼 :php_en_ck="+php_en_ck+"<Br><br>");</script>

二 讀取JS傳送的中英文cookie

1 php讀取JS設定js cookie

<?php $js_cn_ck=$_COOKIE['js_cn_ck']; $un_js_cn_ck=unescape($js_cn_ck); echo "解碼前的中文cookie:js_cn_ck=$js_cn_ck<br><br>"; echo "解碼後的中文cookie:un_js_cn_ck=$un_js_cn_ck<br><br>"; $js_en_ck=$_COOKIE['js_en_ck']; echo "英文cookie無需解碼:js_en_ck=$js_en_ck<br><br>";?>

2 js讀取js設定的cookie

<script> js_cn_ck=Cookies.get('js_cn_ck'); document.write("解碼前的中文cookie :js_cn_ck="+js_cn_ck+"<Br><br>"); //un_js_cn_ck = decodeURIComponent (escape(js_cn_ck)); 調用這兩句會出現js解析中斷 //document.write("解碼後的中文cookie :un_js_cn_ck="+un_js_cn_ck+"<Br><br>"); js_en_ck=Cookies.get('js_en_ck'); document.write("英文cookie無需解碼 :js_en_ck="+js_en_ck+"<Br><br>");</script>

總結:

1. php用自身函數讀取php 的cookie,沒有任何障礙,無需解碼處理。
2. js採用cookie.js方法讀取js 的cookie,沒有任何障礙,無需解碼處理。
3. js讀取php的中文cookie,需要做 "decodeURIComponent (escape(php_cn_ck)) "函數處理
4. php讀取js的中文cookie 需要做 "unescape()" 函數處理

cookie.js:

var Cookies = {};/*** 設定Cookies*/Cookies.set = function(name, value){ var argv = arguments; var argc = arguments.length; var expires = (argc > 2) ? argv[2] : null; if(expires != null){  var exp   = new Date();  exp.setTime(exp.getTime() + 8*3600 + expires); } alert(exp.toGMTString()); var path = (argc > 3) ? argv[3] : '/'; var domain = (argc > 4) ? argv[4] : null;  var secure = (argc > 5) ? argv[5] : false; document.cookie = name + "=" + escape (value) + ((expires == null) ? "" : ("; expires=" + exp.toGMTString())) + ((path == null) ? "" : ("; path=" + path)) + ((domain == null) ? "" : ("; domain=" + domain)) + ((secure == true) ? "; secure" : "");};/*** 讀取Cookies*/Cookies.get = function(name){ var arg = name + "="; var alen = arg.length; var clen = document.cookie.length; var i = 0; var j = 0; while(i < clen){  j = i + alen;  if (document.cookie.substring(i, j) == arg)  return Cookies.getCookieVal(j);  i = document.cookie.indexOf(" ", i) + 1;  if(i == 0)  break; } return null;};/*** 清除Cookies*/Cookies.clear = function(name) { if(Cookies.get(name)){ var expdate = new Date(); expdate.setTime(expdate.getTime() - (86400 * 1000 * 1)); Cookies.set(name, "", expdate); }};Cookies.getCookieVal = function(offset){ var endstr = document.cookie.indexOf(";", offset); if(endstr == -1){  endstr = document.cookie.length; } return unescape(document.cookie.substring(offset, endstr));};

相關推薦:

PHP中cookie使用案例詳解

jQuery+Cookie切換皮膚步驟詳解

Cookie外掛程式js-cookie使用案例詳解

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.