ホームページ  >  記事  >  バックエンド開発  >  mysql で特殊文字が検出され、不完全なデータが生成される

mysql で特殊文字が検出され、不完全なデータが生成される

WBOY
WBOYオリジナル
2016-06-13 12:12:301084ブラウズ

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);
Longhua
------解決策----------------------
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 />                $returnstr = $returnstr.substr($ostr, $i, 1);  <br />                $i = $i + 1;  <br />            }elseif ($ascnum>=128 && $ascnum<=191){ // 特殊字符  <br />                $i = $i + 1;  <br />            }else{  <br />                $returnstr = $returnstr.substr($ostr, $i, 1);  <br />                $i = $i + 1;  <br />            }  <br />        }  <br />        $str = $returnstr;  <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', $str, $matches);  <br />        $str = join('', $matches[0]);  <br />    }  <br />    return $str;  <br />}  <br />

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。