前言
最近将使用爬虫爬取的链接保存到 mysql 数据库中时,发现我将链接使用 json_encode 保存时候,在数据库中却显示了转义字符,我并不需要这转义的,看起来不清晰而且占用存储空间。
后来发现在默认的情况之下使用 json_encode 对数组进行 json 格式的转换时候会自动的将数据中含有斜杠的字符串进行转义,但是我们往往有的时候不需要药对它们进行转义的,本文说说如何使用 json_encode 不自动转义斜杠。
对于如下数组 $a,现有两种办法解决:
1
2
3
4
5
6
7
|
$a = array (
'http://www.baidu.com' ,
'http://www.baidu.com' ,
'http://www.baidu.com' ,
'http://www.baidu.com' ,
'http://www.baidu.com'
);
|
其一,正则替换:
1
2
|
$a = str_replace ( "\\/" , "/" , json_encode( $a ));
var_dump( $a );
|
其二,若 php 版本是 5.4 及以上的话:
1
|
var_dump(json_encode( $a ,JSON_UNESCAPED_SLASHES));
|
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。