mysq,php写入unicode字符

一些特殊字符(图标字符)在保存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."<br />";
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值