170 похожих чатов

Всем привет, у меня вопрос. Делаю сайт на PHP, у

меня есть страница, где я через GET параметр получаю ID, потом делаю SELECT из базы данных с этим ID, и показываю результат.


Сделал такую защиту от SQl INJ.


Просто не применяю encode параметра, и тогда если кто-то присылает '--, то в строку вставляется %27--. Нормально ли это или это возможно взломать?

11 ответов

9 просмотров

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

https://www.php.net/manual/ru/pdo.prepare.php

Peace- Автор вопроса
Dmitry Soloviev
https://www.php.net/manual/ru/pdo.prepare.php

Я знаю, про эти методы. Просто экспереминтирую. Интересно, можно ли это как-то обойти

Peace- Автор вопроса
Dmitry Soloviev
https://www.php.net/manual/ru/pdo.prepare.php

$query = "SELECT *" . "\n FROM users" . "\n WHERE id = " . (int) $id . "\n AND owner = 1" . "\n ORDER BY name" ; $database->setQuery( $query ); $rows = $database->loadObjectList();

Dmitry Soloviev
https://www.php.net/manual/ru/pdo.prepare.php

Хороший метод получить до 3х latency на запросах. До 8.0.22 от prepared statements кроме вреда никакой пользы нет. В 8.0.22 фазу подготовки запроса наконец положили в PREPARE, а не в EXECUTE как она была до этого https://dev.mysql.com/doc/relnotes/mysql/8.0/en/news-8-0-22.html В целом радости от использования prepared statements особенно на высоконагруженных проектах лично я не вижу.

Vladimir Fedorkov
Хороший метод получить до 3х latency на запросах. ...

важнее наверное что PREPARE теперь как то кешируется и при запросе пропускаются фазы парсинга и оптимизации

Vladimir Fedorkov
Хороший метод получить до 3х latency на запросах. ...

Бенчмарки по использованию prepare statements в mysql (через эмуляцию PDO и "родную" от MySQL) - что показали: миллион селектов с эмуляцией отработал за 88 секунд , без эмуляции - за 76. То есть родной мускульный немножечко, но быстрее :) mysql 5.7 был, на 8-ке не пробовал

Vladimir Fedorkov
Хороший метод получить до 3х latency на запросах. ...

я вот все пытаюсь найти что это такое, и никак не могу найти

Похожие вопросы

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
А табстоп это сообщение от окна или от элемента управления?
The Bird of Hermes
18
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Открыл свой двухкилобайтный экзешник в x32dbg, а тут какая-то хрень. Смущает кнопка "выполнить до пользовательского кода", а что ещё может быть в файле помимо него ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
11
Мне были интересны дишные хаки и я нашёл любопытный способ на форуме через __traits, что-то вроде int delegate(int) fac = (int n) => n == 0 ? 1 : n * __traits(parent, {})(n - ...
Constantin F.
1
Всем привет, подскажите/посоветуйте пожалуйста. Фаердак компоненты, имею одно место где бизнес хочет видеть при открытии формы список всех клиентов, это порядка 30к. Мои дово...
Sasha Sch
14
Вопрос тем кто смотрит видео и слушает подкасты - как вы потом ищете нужную вам информацию? Вот статью я прочитал, потом могу искать нужную мне часть банальным поиском. Пропус...
Aleksandr Druzhinin
4
Ребят, если кто в курсе - скажите, а в загранке такое же засилье маркетплейсов? или там простые сермяжные интернет-магазины живут попроще?
Андрей [aharito] Харитонов
14
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
Карта сайта