php出現(xiàn)web系統(tǒng)多域名登錄失敗的解決方法
本文實例講述了php出現(xiàn)web系統(tǒng)多域名登錄失敗的解決方法,分享給大家供大家參考。具體分析如下:
下面只是簡單的邏輯結(jié)構(gòu),對于正式的系統(tǒng)需要做具體的處理。
這里需要注意的是:加解密一定需要做安全驗證。但是這個方法也不夠完美,兩個站點必須有相同一級域名;另外這種完全基于cookie的方式,安全性不夠高
function login() { $info = callloginserver(); //訪問登錄服務器 if(!empty($info)) //登錄成功了 } //用戶沒有登錄,則在本系統(tǒng)中登錄并調(diào)用登錄服務器接口 function login() //正常的登錄 { .......//驗證用戶的合法性 $_session['uid'] = $user_id; setcookie('sign', encrypt($pass9), '', '/', 'the.com'); }
先檢查用戶是否在登錄系統(tǒng)中登錄
funtion sign() { $sign = $_cookie['sign']; if(!empty($sign)) { $sign = decrypt($sign); ..........///登錄成功 } }
用戶沒有登錄,則在本系統(tǒng)中登錄并調(diào)用登錄服務器接口
function loging() //本系統(tǒng)登錄 { .....//登錄成功 callseverlogin();//通知用戶登錄 }
所有的站點共享一個登錄系統(tǒng);當用戶在其中的一個站點登錄成功時, 該系統(tǒng)調(diào)用其他站點的登錄接口,完成用戶在其他站點的登錄,同時設置相應的登錄信息;或者在用戶登錄時,只在該系統(tǒng)保存用戶登錄信息,當用戶在其他站點登錄時,必須請求該系統(tǒng)接口,獲取用戶是否登錄的信息。前一種方式的缺點是:不管用戶有沒有使用其他站點,那些站點都需要保存用戶狀態(tài);后一種方式就把所有的壓力都轉(zhuǎn)移到登錄系統(tǒng)上面來。而如果要實現(xiàn)用戶退出的統(tǒng)一操作,就需要站點調(diào)用登錄系統(tǒng)的退出接口,然后登錄系統(tǒng)接口調(diào)用其他站點的退出接口;或者設置一個標記,如果這個標記不存在則標示用戶退出,此時只要把該標示清空即可,其他站點發(fā)現(xiàn)該標示不存在就知道用戶已經(jīng)退出系統(tǒng)。
這種處理方式需要在登錄系統(tǒng)和個站點之間規(guī)定登錄接口,和注銷接口。通過這些接口,各站點可以很方便的處理用戶登錄或退出。
希望本文所述對大家的PHP程序設計有所幫助。
相關文章
php通過array_shift()函數(shù)移除數(shù)組第一個元素的方法
這篇文章主要介紹了php通過array_shift()函數(shù)移除數(shù)組第一個元素的方法,涉及php中array_shift()函數(shù)操作數(shù)組的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03PHP中auto_prepend_file與auto_append_file用法實例分析
這篇文章主要介紹了PHP中auto_prepend_file與auto_append_file用法,較為詳細的講述了配置信息的休息以及函數(shù)的用法和注意事項,需要的朋友可以參考下2014-09-09PHP中的閉包function()?use()?{}使用場景和技巧
由于存在函數(shù)內(nèi)部不能訪問全局作用的,所以就需要一種可以引入上一級作用域的語法結(jié)構(gòu),可以通過use使用函數(shù)聲明時所在作用域的變量的值。php的閉包可能不常用,但是在某些場合之下還是可以考慮用php的閉包來實現(xiàn)某些功能的。2022-12-12PHP得到mssql的存儲過程的輸出參數(shù)功能實現(xiàn)
在開發(fā)過程中可能會遇到無法取得MSSQL存儲過程的輸出參數(shù),很多朋友都不知道該怎么辦,本文將詳細介紹PHP得到mssql的存儲過程的輸出參數(shù)功能實現(xiàn)2012-11-11