downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | conferences | my php.net

search for in the

SimpleXMLElement::count> <SimpleXMLElement::children
[edit] Last updated: Fri, 24 May 2013

view this page in

SimpleXMLElement::__construct

(PHP 5 >= 5.0.1)

SimpleXMLElement::__constructYeni bir SimpleXMLElement nesnesi oluşturur

Açıklama

__construct ( string $veri [, int $seçenekler [, bool $veri_bir_url [, string $isimalanı [, bool $önek_var ]]]] )

Yeni bir SimpleXMLElement nesnesi oluşturur

Değiştirgeler

veri

İyi biçemli bir XML dizgesi veya veri_bir_url ile TRUE belirtilmişse bir XML belge adresi ya da dosya yolu.

seçenekler

Ek Libxml değiştirgelerini belirtmek için isteğe bağlı bir değiştirge.

veri_bir_url

Öntanımlı olarak değeri FALSE'tır. veri değiştirgesinde bir XML belge adresi ya da dosya yolu belirtecekseniz TRUE olmalıdır.

isimalanı

önek_var

İpucu

Tüm XML hatalarını bastırmak için libxml_use_internal_errors() kullanıp daha sonra bu hataları libxml_get_errors() ile tek tek ele alabilirsiniz.

Dönen Değerler

veri ile belirtilen XML belgeyi içeren bir SimpleXMLElement nesnesi döner.

Hatalar/İstisnalar

XML veride saptanan her hata için bir istisna oluşturup bir E_WARNING üretir.

Örnekler

Örnek 1 - Bir dizgeden bir SimpleXMLElement nesnesi oluşturmak

<?php

include 'example.php';

$sxe = new SimpleXMLElement($xmlstr);
echo 
$sxe->movie[0]->title;

?>

Örnek 2 - Bir dosyadan bir SimpleXMLElement nesnesi oluşturmak

<?php

$sxe 
= new SimpleXMLElement('http://example.org/document.xml'NULLTRUE);
echo 
$sxe->asXML();

?>

Ayrıca Bakınız



SimpleXMLElement::count> <SimpleXMLElement::children
[edit] Last updated: Fri, 24 May 2013
 
add a note add a note User Contributed Notes SimpleXMLElement::__construct - [4 notes]
up
1
kumarldh at gmail dot com
2 years ago
Using libxml_use_internal_errors() may suppress errors but Exception still requires decent handling. I used following code snippet.

<?php
libxml_use_internal_errors
(true);
try{
   
$xmlToObject = new SimpleXMLElement($notSoWellFormedXML);
} catch (
Exception $e){
    echo
'Please try again later...';
    exit();
}
?>
up
1
uramihsayibok, gmail, com
3 years ago
As I was filling out a bug report, I realized why (speculation here) the constructor is final: so that functions like simplexml_load_file and simplexml_load_string can work. I imagine the PHP-ized code looks something like

<?php

function simplexml_load_file($filename, $class_name = "SimpleXMLElement", $options = 0, $ns = "", $is_prefix = false) {
    return new
$class_name($filename, $options, true, $ns, $is_prefix);
}

?>

If we were to use a different $class_name and change the constructor's definition these functions wouldn't work.

There's no easy, sensible solution that keeps simplexml_load_file and simplexml_load_string.
up
1
tudor at culise dot net
5 years ago
This class is extendable, but it's too bad that its constructor cannot be overriden (PHP says it's a final method). Thus the class should be wrapped using the delegation principle rather that extended.
up
0
zwilson at gulosolutions dot com
3 years ago
SimpleXML does not correctly parse SOAP XML results if the result comes back with colons ‘:’ in a tag, like <soap:Envelope>. Why? Because SimpleXML treats the colon character ‘:’ as an XML namespace, and places the entire contents of the SOAP XML result inside a namespace within the SimpleXML object. There is no real way to correct this using SimpleXML, but we can alter the raw XML result a little before we send it to SimpleXML to parse.

All we have to do is use the preg_replace function to get rid of the colons in the SOAP response tags BEFORE you hand it off to SimpleXML, like so:

<?php
// SimpleXML seems to have problems with the colon ":" in the <xxx:yyy> response tags, so take them out
$xmlString = preg_replace("/(<\/?)(\w+):([^>]*>)/", "$1$2$3", $response);
?>

 
show source | credits | sitemap | contact | advertising | mirror sites