Karp 的技术博客
踩坑教训
Aws 非公开桶资源 PHP sdk 解决方案

<?php


use Aws\S3\S3Client;
use Model\Main\Config\DbModel;

class AwsOss
{
    const IMG = 1;
    const MP4_VIDEO = 2;

    /**
     * 获取解密后 base64文件
     * @cli php cli.php Test getObjectUrl
     * @param string $url
     * @param int $fileType 1 图片 2 mp4视频
     * @return string
     * @throws \Exception
     */
    public static function getUrlBase64(string $url, int $fileType)
    {
        $config = DbModel::formatDbConfig(AwsOss::AWS_OSS_PUBLIC_TAG);

        return self::getKycBase64File($url, $config, $fileType);
    }

    /**
     * 获取二进制加密文件
     * @param $url
     * @param array $config aws 桶配置
     * @param int $fileType 1 图片类型 2 视频类型(mp4)
     * @return string
     * @throws \Exception
     */
    private static function getKycBase64File($url, array $config, $fileType = self::IMG)
    {
        $bucket = $config['bucket'];
        $sdKParams = $config['sdk_params'];

        $fileKey = trim(parse_url($url)['path'], '/'); // 一定不能带 /

        $s3Client = new S3Client($sdKParams);
        // 下载文件资源
        $result = $s3Client->getObject(['Bucket' => $bucket, 'Key' => $fileKey]);

        $fileSourceObj = $result['Body'] ?? "";
        if ('' === $fileSourceObj) {
            throw new \Exception('文件资源拉取失败');
        }

        if ($fileType == 1) {
            $type = getimagesizefromstring($fileSourceObj)['mime']; //获取二进制流图片格式
        } else {
            $type = 'audio/mp4';
        }

        return 'data:' . $type . ';base64,' . chunk_split(base64_encode($fileSourceObj));
    }

}
踩坑教训
MySQL 5.7下InnoDB对COUNT(*)的优化与MySQL 5.6性能对比

MySQL 5.7 COUNT()会选择聚集索引,进行一次内部handler函数调用,即可快速获得该表总数

踩坑教训
Mysql 更新记录报错"Truncated incorrect DOUBLE value: 'CC2C3872-25E2-4ABB-BE24-7A293DB4BD3E'"

解决MySQL更新记录报错"Truncated incorrect DOUBLE value: 'CC2C3872-25E2-4ABB-BE24-7A293DB4BD3E'"

踩坑教训
[踩坑] PHP http_build_query 字符 @ 转义 %40

几个月来第一篇文章
吐槽下币安的aws服务,对于不同地区服务器访问,aws cloudfont 限制不同。
我有日本亚马逊服务器 也有 香港谷歌服务器,真的是不同服务不同待遇。

踩坑教训
编译安装PHP组件出现错误提示内存不足:virtual memory exhausted Cannot allocate memory

编译php7.4的版本的make && make install这一步出现错误,提示: