thinkphp中的特殊字符处理

根据最近项目整理 -- 有些特殊字符的存储展示会有问题,解决方案如下:

字符编码:

" 经过ThinkPHP的I 转换为 "
< <
> >
& &
如果用 模板变量直接引用则可以还原,但是用js赋值则不能。js还原函数:
function restore_str_js(str){
var str =  str.replace('"','"');
str = str.replace('<','<');
str = str.replace('>','>');
str = str.replace('&','&');
str = str.replace('char(10)','\r\n');//将换行符 还原展示于页面
return str;
}




换行符的处理:
textarea 有时候用户会插入换行符,但是不加处理插入到数据库中的时候会出错。
php处理之后存入数据库:
//将换行符替换为一个特殊标记,页面展示时还原
function filter_enter($str){
    $str = str_replace(array("\r\n", "\r", "\n"), 'char(10)', $str); //把用户输入的回车替换成一个特殊字符 //textarea
    return $str;
}


若为js读取:str = str.replace('char(10)','\r\n');//将换行符 还原展示于页面
若为模板变量: 
//模板直接引用变量时 转换成换行符
function restore_enter($str){
    $str = str_replace('char(10)','
',$str);//将换行符 还原展示于页面
    return $str;
}




\反斜杠的处理:
I函数对\不加处理,但是在sql查询语句中就会出错。正确的sql语句:
SELECT * FROM `a` where Word like '%\\';   结果:ASPERT\
即1个反斜杠\要在查询之前转成2个反斜杠\\:
//将 \一个反斜杠转化为 \\两个反斜杠,用于数据库查询
function filter_str($str){
    $str = str_replace("\\","\\\\",$str);
    return $str;
}


如果数据库中的\是原样存储的,直接读取赋给模板变量,展示也是有问题的。
//将\反斜杠转换为\;(html实体)用于展示于页面
function restore_str($str){
    $str = str_replace("\\","\",$str);
    return $str;
}


如果用js读取:
 php: $this->assign('name', filter_str($name));   //为了反斜杠  不然就一个反斜杠,后面和字符连起来转义乱码
 js:   var  name = "{$name}";

你可能感兴趣的:(PHP,mysql)