显示 Blade 视图中的 JSON 数据,定制转义规则(取消将 ” (双引号) 转换为 HTML 实体),以便于前端解析
1、现有代码实现如下
1 | "url" : "{{ json_encode($item['url_object']) }}" , |
2、最终生成的 JSON 数据结构如下:
1 | "url": "{"ID":18,"title":"summer","object":"product_cat","object_id":18,"children":[],"url":"/collections/summer","key":3991}", |
3、Blade {{ }} 语句是自动经过 PHP 的 htmlspecialchars 函数传递来防范 XSS 攻击的。因此,需要 {!! !!},防止将 ” (双引号) 转换为 HTML 实体。
1 | "url" : "{!! htmlspecialchars(json_encode($item['url_object']), ENT_NOQUOTES | ENT_HTML401) !!}" , |
4、但是,生成的 JSON 结构错误。原因在于 url 的值未转义。如图1
1 2 3 4 5 6 | { "image": "", "mobile_image": "", "url": "{"ID":18,"title":"summer","object":"product_cat","object_id":18,"children":[],"url":"\/collections\/summer","key":3991}", "title": "summer" } |
5、使用addcslashes — 以 C 语言风格使用反斜线转义字符串中的字符。
1 | "url" : "{!! htmlspecialchars(addcslashes(json_encode($item['url_object']), " \f\n\r\t\\\ "" ), ENT_NOQUOTES | ENT_HTML401) !!}", |
6、生成的 JSON 结构正确。如图2
1 2 3 4 5 6 | { "url": "{\"ID\":18,\"title\":\"summer\",\"object\":\"product_cat\",\"object_id\":18,\"children\":[],\"url\":\"\\/collections\\/summer\",\"key\":3991}", "image": "", "title": "summer", "mobile_image": "" } |
近期评论