Разбор HTML-тэгов в PDO MySQL - PullRequest
       2

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

0 голосов
/ 08 ноября 2018

Мой код анализирует теги 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;

Ответы [ 2 ]

0 голосов
/ 08 ноября 2018

Неправильный способ передачи данных в подготовленный оператор, вы используете индекс для массива, который является нумерованным индексированным массивом на основе 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];
}
0 голосов
/ 08 ноября 2018

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

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

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

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

Параметры

Идентификатор параметра. Для подготовленного утверждения, используя named заполнители, это будет имя параметра формы: name. Для подготовленное утверждение с использованием вопросительных знаков, это будет 1-индексированная позиция параметра.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...