Проверка и очистка международных имен

Я наткнулся на этот отвечать,, который предлагает, кроме проверки того, что строка пуста, нам, вероятно, лучше вообще не проверять. Учитывая объем возможных символов при работе с международными именами,, это кажется разумным.

Должны ли мы вообще отказаться от проверки?

Достаточно ли подготовленных заявлений, когда речь идет о санации международных имен?

$pdo = $connection->prepare("INSERT INTO clicks (domain, sid) VALUES (:domain, :sid)");
$pdo->execute(array(
  ":domain" => $domain,
  ":sid" => $sid
));

Другой подход заключается в том, чтобы запретить определенные символы вместо того, чтобы пытаться сопоставить включенные символы. Однако это тоже будет сложно.

объяснение отрицательного голосования было бы полезно...

oldboy 29.07.2019 23:50

Если вы правильно привязываете входные значения к подготовленным операторам (похоже, что вы это делаете), то какие символы разрешены в значениях, на самом деле не имеют отношения к SQL-инъекциям, потому что значение не может стать частью запроса . stackoverflow.com/questions/8263371/…

Don't Panic 30.07.2019 01:04

@Don'tPanic, отлично.

oldboy 30.07.2019 02:29
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
3
49
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Should we be foregoing validation altogether?

Наверное. Я согласен с ответом связанного пользователя. Попытки строить догадки об именах только причинят вам боль.

Are prepared statements sufficient when it comes to sanitizing international names?

Если все сделано правильно, то да. Обратите внимание, что недостаточно просто использовать подготовленные операторы, вам также необходимо использовать связанные параметры.

Я предполагаю, что вы имеете в виду это, но я чувствую, что должен быть педантичным здесь, потому что я часто вижу такого рода «подготовленное заявление»:

$db->prepare("select * from users where id = $id");

что я использую $pdo = $connection->prepare("INSERT INTO table (column) VALUES (:column), а затем либо связываю их по отдельности (например, $pdo->bindParam(":column", $column)), либо выполняю их как ассоциативный массив (например, $pdo->execute(array(":column" => $column)) достаточно ли этих подготовленных операторов для очистки международных имен?

oldboy 29.07.2019 23:55

@csabinho достаточно ли подготовленных заявлений в моем комментарии выше, чтобы очистить международные имена?

oldboy 29.07.2019 23:55

@csabinho Верно, это именно моя точка зрения. Я вижу это слишком часто, люди думают, что просто использование prepare() делает их безопасными. Я просто хотел указать, что вам также нужно связать.

Alex Howansky 29.07.2019 23:57

@BugWhisperer Невозможно сказать, не видя всего кода, но да, у вас есть правильное основное представление об этом.

Alex Howansky 29.07.2019 23:58

я добавил код. какой еще код вам нужно увидеть, чтобы узнать, является ли подготовленный оператор достаточной дезинфекцией для международных имен?

oldboy 30.07.2019 00:10

Код, который вы разместили, выглядит чистым и не должен подвергаться инъекциям.

Alex Howansky 30.07.2019 00:15

быстрый вопрос, есть ли в конечном итоге привилегия, которую можно разблокировать, которая позволяет вам видеть, кто проголосовал против ваших материалов?

oldboy 30.07.2019 00:18

Насколько мне известно, нет.

Alex Howansky 30.07.2019 00:20

Другие вопросы по теме