PHP http與https之間互轉_PHP教程

來源:互聯網
上載者:User
在 J2EE 中,對於https和http的不同請求,Web容器會產生兩個不同的session對象;因此,如果在同一個Web應用中只有部分頁面使用SSL,要保證使用SSL的頁面與不使用SSL的頁面間的相互切換(也就是https請求與http請求間的切換)會話保持連續,那麼可以通過在訪問的URL中傳遞sessionId來實現,也就是說在進入或退出https的URL上綁定一個sessionId,比如從http切換到https時,URL為:https://xxx/login.do;jsessionid=<%=session.getId()%>,從https切換到http時為:http://xxx/xxx.do;jsessionid=<%=session.getId()%>。這樣Web容器會優先根據這個sessionid擷取session對象,而不是產生新的sessionid,就可以保證http和https切換時會話不變(該方法在Tomcat上驗證過)。

由於在URL上綁定的sessionid容易被竊取,為了保證會話不被劫取,會話認證時需要結合用戶端IP,也就是當使用者登入成功後,通過session.setAttribute("clientIp",request.getRemoteAddr())儲存用戶端的IP地址,在後繼認證會話的合法性時必須判斷用戶端的IP是否是原先儲存在session對象的clientIP屬性的用戶端IP,如果不是則該會話是非法會話。

http直接跳轉為https,重新導向一下就可以了。用php就更簡單了:


當訪問 http 時,跳 https:

 "on"){$xredir="https://".$_SERVER["SERVER_NAME"].$_SERVER["REQUEST_URI"];header("Location: ".$xredir);}?>  

當訪問 https 時,跳 http:


在網頁開頭包含上面代碼即可。

http://www.bkjia.com/PHPjc/752426.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/752426.htmlTechArticle在 J2EE 中,對於https和http的不同請求,Web容器會產生兩個不同的session對象;因此,如果在同一個Web應用中只有部分頁面使用SSL,要保證使用...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.