偵測步驟:1、使用preg_replace()來配合正規表示式過濾字串,去掉字串中的非中文字母,語法「preg_replace("/[^\x{4E00}-\x{9FFF }] /u",'', 原始字串)”,會傳回一個包含全部中文字母的過濾字串;2、利用“===”判斷過濾字串是否為空字串,語法“過濾字串===''”,若等於則原字串中不包含中文,反之則原字串中包含中文。
本教學操作環境:windows7系統、PHP8.1版、DELL G3電腦
在php中,可以使用preg_replace ()函數和「===」運算子來偵測字串中是否包含中文。
實作步驟:
#步驟1:使用preg_replace()函數來配合正規表示式過濾字串,去掉字串中的非中文字母
preg_replace() 函數可以執行正規表示式的搜尋和替換;只需要利用正規表示式搜尋字串中的非中文字母,並將其替換成空字元''
即可。
正規表示式為:
/[^\x{4E00}-\x{9FFF}] /u
$pattern = "/[^\x{4E00}-\x{9FFF}]+/u"; $newStr=preg_replace($pattern,'', $str);
#會傳回一個包含全部中文字母的過濾字串
步驟2:利用「===」運算子判斷過濾字串是否為空字串
$newStr===''
如果等於,則原始字串中不包含中文
#如果不等於,則原始字串中包含中文
#實作程式碼:
function f($str){ echo "原字符串:"; var_dump($str); $pattern = "/[^\x{4E00}-\x{9FFF}]+/u"; $newStr=preg_replace($pattern,'', $str); if($newStr===''){ echo "字符串中不包含中文
"; }else{ echo "字符串中包含中文
"; } }
呼叫上面的f($str)函數
$str1= 'php中文网!-=1548'; f($str1); $str2 = "123456"; f($str2);
說明:
preg_replace()函數
preg_replace() 函數可以執行正規表示式的搜尋和替換,是一個強大的字串替換處理函數,該函數的語法格式如下:
preg_replace($pattern, $replacement, $subject [, $limit = -1 [, &$count]])
參數說明如下:
- $pattern:要搜尋的模式,可以使一個字串或字串陣列;
- $replacement:用於替換的字串或字串陣列。如果這個參數是一個字串,而 $pattern 是一個數組,那麼所有的模式都使用這個字串進行替換。如果 $pattern 和 $replacement 都是數組,每個 $pattern 使用 $replacement 中對應的元素進行替換。如果 $replacement 中的元素比 $pattern 中的少,多出來的 $pattern 使用空字串進行替換。
- $subject:要進行搜尋和替換的字串或字串數組,如果$subject 是一個數組,搜尋和替換回在$subject 的每一個元素上進行, 並且返回值也會是一個數組。
- $limit:可選參數,每個模式在每個 $subject 上進行替換的最大次數。預設是 -1(無限)。
- $count:可選參數,如果指定,將會被填入完成的替換次數。
如果 $subject 是一個數組,preg_replace() 函數會傳回一個數組,在其他情況下會傳回字串。
如果函數 preg_replace() 搜尋到符合項,則會傳回被取代後的 $subject,否則傳回沒有改變的 $subject。 preg_replace() 函數的每個參數(除了參數 $limit)可以是一個陣列。如果參數 $pattern 和參數 $replacement 都是數組,那麼函數將以其鍵名在數組中出現的順序來進行處理。如果發生錯誤,則傳回 NULL。
參數 $replacement 中可以包含後向引用 \\n 或 $n,語法上首選後者。每個這樣的引用將被匹配到的第 n 個捕獲子組捕獲到的文本替換。 n 可以是 0-99,\\0 和 $0 代表完整的模式匹配文字。
捕獲子組的序號計數方式為:代表捕獲子組的左括號從左到右,從 1 開始數。如果要在$replacement 中使用反斜線,必須使用4 個("\\\\" 因為這首先是php 的字串,經過轉義後是兩個,再經過正規表示式引擎後才被認為是一個原文反斜線)。
當在替換模式下工作並且後向引用後面緊跟著需要是另外一個數字(比如:在一個匹配模式後緊接著增加一個原文數字),不能使用\\1 這樣的語法來描述後向引用。例如,\\11 將會使 preg_replace() 無法理解你希望的是一個 \\1 後向引用緊接一個原文 1,還是一個 \\11 後向引用後面不跟任何東西。這種情況下解是使用 ${1}1。這創建了一個獨立的 $1 後向引用,一個獨立的原文 1。
当使用被弃用的 e 修饰符时,这个函数会转义一些字符(即:'、"、\ 和 NULL)然后进行后向引用替换。当这些完成后请确保后向引用解析完后没有单引号或双引号引起的语法错误(比如:'strlen(\'$1\')+strlen("$2")')。确保符合 PHP 的字符串语法,并且符合 eval 语法。因为在完成替换后,引擎会将结果字符串作为 php 代码使用 eval 方式进行评估并将返回值作为最终参与替换的字符串。
恒等式(===)运算符
恒等式(===)运算符是进行给定变量或值之间的严格比较;它比较,并查看两个变量(表达式或常量)是否值相等且具有相同的数据类型,即两者都是字符串或两者都是整数等等。
如果两个变量(表达式或常量)包含相同的值和相同的数据类型,则此运算符返回true,否则返回false。
示例:
<?php header("content-type:text/html;charset=utf-8"); // 给变量赋整数值 $x = 999; echo '$x='.$x."<br>"; // 给变量赋字符串值 $y = '999'; echo '$y='.$y."<br>"; //比较$x 和$y if ($x === $y) echo '$x和$y相等'; else echo '$x和$y不相等'; ?>
输出:
说明:在上面的例子中,$ x和$ y的值相等但数据类型不同,因而返回false,执行else部分。
推荐学习:《PHP视频教程》
以上是php怎麼檢測字串中是否包含中文的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文比較了酸和基本數據庫模型,詳細介紹了它們的特徵和適當的用例。酸優先確定數據完整性和一致性,適合財務和電子商務應用程序,而基礎則側重於可用性和

本文討論了確保PHP文件上傳的確保,以防止諸如代碼注入之類的漏洞。它專注於文件類型驗證,安全存儲和錯誤處理以增強應用程序安全性。

本文討論了在PHP中實施API速率限制的策略,包括諸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之類的庫。它還涵蓋監視,動態調整速率限制和手

本文討論了使用password_hash和pyspasswify在PHP中使用密碼的好處。主要論點是,這些功能通過自動鹽,強大的哈希算法和SECH來增強密碼保護

本文討論了OWASP在PHP和緩解策略中的十大漏洞。關鍵問題包括注射,驗證損壞和XSS,並提供用於監視和保護PHP應用程序的推薦工具。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

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

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