如何使用 PHP 修復(fù) MySQL 8.0 中的'服務(wù)器請(qǐng)求客戶端未知的身份驗(yàn)證方法”錯(cuò)誤?
Dec 14, 2024 am 05:45 AMMySQL 8.0 錯(cuò)誤:解決與 PHP 應(yīng)用程序的身份驗(yàn)證不一致
連接到 MySQL 8.0 數(shù)據(jù)庫(kù)的 PHP 開發(fā)人員可能會(huì)遇到錯(cuò)誤“服務(wù)器請(qǐng)求身份驗(yàn)證”客戶不知道的方法?!贝隋e(cuò)誤通常是由于 MySQL 數(shù)據(jù)庫(kù)和 PHP 應(yīng)用程序使用的身份驗(yàn)證方法不匹配造成的。
身份驗(yàn)證方法沖突:
MySQL 8.0 使用 caching_sha2_password 作為其默認(rèn)身份驗(yàn)證方法,而許多 PHP 應(yīng)用程序希望使用傳統(tǒng)的基于密碼的身份驗(yàn)證。當(dāng)應(yīng)用程序嘗試使用不正確的身份驗(yàn)證方法連接到數(shù)據(jù)庫(kù)時(shí),服務(wù)器會(huì)返回上述錯(cuò)誤。
解決方案:
要解決此問題,有必要修改 MySQL 數(shù)據(jù)庫(kù)使用的身份驗(yàn)證方法以匹配 PHP 應(yīng)用程序所需的身份驗(yàn)證方法。這可以通過(guò)將 MySQL 數(shù)據(jù)庫(kù)的身份驗(yàn)證插件切換為 mysql_native_password 來(lái)實(shí)現(xiàn),它支持基于密碼的身份驗(yàn)證。
更改身份驗(yàn)證插件的步驟:
- 登錄以 MySQL 為根user:
mysql -u root -p
- 運(yùn)行以下 SQL 命令來(lái)更改 root 用戶的身份驗(yàn)證插件:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'new_password';
將 'new_password' 替換為您選擇的安全密碼。
- 如果您的 PHP 應(yīng)用程序使用非 root 用戶,請(qǐng)重復(fù)對(duì)于該用戶,執(zhí)行第 2 步,將“root”替換為適當(dāng)?shù)挠脩裘?/li>
- 重新啟動(dòng) MySQL 服務(wù)以使更改生效。
其他資源:
有關(guān)此主題的更多信息,請(qǐng)參閱以下內(nèi)容資源:
- [Digital Ocean:安裝 MySQL](https://www.digitalocean.com/community/tutorials/how-to-install-mysql-on-ubuntu-20-04)
- [MySQL 文檔:默認(rèn)身份驗(yàn)證插件](https://dev.mysql.com/doc/refman/8.0/en/server-options.html#sysvar_default_authentication_plugin)
以上是如何使用 PHP 修復(fù) MySQL 8.0 中的'服務(wù)器請(qǐng)求客戶端未知的身份驗(yàn)證方法”錯(cuò)誤?的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

熱AI工具

Undress AI Tool
免費(fèi)脫衣服圖片

Undresser.AI Undress
人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover
用于從照片中去除衣服的在線人工智能工具。

Clothoff.io
AI脫衣機(jī)

Video Face Swap
使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費(fèi)的代碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁(yè)開發(fā)工具

SublimeText3 Mac版
神級(jí)代碼編輯軟件(SublimeText3)

PHP變量作用域常見問題及解決方法包括:1.函數(shù)內(nèi)部無(wú)法訪問全局變量,需使用global關(guān)鍵字或參數(shù)傳入;2.靜態(tài)變量用static聲明,只初始化一次并在多次調(diào)用間保持值;3.超全局變量如$_GET、$_POST可在任何作用域直接使用,但需注意安全過(guò)濾;4.匿名函數(shù)需通過(guò)use關(guān)鍵字引入父作用域變量,修改外部變量則需傳遞引用。掌握這些規(guī)則有助于避免錯(cuò)誤并提升代碼穩(wěn)定性。

要安全處理PHP文件上傳需驗(yàn)證來(lái)源與類型、控制文件名與路徑、設(shè)置服務(wù)器限制并二次處理媒體文件。1.驗(yàn)證上傳來(lái)源通過(guò)token防止CSRF并通過(guò)finfo_file檢測(cè)真實(shí)MIME類型使用白名單控制;2.重命名文件為隨機(jī)字符串并根據(jù)檢測(cè)類型決定擴(kuò)展名存儲(chǔ)至非Web目錄;3.PHP配置限制上傳大小及臨時(shí)目錄Nginx/Apache禁止訪問上傳目錄;4.GD庫(kù)重新保存圖片清除潛在惡意數(shù)據(jù)。

PHP注釋代碼常用方法有三種:1.單行注釋用//或#屏蔽一行代碼,推薦使用//;2.多行注釋用/.../包裹代碼塊,不可嵌套但可跨行;3.組合技巧注釋如用/if(){}/控制邏輯塊,或配合編輯器快捷鍵提升效率,使用時(shí)需注意閉合符號(hào)和避免嵌套。

AgeneratorinPHPisamemory-efficientwaytoiterateoverlargedatasetsbyyieldingvaluesoneatatimeinsteadofreturningthemallatonce.1.Generatorsusetheyieldkeywordtoproducevaluesondemand,reducingmemoryusage.2.Theyareusefulforhandlingbigloops,readinglargefiles,or

寫好PHP注釋的關(guān)鍵在于明確目的與規(guī)范,注釋應(yīng)解釋“為什么”而非“做了什么”,避免冗余或過(guò)于簡(jiǎn)單。1.使用統(tǒng)一格式,如docblock(/*/)用于類、方法說(shuō)明,提升可讀性與工具兼容性;2.強(qiáng)調(diào)邏輯背后的原因,如說(shuō)明為何需手動(dòng)輸出JS跳轉(zhuǎn);3.在復(fù)雜代碼前添加總覽性說(shuō)明,分步驟描述流程,幫助理解整體思路;4.合理使用TODO和FIXME標(biāo)記待辦事項(xiàng)與問題,便于后續(xù)追蹤與協(xié)作。好的注釋能降低溝通成本,提升代碼維護(hù)效率。

ToinstallPHPquickly,useXAMPPonWindowsorHomebrewonmacOS.1.OnWindows,downloadandinstallXAMPP,selectcomponents,startApache,andplacefilesinhtdocs.2.Alternatively,manuallyinstallPHPfromphp.netandsetupaserverlikeApache.3.OnmacOS,installHomebrew,thenrun'bre

在PHP中獲取字符串特定索引字符可用方括號(hào)或花括號(hào),但推薦方括號(hào);索引從0開始,超出范圍訪問返回空值,不可賦值;處理多字節(jié)字符需用mb_substr。例如:$str="hello";echo$str[0];輸出h;而中文等字符需用mb_substr($str,1,1)獲取正確結(jié)果;實(shí)際應(yīng)用中循環(huán)訪問前應(yīng)檢查字符串長(zhǎng)度,動(dòng)態(tài)字符串需驗(yàn)證有效性,多語(yǔ)言項(xiàng)目建議統(tǒng)一使用多字節(jié)安全函數(shù)。

易于效率,啟動(dòng)啟動(dòng)tingupalocalserverenverenvirestoolslikexamppandacodeeditorlikevscode.1)installxamppforapache,mysql,andphp.2)uscodeeditorforsyntaxssupport.3)
