使用str-replace而不是ereg-replace
習慣使用Perl進行程式設計的程式設計師更願意使用ereg_replace完成字串替換工作,因為在PHP中ereg_replace的用法和Perl中模式匹配的用法相近。但是,下面的這段程式碼證明,使用str_replace 取代 ereg_replace將可以大大提高程式碼的運行速度。
測試str_replace與ereg_replace的運轉速度
//這段程式碼測試str_replace的運行速度
$i=0; $i str_replace(i>, b>, $string).
}
段程式碼測試ereg_replace的運轉速度
for ($i=0; $i, , $string).
}
?>
結論
使用str_replace的時間-
使用ereg_pattern的時間-
使用str_replace的時間- 0.089757
使用ereg_pattern的時間- 0.248881
從運作的結果我們可以看出使用str_replace替代ereg_replace作為字串替換函數,大幅提升了程式碼的運行速度。
3.注意字串的引用
PHP和其它許多程式語言一樣,可以使用雙引號("")來引用字串,也可以使用單引號()。但是在PHP中,如果使用雙引號來引用字串,那麼PHP解析器將首先分析字串中有沒有對變數的引用,並且有變數的話,將對變數進行替換。如果是單引號,則沒有如此複雜——直接將單引號包含起來的所有字串直接顯示出來。顯然,在PHP程式設計中,如果使用單引號引用字串變數要比使用雙引號快速一些。
4.在資料庫中避免使用聯合作業
比起其它的Web程式語言來說,PHP的資料庫功能十分強大。但是在PHP中資料庫的運作仍然是一件十分費時費力的事情,所以,作為一個Web程式設計師,要盡量減少資料庫的查詢操作,同時應該為資料庫建立適當的索引。另一件值得注意的事情是在用PHP操作資料庫時,盡可能不使用多個資料表的聯合操作,儘管聯合操作可以增強資料庫的查詢功能,但是卻大大增加了伺服器的負擔。
為了說明這個問題,我們可以看看下面的這個簡單的例子。
我們在資料庫中建立了兩個資料表foo和big_foo。在資料表foo中,只有一個字段,包含了從1-1000之間的所有自然數。資料表big_foo同樣只有一個字段,但包含了從1-1,000,000之間的全部自然數。所以,從大小上說,big_foo等於foo與它本身進行了聯合操作。
$db->query("select * from foo");
0.032273 secs
$db->next_record();
->query("insert into foo values (NULL)");
0.019506 secs
$db->query("select * from foo as a, foo as b");
17.2805 "select * from foo as a, foo as b where a.id > b.id");
14.645251 secs
$db->query("select * from foo as aere, foo $db->query("selectas aere a. id = b.id");
0.041269 secs
$db->query("select * from big_foo");
25.393672 secs
在PHP變成中,include()與require()的功能相同,但在用法上卻有些不同,include()是有條件包含函數,而require()則是無條件包含函數。例如在下面的範例中,如果變數$somgthing為真,則會包含文件somefile:
if($something){
include("somefile");
}
something取何值,下面的程式碼會把文件somefile包含進文件裡:
if($something){
require("somefile");
}
說明了這兩個函數之間的差異。
$i = 1;
while ($i require("somefile.$i");
$i+在這個程式碼中; ,每一次循環的時候,程式都會把同一個檔案包含進去。很顯然這不是程式設計師的初衷,從程式碼中我們可以看出這段程式碼希望在每次循環時,將不同的檔案包含進來。如果要完成這個功能,必須求助函數include():
$i = 1;
while ($i include("somefile.$i")
include("somefile.$i")
; ;
}
6.注意echo和print的差異
PHP中echo和print的功能基本上相同,但兩者之間也有微差異。在PHP程式碼中可以把print當作一個普通函數來使用,例如執行下面的程式碼後變數$res的值將為1。
$ret = print "Hello World";
這表示print可用在一些複雜的表達式中,而echo則不行。同樣,在程式碼中echo語句的運行速度要略微快於print語句,因為echo語句不要求傳回任何數值

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
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Dreamweaver CS6
視覺化網頁開發工具

記事本++7.3.1
好用且免費的程式碼編輯器

Atom編輯器mac版下載
最受歡迎的的開源編輯器

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