首页 / PHP / mysq,php写入unicode字符
mysq,php写入unicode字符
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysq,php写入unicode字符,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2180字,纯文字阅读大概需要4分钟。
内容图文
![mysq,php写入unicode字符](/upload/InfoBanner/zyjiaocheng/158/7529f726b7b4409aa75f4719e884dc2f.jpg)
一些特殊字符(图标字符)在保存mysql时,不能插入数据库
可以先把字符(特殊字符和正常字符)用base64_encode转为base64编码,保存到mysql
取出还原时,用base64_decode进行base64解码,再用json_decode还原为原字符
参考网上资料整理
/** * 一些特殊字符(图标字符)在保存mysql时,不能插入数据库 * 可以先把字符(特殊字符和正常字符)用base64_encode转为base64编码,保存到mysql * 取出还原时,用base64_decode进行base64解码,再用json_decode还原为原字符 */ /** * unicode解码 * @param $str * @return mixed|string */ function unicode_decode($str) { if (!$str) return $str; $decode = json_decode($str); if ($decode) return $decode; $str = '["' . $str . '"]'; $decode = json_decode($str); if (count($decode) == 1) { return $decode[0]; } return $str; } //$re = unicode_decode('\u963f\u55b5\ud83d\udc31\ud83d\udca6'); //echo($re); /** * unicode编码 * @param $str * @return string */ function unicode_encode($str) { if (!$str) return $str; $decode = json_encode($str); if ($decode) return $decode; $str = '["' . $str . '"]'; $decode = json_encode($str); if (count($decode) == 1) { return $decode[0]; } return $str; } //$re1 = unicode_encode('阿喵'); //echo($re1); /////////////////////////////////////////////////////////////// /** * 对unicode字符进行base64编码,保存入库 */ $conn = @mysql_connect("localhost","root","111111"); if (!$conn){ die("连接数据库失败:" . mysql_error()); } mysql_select_db("wx_sys", $conn); mysql_query("set character set 'gbk'"); //避免中文乱码字符转换 mysql_query("set character set 'utf8'"); // PHP 文件为 utf-8 格式时使用 //mysql_query("set names 'utf8'"); //PHP 文件为 utf-8 格式时使用 //unicode码字符 $name = '\u963f\u55b5\ud83d\udc31\ud83d\udca6'; //正常中文 //$name = '张三'; //base64编码 $re = base64_encode($name); $sql = "insert into test (uni) values ('" . $re . "')"; if(!mysql_query($sql,$conn)){ echo "添加数据失败:".mysql_error(); } else { echo "添加数据成功!"; } ///////////////////// /** * 取出数据,base64解码,并还原字符 */ $sql2 = "select * from test"; $result = mysql_query($sql2) or die("无效查询: " . mysql_error()); //循环从数据集取出数据 while( $row = mysql_fetch_array($result) ){ $sr = base64_decode($row['uni']); $ab = unicode_decode($sr); echo "uni:".$ab."
"; }
以上就介绍了mysq,php写入unicode字符,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
内容总结
以上是互联网集市为您收集整理的mysq,php写入unicode字符全部内容,希望文章能够帮你解决mysq,php写入unicode字符所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。