使用 mysqli_connect 解决 MySQL 身份验证错误:“未知身份验证方法 [caching_sha2_password]”
尝试使用 mysqli_connect 建立数据库连接时,您可能会遇到错误,指出“服务器请求客户端未知的身份验证方法 [caching_sha2_password]。”此错误是由于 MySQL 服务器上配置的身份验证方法与 PHP 代码支持的方法不匹配而引起的。
具体来说,MySQL 服务器 ini 文件将 default_authentication_plugin 设置为 caching_sha2_password。该插件提供了增强的安全性,但需要客户端支持该方法。但是,您的 PHP 代码使用默认的 MySQL 本机密码身份验证机制,该机制与 caching_sha2_password 不兼容。
要解决此问题,您有两个选择:
选项 1:更改身份验证插件MySQL服务器
您可以将MySQL服务器ini文件中的default_authentication_plugin更改为mysql_native_password。这将允许您的 PHP 代码使用本机密码身份验证方法进行连接。
选项 2:在 PHP 代码中指定身份验证方法
或者,您可以在 PHP 代码中指定要匹配的身份验证方法服务器的配置。这可以通过在调用 mysqli_connect() 之前使用 mysqli_options() 函数来完成。
mysqli_options(mysqli, MYSQLI_OPT_AUTH_PLUGIN, 'caching_sha2_password');
更改用户身份验证
如果上述选项都不能解决问题,您可能需要更改尝试连接的特定用户的身份验证方法。这可以使用以下 SQL 命令来完成:
ALTER USER 'username'@'hostname' IDENTIFIED WITH mysql_native_password BY 'new_password';
通过实施这些解决方案,尽管服务器上设置了默认身份验证方法,您也可以使用 mysqli_connect 成功建立与 MySQL 的连接。
以上是如何修复 mysqli_connect 的 MySQL'未知身份验证方法 [caching_sha2_password]”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

TheSecretTokeEpingAphp-PowerEdwebSiterUnningSmoothlyShyunderHeavyLoadInVolvOLVOLVOLDEVERSALKEYSTRATICES:1)emplactopCodeCachingWithOpcachingWithOpCacheToreCescriptexecution Time,2)使用atabasequercachingCachingCachingWithRedataBasEndataBaseLeSendataBaseLoad,3)

你应该关心DependencyInjection(DI),因为它能让你的代码更清晰、更易维护。1)DI通过解耦类,使其更模块化,2)提高了测试的便捷性和代码的灵活性,3)使用DI容器可以管理复杂的依赖关系,但要注意性能影响和循环依赖问题,4)最佳实践是依赖于抽象接口,实现松散耦合。

是的,优化papplicationispossibleandessential.1)empartcachingingcachingusedapcutorediucedsatabaseload.2)优化的atabaseswithexing,高效Quereteries,and ConconnectionPooling.3)EnhanceCodeWithBuilt-unctions,避免使用,避免使用ingglobalalairaiables,并避免使用

theKeyStrategiestosiminificallyBoostphpapplicationPermenCeare:1)useOpCodeCachingLikeLikeLikeLikeLikeCacheToreDuceExecutiontime,2)优化AtabaseInteractionswithPreparedStateTemtStatementStatementSandProperIndexing,3)配置

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增强codemodocultion,可验证性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

选择DependencyInjection(DI)用于大型应用,ServiceLocator适合小型项目或原型。1)DI通过构造函数注入依赖,提高代码的测试性和模块化。2)ServiceLocator通过中心注册获取服务,方便但可能导致代码耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)启用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替换loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化进行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

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

WebStorm Mac版
好用的JavaScript开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

SublimeText3 Linux新版
SublimeText3 Linux最新版

Dreamweaver CS6
视觉化网页开发工具