這篇文章主要介紹了thinkphp中session和cookie無效的解決方法,涉及針對BOM頭的分析與刪除方法,具有一定的參考借鑒價值,需要的朋友可以參考下
本文實例講述了thinkphp中session和cookie無效的解決方法。分享給大家供大家參考。具體分析如下:
問題描述:
在本地調試時session和cookie是用沒有問題的,我是用session保存當前登入帳戶的資訊,上傳伺服器之後,發現跳轉之後session不復存在,為什麼呢?在目前頁面輸出session是存在的.
遇到這個問題三天了,因為是自學沒有老師可以請教,身邊也沒有幾個是弄PHP的,所以真的是很悲劇,於是乎百度,而百度上很多人都是屁話連天,沒有什麼可以解決問題的,經過三天的修改終於找到了根源,原來是因為絕大多數支持thinkphp的伺服器是linux系統,而我們的程式設計基本上還是windows,這樣就會出現bom頭這個問題,而PHP對於bom頭不能解析,而直接拿下來了,導致session和cookie不能用.
##解決方法:
#什麼是bom頭?在utf-8編碼文件中BOM在文件頭,佔用三個字節,用來標示該文件屬於utf-8編碼,現在已經有很多軟體識別bom頭,但是還有些不能識別bom頭,比如PHP就不能辨識bom頭,這也是用記事本編輯utf-8編碼後執行就會出錯的原因了.去掉bom頭的辦法,簡單的是下面兩種:1 、editplus去BOM頭的方法編輯器調整為UTF8編碼格式後,保存的文件前面會多出一串隱藏的字符(也即是BOM),用於編輯器識別這個文件是否是以UTF8編碼.運行Editplus,點擊工具,選擇首選項,選中文件,UTF-8標識選擇總是刪除簽名,然後對PHP文件編輯和保存後的PHP文件就是不帶BOM的了.2、ultraedit去除bom頭辦法打開文件後,另存為選項的編碼格式裡選擇(utf-8 無bom頭),確定就ok了,怎麼樣,去掉bom頭很簡單吧.再來一段議論utf8的BOM信息的,BOM是指php文件本身的存儲方式為帶BOM的UTF-8,普通頁面的中文亂碼方式一般不是由這個原因導致的.header("Content-type: text/html; charset=utf-8");
以上是如何解決thinkphp中session和cookie無效的問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!