PhpMyAdmin启用双因子认证(2FA),及异常问题排查

首先示例下启用2FA的过程,文末会附上一些遇到的问题,及原因和解决方案。

1. 启用双因素身份认证

在这里插入图片描述

2. 使用2FA工具扫码或手动录入密钥,然后在下面的输入框中输入工具上生成的动态code,并点击启用双因素身份认证。

2FA工具可以使用华为云等app.
这里只是示例图片,不用为我的key泄露担心。
在这里插入图片描述

3. 然后退出账号,重新登录,可以看到会要求输入动态认证代码。

在这里插入图片描述

以上是正常情形下的流程,但是配置过程中难免会遇到其它一些问题。

  1. 配置后未生效。 pma再配置未成功写入时,可能不展示错误。
    解决方案:检查是否启用了phpMyAdmin configuration storage,通常是将安装目录下的sql/create_table执行,创建pma需要的存储表。 检查用户是否有写上面表的权限;

  2. 查看服务器日志,如nginx, 发现下面错误:

FastCGI sent in stderr: "PHP message: PHP Fatal error:  Uncaught Error: Call to undefined method BaconQrCode\Renderer\Image\SvgImageBackEnd::getQRCodeInline() in xxxxxxx/vendor/pragmarx/google2fa-qrcode/src/Google2FA.php:64

解决方案:这个通常是pma与依赖不兼容,造成的。删除vendor, composer.lock,然后重新compoer install;

  1. pma会使用多种可选方案来生成二维码图片,如下面是其源码
public function getImageBackend()
{
    if (empty($this->imageBackEnd)) {
        $this->imageBackEnd = !$this->imagickIsAvailable()
            ? new SvgImageBackEnd()
            : new ImagickImageBackEnd();
    }

    $this->setImageBackEnd($this->imageBackEnd);

    return $this->imageBackEnd;
}

可以看到再未安装php-imagick扩展时,是使用的矢量图, 如果安装了php-imagick扩展则会使用 ImagickImageBackEnd生成图片(这种情形下有时候,图片大小不受控制。)

  1. 如果遇到其它错误,看一查看日志,或者跟踪源码执行来定位问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值