搜尋
首頁後端開發PHP問題如何使用PHP中的斷言函數

本篇文章要介紹一下使用PHP中斷言函數的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

如何使用PHP中的斷言函數

原來一直以為斷言相關的函數是PHPUnit 這些單元測試元件提供的,在閱讀手冊後才發現,這個assert() 斷言函數是PHP 本身就自帶的一個函數。也就是說,我們在程式碼中進行簡單的測試的時候是不需要完全引入整個單元測試組件的。

assert() 斷言函數

assert(1==1);

assert(1==2);
// assert.exception = 0 时,Warning: assert(): assert(1 == 2)
// assert.exception = 1 时,Fatal error: Uncaught AssertionError: 验证不通过

很明顯,第二段程式碼無法透過斷言驗證。這時,PHP 就會回傳一個警告或異常錯誤。為什麼有可能是兩種錯誤形式呢?當我們設定 php.ini 中的 assert.exception 為 off 或 0 時,也就是關閉這個參數的能力時,程式就會以 PHP5 的形式依然傳回一個警告,就像上面程式碼中的註解一樣。

同時,透過 try...catch 也無法進行異常的捕捉了。這個參數其實就是控制是否以正宗的異常物件進行拋出。如果保持這個參數為預設情況也就是設定為 on 或 1 的話,就會直接拋出異常,程式中止。

從上述程式碼可以看出,斷言的第一個參數是一個表達式,而且是需要一個傳回 bool 類型物件的表達式。如果我們傳遞的是一個字串或數字呢?

// 设置 assert.exception = 0 进行多条测试

assert(" ");
// Deprecated: assert(): Calling assert() with a string argument is deprecated
// Warning: assert(): Assertion " " failed

assert("1");
// Deprecated: assert(): Calling assert() with a string argument is deprecated

assert(0);
// Warning: assert(): assert(0) failed

assert(1);

assert("1==2");
// Deprecated: assert(): Calling assert() with a string argument is deprecated
// Warning: assert(): Assertion "1==2" failed

很明顯第一個參數的表達式會進行類型強制轉換,但是字串類型會多出一個過時提醒,表示給assert() 函數傳遞字串類型的表達式類型已經過時了。目前的測試版本是 7.3 ,在將來可能就會直接報中止運行的錯誤或異常了。

主要問題在於,如果傳遞的字串本身也是一個表達式的話,會以這個表達式的內容為基礎進行判斷,這樣很容易產生歧義,就像最後一段程式碼一樣。當然,已經過時的使用方式還是不建議的,這裡僅是做一個了解即可。

接下來我們來看看assert() 函數的其他參數,它的第二個參數是兩種類型,要麼給一個字串用來定義錯誤的訊息,要麼給一個異常類別用於拋出異常。

assert(1==1, "验证不通过");

assert(1==2, "验证不通过");
// Warning: assert(): 验证不通过 failed

如果直接給的一個字串,那麼在警告的提示訊息中,顯示的就是我們定義的這個錯誤訊息的內容。這個非常好理解。

// 注意 assert.exception 设置不同的区别

assert(1==1,  new Exception("验证不通过"));

assert(1==2,  new Exception("验证不通过"));
// assert.exception = 1 时,Fatal error: Uncaught Exception: 验证不通过
// assert.exception = 0 时,Warning: assert(): Exception: 验证不通过

當然,我們也可以給一個 例外類別 讓斷言拋出一個例外。在預設情況下,這個異常的拋出將中止程式的運作。也就是一個正常的異常拋出流程,我們可以使用 try...catch 進行異常的捕捉。

try{
    assert(1==2,  new Exception("验证不通过"));
}catch(Exception $e){
    echo "验证失败!:", $e->getMessage(), PHP_EOL;
}
// 验证失败!:验证不通过

另外還有一個參數會對斷言的整體運行產生影響,那就是 php.ini 中的 zend.assertions 參數。它包含三個值:

  • 1,產生並執行程式碼,一般在測試環境使用
  • 0,生成程式碼但是在運行時會路過
  • #- 1,不產生程式碼,一般在正式環境使用

這個參數大家可以自行設定測試,預設的php.ini 中它的預設值是1 ,也就是正常的執行assert() 函數。

