javascript - 清理字符串以避免特殊字符破坏 php 生成的 javascript

标签 javascript php special-characters sanitization

我有一个 php“搜索”脚本,用于在 MySQL 数据库中查找请求的数据并打印表格。该表的每一行都可以通过单击图标来修改或删除。当您单击这些图标之一时,将调用显示屏幕的 JavaScript 函数。

这是一段代码:

      while ($row = mysqli_fetch_row($result)) {
            // Define $id
            $id = $row[7];

            // Sanitize output
            $user = htmlentities($row[0]);
            $name = htmlentities($row[1]);
            $surnames = htmlentities($row[2]);
            $email = htmlentities($row[3]);
            $role = htmlentities($row[4]);
            $access = htmlentities($row[5]);
            $center = htmlentities($row[6]);

            $message .= "<tr>
                    <td>" . $user . "</td>" .
                    "<td>" . $name . "</td>" .
                    "<td>" . $surnames . "</td>" .
                    "<td>" . $email . "</td>" .
                    "<td>" . $role . "</td>" .
                    "<td>" . $access . "</td>" .
                    "<td>" . $center . "</td>" .
                    "<td>" .
                        "<input type='image' src='../resources/edit.png' id='edit_" . $user . "' class='edit' onclick=edit_user(\"$user\",\"$name\",\"$surnames\",'$email','$role','$access',\"$center\",'$id') title='Editar'></button>" . 
                    "</td>" .
                    "<td>" .
                        "<input type='image' src='../resources/delete.png' id='delete_" . $user . "' class='delete' onclick=delete_user(\"$user\",'$role') title='Eliminar'></button>" . 
                    "</td>
                </tr>";
        }

这只是我生成的表的一部分。毕竟,我使用 json_encode 对表进行编码并回显它。 echo 由 ajax 函数捕获,该函数对其进行解码 (JSON.parse) 并将其放入 div 中。

表格已正确呈现,并且对于普通字符来说一切正常,但我发现如果我有引号、斜线和其他有意义的字符,可能会出现一些问题。字符串在表中正确显示,因此 php 没有问题,但生成的 javascript 无法处理某些字符串。

例如,如果我介绍:

</b>5'"

或者:

<b>5'6"</b><br><div

作为用户,当我单击编辑或删除图标时,我在 javascript 控制台中收到一些错误:

未捕获的语法错误:无效的正则表达式:缺少/ home.php:1 未捕获的语法错误:参数列表后缺少 )

未捕获的语法错误:参数列表后缺少 )

未捕获的语法错误:意外的标记非法

我尝试过使用addslash、replace、htmlentites、htmlspecialchars的几种组合...但我找不到正确的组合。

为了避免出现任何问题,正确的处理方法是什么?

谢谢。

编辑:

我已经对此进行了探索,它似乎有效:

在 php 中我使用这个函数:

function javascript_escape($str) {
$new_str = '';

$str_len = strlen($str);
for($i = 0; $i < $str_len; $i++) {
    $new_str .= '\\x' . dechex(ord(substr($str, $i, 1)));
}

return $new_str;
}

然后我使用类似的东西

$('<textarea />').html(user).text()

在 JavaScript 中解码字符串。

这对于 XSS 攻击安全吗?

最佳答案

首先,创建数组的 HTML 安全 JSON 字符串并修改代码以使用数据属性,如下所示:

      while ($row = mysqli_fetch_row($result)) {
            // Define $id
            $id = $row[7];

            // Sanitize output
            $user = htmlentities($row[0]);
            $name = htmlentities($row[1]);
            $surnames = htmlentities($row[2]);
            $email = htmlentities($row[3]);
            $role = htmlentities($row[4]);
            $access = htmlentities($row[5]);
            $center = htmlentities($row[6]);

            $json_str_edit = htmlentities(json_encode(array($row[0], $row[1], $row[2], $row[3], $row[4], $row[5], $row[6], $id)));
            $json_str_delete = htmlentities(json_encode(array($row[0], $row[4])));

            $message .= "<tr>
                    <td>" . $user . "</td>" .
                    "<td>" . $name . "</td>" .
                    "<td>" . $surnames . "</td>" .
                    "<td>" . $email . "</td>" .
                    "<td>" . $role . "</td>" .
                    "<td>" . $access . "</td>" .
                    "<td>" . $center . "</td>" .
                    "<td>" .
                        "<input type=\"image\" src=\"../resources/edit.png\" id=\"edit_$user\" class=\"edit\" data-user=\"$json_str_edit\" title=\"Editar\"></button>" . 
                    "</td>" .
                    "<td>" .
                        "<input type=\"image\" src=\"../resources/delete.png\" id=\"delete_$user\" class=\"delete\" data-user=\"$json_str_delete\" title=\"Eliminar\"></button>" . 
                    "</td>
                </tr>";
        }

然后在 JS 中创建一个事件监听器来捕获关联的点击事件,如下所示:

function edit_user(user, name, surnames, email, role, access, center, id) {
    // `this` will refer to the html element involved in the event

    }

function delete_user(user, role) {
    // `this` will refer to the html element involved in the event

    }

document.addEventListener('click', function(event) {
    if(event.target.hasAttribute('data-user')) {
        switch(event.target.className) {
            case 'edit':
                edit_user.apply(event.target, JSON.parse(event.target.dataset.user));
                break;
            case 'delete':
                delete_user.apply(event.target, JSON.parse(event.target.dataset.user));
                break;
            }
        }
    }, false);

或者通过 addEventListener 方法,您可以简单地将此 onclick 事件监听器直接添加到元素,如下所示(我真的认为在这种情况下这并不重要):

onclick="edit_user.apply(this, JSON.parse(this.dataset.user))"

仅供引用,更常见的做法是在脚本中使用单引号以避免转义双引号字符。使事情变得更干净、更标准化。

关于javascript - 清理字符串以避免特殊字符破坏 php 生成的 javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36733821/

相关文章:

javascript - 如何在Javascript中用两个反斜杠替换反斜杠

javascript - 带字幕的多图像文件上传

javascript - html 里面的 xml

php - Stripe 3d 安全订阅失败

javascript - 为什么我的 PHP 数组没有作为数组发布到 JavaScript?

java - 适用于大型项目的 Apache.Httpd+Php 或 Apache.Tomcat+Java

javascript - 在视口(viewport)中显示一个 div

javascript - .toggle() 在 figcaption 上不起作用

mysql - 从WP页面中的mysql数据库中提取电子邮件时回显@符号

php - 有异常(exception)的 htmlentities