gpt4 book ai didi

php - 提供 JSONP 是否安全?

转载 作者:IT王子 更新时间:2023-10-28 23:47:52 25 4
gpt4 key购买 nike

<?php header('content-type: application/json');

$json = json_encode($data);

echo isset($_GET['callback'])
? "{$_GET['callback']}($json)"
: $json;

或者我是否应该过滤 $_GET['callback'] 变量,使其仅包含有效的 JavaScript 函数名称?如果是这样,什么是有效的 JavaScript 函数名称?

或者不使用 JSONP 过滤那个变量?


当前解决方案:http://www.geekality.net/?p=1021 上发布了我当前解决方案的博客.简而言之,目前我有以下代码,希望它应该是相当安全的:

<?php header('content-type: application/json; charset=utf-8');

function is_valid_callback($subject)
{
$identifier_syntax
= '/^[$_\p{L}][$_\p{L}\p{Mn}\p{Mc}\p{Nd}\p{Pc}\x{200C}\x{200D}]*+$/u';

$reserved_words = array('break', 'do', 'instanceof', 'typeof', 'case',
'else', 'new', 'var', 'catch', 'finally', 'return', 'void', 'continue',
'for', 'switch', 'while', 'debugger', 'function', 'this', 'with',
'default', 'if', 'throw', 'delete', 'in', 'try', 'class', 'enum',
'extends', 'super', 'const', 'export', 'import', 'implements', 'let',
'private', 'public', 'yield', 'interface', 'package', 'protected',
'static', 'null', 'true', 'false');

return preg_match($identifier_syntax, $subject)
&& ! in_array(mb_strtolower($subject, 'UTF-8'), $reserved_words);
}

$data = array(1, 2, 3, 4, 5, 6, 7, 8, 9);
$json = json_encode($data);

# JSON if no callback
if( ! isset($_GET['callback']))
exit( $json );

# JSONP if valid callback
if(is_valid_callback($_GET['callback']))
exit( "{$_GET['callback']}($json)" );

# Otherwise, bad request
header('Status: 400 Bad Request', true, 400);

最佳答案

否,如果您打算将 JSONP 限制为选择域。也指定编码,否则不应访问 JSON 的人可能会进行 UTF-7 注入(inject)攻击。请改用此 header :

header('Content-Type: application/json; charset=utf-8');

如果它应该是一个公共(public) JSONP 服务,那么它是安全的,并且还可以使用 application/javascript 而不是 application/json

关于php - 提供 JSONP 是否安全?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3128062/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com