assert_options() 及相對應的php.ini 中的參數配置

PHP 中的斷言功能也為我們提供了一個assert_options() 函數,用於方便地設定和獲取一些和斷言能力有關的參數配置。它能夠設定的斷言標誌包括:

標誌| INI設定| 預設值| 描述

  • ##(NULL)斷言失敗時呼叫回呼函數

    这些参数的含义都非常好理解,大家可以自己测试一下。我们就来看一下最后一个 ASSERT_CALLBACK 的作用。其实它的说明也非常清楚,就是断言失败的情况下就进入到这个选项定义的回调函数中。

    assert_options(ASSERT_ACTIVE, 1);
    assert_options(ASSERT_WARNING, 1);
    assert_options(ASSERT_BAIL, 1);
    
    assert_options(ASSERT_CALLBACK, function($params){
        echo "====faild====", PHP_EOL;
        var_dump($params);
        echo "====faild====", PHP_EOL;
    });
    
    assert(1!=1);
    // ====faild====
    // string(105) ".../source/一起学习PHP中断言函数的使用.php"
    // ====faild====

    当断言失败的时候,我们就进入了回调函数中,在回调函数直接简单的打印了传给回调函数的参数内容。可以看出,这个回调函数里面传递过来的是无法通过断言的文件信息。

    总结

    学习掌握一下断言函数的使用及配置,可以为我们将来学习 PHPUnit 单元测试打下基础,当然,本身这个能力的东西就不是很多,大家记住就好啦!

    测试代码:

    https://github.com/zhangyue0503/dev-blog/blob/master/php/202005/source/%E4%B8%80%E8%B5%B7%E5%AD%A6%E4%B9%A0PHP%E4%B8%AD%E6%96%AD%E8%A8%80%E5%87%BD%E6%95%B0%E7%9A%84%E4%BD%BF%E7%94%A8.php

    推荐学习:php视频教程

    ASSERT_ACTIVE #assert.active 1 啟用assert() 斷言
    ASSERT_WARNING assert.warning # 1 為每個失敗的斷言產生一個PHP 警告(warning)
    #ASSERT_BAIL assert.bail #0 在斷言失敗時中止執行
    ASSERT_QUIET_EVAL assert.quiet_eval 0 #在斷言表達式求值時停用error_reporting
    ASSERT_CALLBACK #assert.callback

以上是如何使用PHP中的斷言函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:segmentfault。如有侵權,請聯絡admin@php.cn刪除
酸與基本數據庫:差異和何時使用。酸與基本數據庫:差異和何時使用。Mar 26, 2025 pm 04:19 PM

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

PHP安全文件上傳:防止與文件相關的漏洞。PHP安全文件上傳:防止與文件相關的漏洞。Mar 26, 2025 pm 04:18 PM

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

PHP輸入驗證:最佳實踐。PHP輸入驗證:最佳實踐。Mar 26, 2025 pm 04:17 PM

文章討論了PHP輸入驗證以增強安全性的最佳實踐,重點是使用內置功能,白名單方法和服務器端驗證等技術。

PHP API率限制:實施策略。PHP API率限制:實施策略。Mar 26, 2025 pm 04:16 PM

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

php密碼哈希:password_hash和password_verify。php密碼哈希:password_hash和password_verify。Mar 26, 2025 pm 04:15 PM

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

OWASP前10 php:描述並減輕常見漏洞。OWASP前10 php:描述並減輕常見漏洞。Mar 26, 2025 pm 04:13 PM

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

PHP XSS預防:如何預防XSS。PHP XSS預防:如何預防XSS。Mar 26, 2025 pm 04:12 PM

本文討論了防止PHP中XSS攻擊的策略,專注於輸入消毒,輸出編碼以及使用安全增強的庫和框架。

PHP接口與抽像類:何時使用。PHP接口與抽像類:何時使用。Mar 26, 2025 pm 04:11 PM

本文討論了PHP中接口和抽像類的使用,重點是何時使用。界面定義了無實施的合同,適用於無關類和多重繼承。摘要類提供常見功能

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 Mac版

SublimeText3 Mac版

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

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具