Разбор HTML-тегов в PDO MySQL

Мой код анализирует HTML-теги с помощью регулярного выражения и хранит все ссылки в виде массива внутри базы данных.

У меня проблема в моем коде, я не знаю, как ее исправить, чтобы сохранить ссылки внутри MySQL

я вижу это сообщение об ошибке Ошибка: SQLSTATE [HY093]: недопустимый номер параметра: столбцы / параметры начинаются с 1

try {
    $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
    // set the PDO error mode to exception
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $domain = "https://google.com";
    $input = @file_get_contents($domain) or die("Could not access file: $domain");
    $regexp = "<a\s[^>]*href=(\"??)([^\" >]*?)\\1[^>]*>(.*)</a>";
    if (preg_match_all("/$regexp/siU", $input, $matches, PREG_SET_ORDER)) {
        foreach($matches as $match) {
            $url=$match[2];
            // $match[2] = link address
            // $match[3] = link text
        }
    }   
    $rows = array($domain, $url);
    $stmt = $conn->prepare("INSERT INTO linkss(id, domain, url) 
                            VALUES (NULL, :domain, :url)");
    foreach($rows as $key => $value){
        $stmt->bindParam($key, $value);
    }
    $stmt -> execute();  
    echo "New records created successfully"; 
}
catch(PDOException $e){
    echo "Error: " . $e->getMessage();
}
$conn = null;
Стоит ли изучать 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
119
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

При привязке параметра необходимо указать : в имени параметра:

$stmt->bindParam(':' . $search_field, $search_val);

Вы получаете сообщение об ошибке, потому что это отсутствует, и код возвращается к ожиданию целочисленного значения для указания позиции параметра (как если бы вы использовали параметры? -Стиля).

Обратите внимание на это описание первого параметра для PDOStatement :: bindParam () из документации.

Parameters

Parameter identifier. For a prepared statement using named placeholders, this will be a parameter name of the form :name. For a prepared statement using question mark placeholders, this will be the 1-indexed position of the parameter.

Это необязательно и не проблема.

mario 08.11.2018 13:38

Вам нужно указать :, иначе он не распознает параметр

Jbadminton 08.11.2018 13:40

Пожалуйста, проверьте stackoverflow.com/questions/9778887/…

Nigel Ren 08.11.2018 13:40

Это просто неправильно. Именованные заполнители можно указывать без двоеточия.

mario 08.11.2018 13:42

Не знал, мне всегда говорят добавить двоеточие

Jbadminton 08.11.2018 13:43
Ответ принят как подходящий

То, как вы передаете данные в подготовленный оператор, неверно, вы используете индекс для массива, который представляет собой массив с числовым индексом на основе 0. Вот почему вы получаете ошибку. Хотя не уверен, зачем вам этот массив ...

$rows = array($domain, $url);

Вместо этого я бы предложил использовать ...

$stmt = $conn->prepare("INSERT INTO linkss(id, domain, url) 
                          VALUES (NULL, :domain, :url)");
foreach($url as $value){
     $stmt->bindParam(':domain', $domain);
     $stmt->bindParam(':url', $value);
     $stmt -> execute();  
}

Это также должно вставить запись для каждого URL-адреса, а не для последнего, поскольку execute() находится внутри цикла.

Обновлять:

Вам также необходимо изменить код, который формирует список URL-адресов, это ранее постоянно перезаписывало последний URL-адрес, это создаст список всех URL-адресов ...

$url = array();
foreach($matches as $match) {
    $url[]=$match[2];
}

я удалил $ rows = array ($ domain, $ url); и использовал ваш код, но теперь вижу еще одну ошибку. Предупреждение: недопустимый аргумент для foreach () в /home/ddd/public_html/links.php в строке 27

Eddy 08.11.2018 13:45

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