mysql 碰到特殊字符,造成了数据不全

本文介绍了解决MySQL数据库中存储特殊字符导致数据不全的问题。通过使用PHP脚本进行字符过滤和转换,确保了数据的完整性和正确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mysql 遇到特殊字符,造成了数据不全
我是把数组序列化之后存入数据库的某个字段,但是数组中有些数据的值带有特殊字符,如图:

保存在数据库之后就成这样子了


类似这样的特殊字符还有很多的;

丢失了一部分数据,哪位哥哥遇到过这种情况吗?请赐教。
------解决思路----------------------

<span style="color:#000000">header('Content-type: text/html;charset=utf-8');
$s = '6b6Z5Y2O8K+gpQ==';
echo $t = base64_decode($s), PHP_EOL;
echo bin2hex($t);</span>

龙华
------解决思路----------------------
把不是utf8的字符過濾就可以了。

<span style="color:#000000">
header('Content-type: text/html;charset=utf-8');
$s = '6b6Z5Y2O8K+gpTEyMzEyMzEyMw==';
$t = base64_decode($s). PHP_EOL;
echo $t.'
';
echo filter_utf8_char($t);

/** 過濾字符串,保留UTF8字母數字中文及部份符號 
*   @param  String  $ostr 
*   @return String 
*/  
function filter_utf8_char($ostr){  
    preg_match_all('/[\x{FF00}-\x{FFEF}
<span style="color:#FF8000">------解决思路----------------------</span>
\x{0000}-\x{00ff}
<span style="color:#FF8000">------解决思路----------------------</span>
\x{4e00}-\x{9fff}]+/u', $ostr, $matches);  
    $str = join('', $matches[0]);  
    if($str==''){   //含有特殊字符需要逐個處理  
        $returnstr = '';  
        $i = 0;  
        $str_length = strlen($ostr);  
        while ($i<=$str_length){  
            $temp_str = substr($ostr, $i, 1);  
            $ascnum = Ord($temp_str);  
            if ($ascnum>=224){  
                $returnstr = $returnstr.substr($ostr, $i, 3);  
                $i = $i + 3;  
            }elseif ($ascnum>=192){  
                $returnstr = $returnstr.substr($ostr, $i, 2);  
                $i = $i + 2;  
            }elseif ($ascnum>=65 && $ascnum<=90){  
                $returnstr = $returnstr.substr($ostr, $i, 1);  
                $i = $i + 1;  
            }elseif ($ascnum>=128 && $ascnum<=191){ // 特殊字符  
                $i = $i + 1;  
            }else{  
                $returnstr = $returnstr.substr($ostr, $i, 1);  
                $i = $i + 1;  
            }  
        }  
        $str = $returnstr;  
        preg_match_all('/[\x{FF00}-\x{FFEF}
<span style="color:#FF8000">------解决思路----------------------</span>
\x{0000}-\x{00ff}
<span style="color:#FF8000">------解决思路----------------------</span>
\x{4e00}-\x{9fff}]+/u', $str, $matches);  
        $str = join('', $matches[0]);  
    }  
    return $str;  
}  </span>

转自:http://www.php.cn/php-weizijiaocheng-204496.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值