我们在1、location和“:”号间不能有空格,否则会出错。
2、在用header前不能有任何的输出。
3、PHP中用header后的PHP代码还会被执行。
下面是和asp中重定向response.redirect的比较:
例1:
response.redirect "../test.asp"
header("location:../test.php");
两者区别:
asp的redirect函数可以在向客户发送头文件后起作用.
如
<ol class="dp-xml"> <li class="alt"><span><strong><font color="#006699"><span class="tag"><span class="tag-name">html</span><span class="tag">></span><span class="tag"><span class="tag-name">head</span><span class="tag">></span><span class="tag"></span><span class="tag-name">head</span><span class="tag">></span><span class="tag"><span class="tag-name">body</span><span class="tag">></span></span></span></span></font></strong><span> </span></span></li> <li class=""> <span></span><span class="tag"><strong><font color="#006699"></font></strong></span><span>%response.redirect "../test.asp"%</span><span class="tag"><strong><font color="#006699">></font></strong></span><span> </span> </li> <li class="alt"> <span></span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">body</span><span class="tag">></span><span class="tag"></span><span class="tag-name">html</span><span class="tag">></span></font></strong><span> </span> </li> </ol>
查是PHP中用header中下例代码会报错:
<ol class="dp-xml"> <li class="alt"><span><strong><font color="#006699"><span class="tag"><span class="tag-name">html</span><span class="tag">></span><span class="tag"><span class="tag-name">head</span><span class="tag">></span><span class="tag"></span><span class="tag-name">head</span><span class="tag">></span><span class="tag"><span class="tag-name">body</span><span class="tag">></span></span></span></span></font></strong><span> </span></span></li> <li class=""> <span></span><span class="tag"><strong><font color="#006699"></font></strong></span><span> </span> </li> <li class="alt"> <span></span><span class="tag-name"><strong><font color="#006699">header</font></strong></span><span>("location:../test.php"); </span> </li> <li class=""> <span></span><span class="tag"><strong><font color="#006699">?></font></strong></span><span> </span> </li> <li class="alt"> <span></span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">body</span><span class="tag">></span><span class="tag"></span><span class="tag-name">html</span><span class="tag">></span></font></strong><span> </span> </li> </ol>
只能这样:
<ol class="dp-xml"> <li class="alt"><span><span class="tag"><strong><font color="#006699"></font></strong></span><span> </span></span></li> <li class=""> <span></span><span class="tag-name"><strong><font color="#006699">header</font></strong></span><span>("location:../test.php"); </span> </li> <li class="alt"> <span></span><span class="tag"><strong><font color="#006699">?></font></strong></span><span> </span> </li> <li class=""> <span></span><strong><font color="#006699"><span class="tag"><span class="tag-name">html</span><span class="tag">></span><span class="tag"><span class="tag-name">head</span><span class="tag">></span><span class="tag"></span><span class="tag-name">head</span><span class="tag">></span><span class="tag"><span class="tag-name">body</span><span class="tag">></span></span></span></span></font></strong><span>...</span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">body</span><span class="tag">></span><span class="tag"></span><span class="tag-name">html</span><span class="tag">></span></font></strong><span> </span> </li> </ol>
即PHP中用header函数之前不能向客户发送任何数据.
例2:
asp中
<ol class="dp-xml"> <li class="alt"><span><strong><font color="#006699"><span class="tag"><span class="tag-name">html</span><span class="tag">></span><span class="tag"><span class="tag-name">head</span><span class="tag">></span><span class="tag"></span><span class="tag-name">head</span><span class="tag">></span><span class="tag"><span class="tag-name">body</span><span class="tag">></span></span></span></span></font></strong><span> </span></span></li> <li class=""> <span></span><span class="tag"><strong><font color="#006699"></font></strong></span><span>% </span> </li> <li class="alt"><span>response.redirect "../a.asp" </span></li> <li class=""><span>response.redirect "../b.asp" </span></li> <li class="alt"> <span>%</span><span class="tag"><strong><font color="#006699">></font></strong></span><span> </span> </li> <li class=""> <span></span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">body</span><span class="tag">></span><span class="tag"></span><span class="tag-name">html</span><span class="tag">></span></font></strong><span> </span> </li> </ol>
结果是重定向a.asp文件.
php呢?
<ol class="dp-xml"> <li class="alt"><span><span class="tag"><strong><font color="#006699"></font></strong></span><span> </span></span></li> <li class=""> <span></span><span class="tag-name"><strong><font color="#006699">header</font></strong></span><span>("location:../a.php"); </span> </li> <li class="alt"><span>header("location:../b.php"); </span></li> <li class=""> <span></span><span class="tag"><strong><font color="#006699">?></font></strong></span><span> </span> </li> <li class="alt"> <span></span><strong><font color="#006699"><span class="tag"><span class="tag-name">html</span><span class="tag">></span><span class="tag"><span class="tag-name">head</span><span class="tag">></span><span class="tag"></span><span class="tag-name">head</span><span class="tag">></span><span class="tag"><span class="tag-name">body</span><span class="tag">></span><span class="tag"></span><span class="tag-name">body</span><span class="tag">></span><span class="tag"></span><span class="tag-name">html</span><span class="tag">></span></span></span></span></font></strong><span> </span> </li> </ol>
我们发现它重定向b.php.
原来在asp中执行redirect后不会再执行后面的代码.
而php在执行header后,继续执行下面的代码.
在这方面上php中的header重定向不如asp中的重定向.有时我们要重定向后,不能执行后面的代码:
一般地我们用
<ol class="dp-xml"> <li class="alt"><span><span>if(...) </span></span></li> <li class=""><span>header("..."); </span></li> <li class="alt"><span>else </span></li> <li class=""><span>{ </span></li> <li class="alt"><span>... </span></li> <li class=""><span>} </span></li> </ol>
但是我们可以简单的用下面的方法:
<ol class="dp-xml"> <li class="alt"><span><span>if(...) </span></span></li> <li class=""><span>{ header("...");exit();} </span></li> </ol>
PHP中用header还要注意的是,如果是用Unicode(UTF-8)编码时也会出现问题,需要调整缓存设置.
<ol class="dp-xml"> <li class="alt"><span><span class="tag"><strong><font color="#006699"></font></strong></span><span>[</span><span class="attribute"><font color="#ff0000">email</font></span><span>=%@]%@</span><span class="attribute"><font color="#ff0000">LANGUAGE</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">"VBSCRIPT[/email]"</font></span><span> </span><span class="attribute"><font color="#ff0000">CODEPAGE</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">"936"</font></span><span>%</span><span class="tag"><strong><font color="#006699">></font></strong></span><span> </span></span></li> <li class=""> <span></span><span class="tag"><strong><font color="#006699"></font></strong></span><span>%if Request.ServerVariables("SERVER_NAME")="s.jb51.net" then </span> </li> <li class="alt"><span>response.redirect "news/index.htm" </span></li> <li class=""> <span>else%</span><span class="tag"><strong><font color="#006699">></font></strong></span><span> </span> </li> <li class="alt"> <span></span><span class="tag"><strong><font color="#006699"></font></strong></span><span>%end if%</span><span class="tag"><strong><font color="#006699">></font></strong></span><span> </span> </li> <li class=""> <span></span><strong><font color="#006699"><span class="tag"><span class="tag-name">script</span><span class="tag">></span></span></font></strong><span> </span> </li> <li class="alt"> <span>var </span><span class="attribute"><font color="#ff0000">url</font></span><span> = </span><span class="attribute-value"><font color="#0000ff">location</font></span><span>.href; </span> </li> <li class=""> <span>if(url.indexOf('http://www.jb51.net/')!=-1)</span><span class="attribute"><font color="#ff0000">location.href</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">'/index/index.htm'</font></span><span>; </span> </li> <li class="alt"> <span>if(url.indexOf('http://www.kanshule.com/')!=-1)</span><span class="attribute"><font color="#ff0000">location.href</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">'/index1/index.htm'</font></span><span>; </span> </li> <li class=""> <span>if(url.indexOf('http://www.shouji17.com/')!=-1)</span><span class="attribute"><font color="#ff0000">location.href</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">'/cn/index.asp'</font></span><span>; </span> </li> <li class="alt"> <span>if(url.indexOf('http://www.baidu.com/')!=-1)</span><span class="attribute"><font color="#ff0000">location.href</font></span><span>=</span><span class="attribute-value"><font color="#0000ff">'/cn/index.asp'</font></span><span>; </span> </li> <li class=""> <span></span><strong><font color="#006699"><span class="tag"></span><span class="tag-name">script</span><span class="tag">></span></font></strong><span> </span> </li> </ol>

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()

ToretrievedatafromaPHPsession,startthesessionwithsession_start()andaccessvariablesinthe$_SESSIONarray.Forexample:1)Startthesession:session_start().2)Retrievedata:$username=$_SESSION['username'];echo"Welcome,".$username;.Sessionsareserver-si

利用會話構建高效購物車系統的步驟包括:1)理解會話的定義與作用,會話是服務器端的存儲機制,用於跨請求維護用戶狀態;2)實現基本的會話管理,如添加商品到購物車;3)擴展到高級用法,支持商品數量管理和刪除;4)優化性能和安全性,通過持久化會話數據和使用安全的會話標識符。

本文討論了PHP中的crypt()和password_hash()的差異,以進行密碼哈希,重點介紹其實施,安全性和對現代Web應用程序的適用性。

文章討論了通過輸入驗證,輸出編碼以及使用OWASP ESAPI和HTML淨化器之類的工具來防止PHP中的跨站點腳本(XSS)。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

WebStorm Mac版
好用的JavaScript開發工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器