一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - PHP教程 - 關(guān)于Iframe如何跨域訪問Cookie和Session的解決方法

關(guān)于Iframe如何跨域訪問Cookie和Session的解決方法

2020-03-19 13:28PHP教程網(wǎng) PHP教程

本篇文章小編將為大家介紹,關(guān)于Iframe如何跨域訪問Cookie和Session的解決方法,有需要的朋友可以參考一下

最近做登錄系統(tǒng)的整合,其中遇到的一個最關(guān)鍵的問題為在一個統(tǒng)一的后臺里需要無障礙的訪問另外一個系統(tǒng)后臺,這個系統(tǒng)是第三方提供的一個加過密的系統(tǒng),后臺自動登錄接口是自己分析出來的,沒有單獨提供,當從統(tǒng)一后臺通過自動登錄接口登錄時,系統(tǒng)直接跳轉(zhuǎn)到系統(tǒng)后臺首頁,后臺登錄成功后所跳轉(zhuǎn)的URL這里沒法指定,控制不了跳轉(zhuǎn)的頁面,如果在統(tǒng)一后臺里需要鏈接到這個系統(tǒng)后臺的另外一個頁面,而非后臺默認首頁時,也就是將第三方系統(tǒng)后臺的菜單功能放到我們這個統(tǒng)一后臺里。

對于這樣的一個需要,這里會遇到一個問題,為了能正常訪問第三方系統(tǒng)的后臺欄目,必需確保已經(jīng)登錄該系統(tǒng),否則會提示用戶登錄,所以在點擊這些菜單鏈接時,系統(tǒng)必需已經(jīng)登錄。

為了解決這個問題,在頁面頭部添加了一個不可見的iframe,使其指向到自動登錄接口,這個接口如果正常通過瀏覽器地址欄訪問,當用戶名和密碼驗證無誤時,會跳轉(zhuǎn)到系統(tǒng)后臺首頁,由于此時放在了一個不可見的IFRAME中,所以跳轉(zhuǎn)對當前后臺頁面沒有任何影響。按照我的設(shè)計方法,系統(tǒng)應(yīng)該就可以正常使用了。

但,既然說到但了,就說明肯定遇到了問題,不然這里不會來這么大的一個轉(zhuǎn)折的。

但由于這里各系統(tǒng)均屬于不同的系統(tǒng),域名不一樣,所以出現(xiàn)了Iframe在IE中,不能正常生成第三方系統(tǒng)Cookie的情況,但在Firefox和其它瀏覽器中均可生成,所以用IE訪問時,總是跳轉(zhuǎn)到登錄頁面。

這里需要說明一下,這里的第三方系統(tǒng)放在我們自己的服務(wù)器上的,只是所有源碼加了密!

最后查閱了相關(guān)資料后,發(fā)現(xiàn)在IE中,為了安全,阻止了通過IFRAME生成第三方域的COOKIE,為了解決這個問題,MS規(guī)定只要在HTTP的HEADER頭中,設(shè)定P3P這個頭,就可以通過IFRAME來生成第三方COOKIE了。

PHP中,P3P HEADER 頭的設(shè)置方法如下:

header(‘P3P: CP=”CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR”‘);

注意:這里的P3P需要添加到第三方域生成Cookie的那個文件才生效,否則無濟于事。

這里又有問題了,第三方系統(tǒng)生成COOKIE在后臺的一個叫admin.php的頁面里生成的,而這個頁面又是加過密的,這可怎么辦了,想了很久,最后同事靈機一動,說我們可以用我們自己的文件來包含它。靠,這方法太妙了,為什么我就沒有想到了,同事真是太有才了,真是佩服的五體投地,當然,我對他這么一佩服,據(jù)他說自己當晚也自己佩服了自己一晚上。

所以最后的解決方案為將原來的admin.php文件命名為admin_2.php,然后新建admin.php,最后在這個文件中,添加上面所的P3P這個HEADER頭,并再次包含 admin_2.php這個文件,最終代碼如下:

header(‘P3P: CP=”CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR”‘);

include “admin_2.php”;

最后,問題徹底解決!

這里標題是COOKIE和SESSION的問題,實質(zhì)上,基本上是一回事,SEESION最終的保存也是通過SESSION_ID保存到COOKIE源碼天空,然后通過這個SID到服務(wù)器上找相應(yīng)的SEESION數(shù)據(jù),只要把COOKIE里的SEESION_ID這個COOKIE給刪掉,SESSION也就失效了。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本ww视频 | 青青青视频免费观看 | 日韩一区二区中文字幕 | 古代翁熄乩伦小说h | 被巨大黑人的翻白眼 | 国产精品久久久99 | 成人欧美一区二区三区 | 国产一区二区播放 | 四虎4hu永久免费国产精品 | 四虎免费影院4hu永久免费 | 香蕉久久高清国产精品免费 | 婷婷综合久久 | 欧美在线视频一区在线观看 | 我与岳乱短篇小说 | 久久99国产精品二区不卡 | 日韩欧美亚洲国产高清在线 | 久久不卡免费视频 | 色yeye在线观视频 | 男人的影院 | 国产免费好大好硬视频 | 国产成人综合网亚洲欧美在线 | 三级理论在线播放大全 | 范冰冰特黄xx大片 | 久久精视频 | 国产一级持黄大片99久久 | 美女靠逼的视频 | 国产乱子伦一区二区三区 | 国产伦精品一区二区三区免 | chinese调教踩踏视频 | 办公室里被迫高h | 欧美久久久久久 | 成在线人免费 | 国产精品视频免费观看 | 荡女人人爱| 国模大胆一区二区三区 | 国产成人盗摄精品 | 99国产自偷色久 | 国产精品久久久久久久午夜片 | 国产做a爰片久久毛片 | 我半夜摸妺妺的奶C了她 | 美女脱了内裤让男生玩屁股 |