程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP http與https之間互轉

PHP http與https之間互轉

編輯:關於PHP編程

在 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就更簡單了:

<?php
	header("Location:https://www.bkjia.com");
?>

當訪問 http 時,跳 https:

<?php
//http轉化為https   
if ($_SERVER["HTTPS"] <> "on")
{
	$xredir="https://".$_SERVER["SERVER_NAME"].$_SERVER["REQUEST_URI"];
	header("Location: ".$xredir);
}
?>  

當訪問 https 時,跳 http:

<?php
//https轉化為http   
if ($_SERVER["HTTPS"] == "on")  
{  
	$xredir="http://".$_SERVER["SERVER_NAME"]. $_SERVER["REQUEST_URI"];  
	header("Location: ".$xredir);  
}   
?>

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved