Проблема поиска и передачи переменных в php и mysql

У меня такой код:

http://www.nomorepasting.com/getpaste.php?pasteid=22615

Это вызывается javascript, упомянутым в этот вопрос:

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

Я не уверен, как лучше всего контролировать поток информации. Моя логика в порядке? Передать запрос через javascript в файл php, а затем вернуть его с помощью функции?

Я также обеспокоен тем, что использую $ rows, поскольку в этом нет необходимости.

Стоит ли изучать 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 и хотите разрабатывать...
0
0
207
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

В коде, на который вы ссылаетесь, я не вижу, где объявлено $ searchString? В вышеупомянутом PHP я вижу эти два отдельных раздела:

$query ='';
if (isset($_GET["query"]))
$query = $_GET["query"];

и код, который вы выполняете позже на странице,

$table = 'Auctions';
$rows = getRowsByArticleSearch($searchString, $table);

Насколько я могу судить в коде, нигде не объявляется $ searchString. Однако более серьезная проблема заключается в том, что вы не очищаете строку запроса перед ее выполнением. В целях безопасности я бы по крайней мере заменил:

$result = mysql_query("SELECT ARTICLE_NO, USERNAME, ACCESSSTARTS, ARTICLE_NAME 
                       FROM {$table} 
                       WHERE upper ARTICLE_NAME LIKE '%" . $searchString . "%'");

с

$result = mysql_query("SELECT ARTICLE_NO, USERNAME, ACCESSSTARTS, ARTICLE_NAME 
                       FROM {$table} 
                       WHERE upper ARTICLE_NAME LIKE '%" . mysql_real_escape_string($searchString) . "%'");

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

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

Я думаю, вы хотите заменить это (строка 36):

$rows = getRowsByArticleSearch($searchString, $table);

с этим:

$rows = getRowsByArticleSearch($query, $table);

И по соображениям безопасности самое меньшее, что вам следует сделать, это материал mysql_real_escape_string из сообщения Spelley.

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