PHP.mk документација

libxml_get_errors

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

function.libxml-get-errors.php PHP.net прокси Преводот се освежува
Оригинал на PHP.net
Патека function.libxml-get-errors.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + превод во позадина Кодовите, табелите и белешките остануваат читливи во истиот тек.
libxml_get_errors

Референца за `function.libxml-get-errors.php` со подобрена типографија и навигација.

function.libxml-get-errors.php

libxml_get_errors

(PHP 5 >= 5.1.0, PHP 7, PHP 8)

libxml_get_errors (PHP 5 >= 5.1.0, PHP 7, PHP 8)

= NULL

libxml_get_errors(): array

Земи низа од грешки

Параметри

Оваа функција нема параметри.

Вратени вредности

Враќа низа со LibXMLError Земи низа од грешки.

Примери

ако е овозможен колекторот за отпадоци, libxml_get_errors() example

објекти ако има грешки во баферот, или празна низа инаку.

<?php

libxml_use_internal_errors
(true);

$xmlstr = <<< XML
<?xml version='1.0' standalone='yes'?>
<movies>
<movie>
<titles>PHP: Behind the Parser</title>
</movie>
</movies>
XML;

$doc = simplexml_load_string($xmlstr);
$xml = explode("\n", $xmlstr);

if (
$doc === false) {
$errors = libxml_get_errors();

foreach (
$errors as $error) {
echo
display_xml_error($error, $xml);
}

libxml_clear_errors();
}


function
display_xml_error($error, $xml)
{
$return = $xml[$error->line - 1] . "\n";
$return .= str_repeat('-', $error->column) . "^\n";

switch (
$error->level) {
case
LIBXML_ERR_WARNING:
$return .= "Warning $error->code: ";
break;
case
LIBXML_ERR_ERROR:
$return .= "Error $error->code: ";
break;
case
LIBXML_ERR_FATAL:
$return .= "Fatal Error $error->code: ";
break;
}

$return .= trim($error->message) .
"\n Line: $error->line" .
"\n Column: $error->column";

if (
$error->file) {
$return .= "\n File: $error->file";
}

return
"$return\n\n--------------------------------------------\n\n";
}

?>

Пример #1 Пример што покажува затворачка ознака што го опфаќа последниот нов ред

<titles>PHP: Behind the Parser</title>
----------------------------------------------^
Fatal Error 76: Opening and ending tag mismatch: titles line 4 and title
  Line: 4
  Column: 46

--------------------------------------------

Види Исто така

  • libxml_get_last_error() Овој пример покажува како да се изгради едноставен libxml ракувач со грешки.
  • libxml_clear_errors() Овој пример демонстрира основна употреба на libxml грешки и вредноста вратена од оваа функција.

Белешки од корисници 1 белешка

lech
пред 8 години
Please beware that the column property seems almost always to be invalid. I thought it only occurred when the line in question was long (and I was just about to submit a bug report with an example), however, at the time of posting, you can even see the problem in the example provided on this page: line 4 does not even have 46 characters. Where the XML line is long, the difference can be very large.

This property comes from the libxml extension, so in any case I don't think this is a PHP bug, however it is worth knowing that the value might be totally unreliable to save some confusion.

The PHP documentation page for the libXMLError class gives some indication, stating:

"This property isn't entirely implemented in libxml and therefore 0 is often returned."

(My libxml version: 2.9.1)
На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.