Как правильно экранировать html формы ввода значений по умолчанию в php?

Учитывая следующие два фрагмента HTML / PHP:

<input type="text" name="firstname" value="<?php echo $_POST['firstname']; ?>" />

а также

<textarea name="content"><?php echo $_POST['content']; ?></textarea>

какую кодировку символов мне нужно использовать для отображения $_POST переменные? Могу ли я использовать любые встроенные функции PHP? Пожалуйста, предположите, что $_POST значения еще не были закодированы. Никаких волшебных кавычек нет ничего.

4 ответа

Решение

Использование htmlspecialchars($_POST['firstname']) а также htmlspecialchars($_POST['content']),

Всегда избегать строк с htmlspecialchars() прежде чем показывать их пользователю.

Однако, htmlspecialchars() не поможет вам value='single quotes'

Вот что происходит:

value='We're not using this in our &quot;code&quot;...'

Все, что вы видите, это We

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

Учитывая, что это довольно долго, я бы поместил это в функцию

<?PHP
function encodeValue ($s) {
    return htmlentities($s, ENT_COMPAT|ENT_QUOTES,'ISO-8859-1', true); 
}
?>

Он имеет ENT_QUOTES, чтобы обеспечить кодирование одинарных и двойных кавычек, но он также будет кодировать специальные символы (как в Хосе) вместо вставки пустой строки.

Тогда вы можете сделать:

<input type="text" name="firstname" value="<?= encodeValue($_POST['firstname']) ?>" />

а также

<textarea name="content"><?= encodeValue($_POST['content']) ?></textarea>

Я часто использую

<input type="text" name="firstname" value=<?php echo json_encode($_POST['firstname']); ?>/>
Другие вопросы по тегам