• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 3年前 (2022-01-24) 15次浏览 已收录 0个评论

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

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

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

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

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

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

<br />header('Content-type: text/html;charset=utf-8');<br />$s = '6b6Z5Y2O8K+gpTEyMzEyMzEyMw==';<br />$t = base64_decode($s). PHP_EOL;<br />echo $t.'<br>';<br />echo filter_utf8_char($t);<br /><br />/** 過濾字符串,保留UTF8字母數字中文及部份符號 <br />*   @param  String  $ostr <br />*   @return String <br />*/  <br />function filter_utf8_char($ostr){  <br />    preg_match_all('/[\x{FF00}-\x{FFEF}<br><font color='#FF8000'>------解决思路----------------------</font><br>\x{0000}-\x{00ff}<br><font color='#FF8000'>------解决思路----------------------</font><br>\x{4e00}-\x{9fff}]+/u', $ostr, $matches);  <br />    $str = join('', $matches[0]);  <br />    if($str==''){   //含有特殊字符需要逐個處理  <br />        $returnstr = '';  <br />        $i = 0;  <br />        $str_length = strlen($ostr);  <br />        while ($i<=$str_length){  <br />            $temp_str = substr($ostr, $i, 1);  <br />            $ascnum = Ord($temp_str);  <br />            if ($ascnum>=224){  <br />                $returnstr = $returnstr.substr($ostr, $i, 3);  <br />                $i = $i + 3;  <br />            }elseif ($ascnum>=192){  <br />                $returnstr = $returnstr.substr($ostr, $i, 2);  <br />                $i = $i + 2;  <br />            }elseif ($ascnum>=65 && $ascnum<=90){  <br />                $re<p>5本文来源gao!daima.com搞$代!码#网#</p><pre>搞代gaodaima码

turnstr = $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}
——解决思路———————-
\x{0000}-\x{00ff}
——解决思路———————-
\x{4e00}-\x{9fff}]+/u’, $str, $matches);
$str = join(”, $matches[0]);
}
return $str;
}


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql 碰到特殊字符,造成了数据不全
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址