Приложение никогда не должно полагать, что среда
пользователя безопасна. Сюда включается (но этим не
ограничено): ввод пользователя, сигналы, переменные среды,
ресурсы, IPC, отображаемая в файл память, рабочий каталог
файловой системы, дескрипторы файлов, число открытых файлов и
прочее.
Никогда не думайте, что сможете предусмотреть все формы
неправильного ввода, который может дать пользователь. Вместо
этого ваше приложение должно осуществлять позитивную
фильтрацию, пропуская только конечное множество возможных
вариантов ввода, которые вы считаете безопасными. Неполная
праверка данных была причиной многих нарушений защиты,
особенно CGI-скриптов на веб-сайтах. Для имен файлов вам
нужно уделять особое внимание путям ("../", "/"),
символическим ссылкам и экранирующим символам оболочки.
В perl имеется такая очень полезная вещь, как
"безупречный" (taint) режим, который можно использовать для
запрещения скриптам использовать данные, порожденные вне
программы, не безопасным способом. Этот режим проверяет
аргументы командной строки, переменные окружения, информацию
локализации, результаты некоторых системных вызовов (readdir(),
readlink(), getpwxxx() и весь
файловый ввод.