1
0
mirror of https://github.com/php/doc-de.git synced 2026-04-26 16:38:05 +02:00
Files
Martin Samesch 4fa203e23c Sync with EN
2024-10-29 22:45:15 +01:00

156 lines
5.0 KiB
XML

<?xml version="1.0" encoding="utf-8"?>
<!-- $Revision$ -->
<!-- EN-Revision: 89ae180a851621c308f0ea4604ff2e919aa57a7f Maintainer: sammywg Status: ready -->
<refentry xml:id="soapserver.setpersistence" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink">
<refnamediv>
<refname>SoapServer->setPersistence()</refname>
<refpurpose>Versetzt einen SoapServer in den Persistenz-Modus</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis role="SoapServer">
<modifier>public</modifier> <type>void</type><methodname>SoapServer::setPersistence</methodname>
<methodparam><type>int</type><parameter>mode</parameter></methodparam>
</methodsynopsis>
<para>
Diese Funktion erlaubt das Ändern des Persistenzzustands eines SoapServer
Objekts zwischen Anfragen. Diese Funktion erlaubt das Speichern von Daten
zwischen Anfragen durch Verwendung von PHP Sessions. Diese Methode hat nur
Auswirkungen auf den SoapServer, nachdem er Funktionen unter Verwendung von
<methodname>SoapServer::setClass</methodname> exportiert hat.
</para>
<note>
<para>
Die Option <constant>SOAP_PERSISTENCE_SESSION</constant> macht nur Objekte
der angegebenen Klasse persistent, nicht aber ihre statischen Eigenschaften.
Daher sollten sie <varname>$this->bar</varname> anstatt von self::$bar nutzen.
</para>
</note>
<note>
<para>
<constant>SOAP_PERSISTENCE_SESSION</constant> serialisiert Daten des
Klassenobjekts zwischen Anfragen. Damit Ressourcen (&zb;
<classname>PDO</classname>) ordnungsgemäß verwendet werden können, sollten
die magischen Methoden <link linkend="object.wakeup">__wakeup()</link> und
<link linkend="object.sleep">__sleep()</link> verwendet werden.
</para>
</note>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>mode</parameter></term>
<listitem>
<para>
Eine der
<constant>SOAP_PERSISTENCE_<replaceable>*</replaceable></constant>-Konstanten.
</para>
<para>
<constant>SOAP_PERSISTENCE_REQUEST</constant> - SoapServer Daten bleiben
zwischen Anfragen nicht erhalten. Das ist das <emphasis
role="bold">standardmäßige</emphasis> Verhalten von jedem SoapServer
Objekt nachdem setClass aufgerufen wurde.
</para>
<para>
<constant>SOAP_PERSISTENCE_SESSION</constant> - SoapServer Daten bleiben
zwischen Anfragen erhalten. Dies wird durch Serialisierung der SoapServer
Klassendaten in <varname>$_SESSION['_bogus_session_name']</varname>
erreicht, weshalb <function>session_start</function> aufgerufen werden
muss, bevor dieser Persistenzmodus eingestellt wird.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
&return.void;
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title><function>SoapServer::setPersistence</function>-Beispiel</title>
<programlisting role="php">
<![CDATA[
<?php
class MyFirstPersistentSoapServer {
private $resource; // (wie z. B. PDO, mysqli usw.)
public $myvar1;
public $myvar2;
public function __construct() {
$this->__wakeup(); // Wir rufen unser wakeup auf, damit die Ressource verwendet werden kann
}
public function __wakeup() {
$this->resource = CodeToStartOurResourceUp();
}
public function __sleep() {
// Wir stellen sicher, dass $resource hier ausgelassen wird, damit
// unsere Sessiondaten persistent bleiben. Versäumen wir dies, wird das
// Deserialisieren der Daten bei der nächsten Anfrage fehlschlagen;
// folglich wäre unser SoapObject nicht anfrageübergreifend persistent.
return array('myvar1','myvar2');
}
}
try {
session_start();
$server = new SoapServer(null, array('uri' => $_SERVER['REQUEST_URI']));
$server->setClass('MyFirstPersistentSoapServer');
// setPersistence MUSS nach setClass aufgerufen werden, weil setClass
// SESSION_PERSISTENCE_REQUEST setzt sobald die Methode ausgeführt wird.
$server->setPersistence(SOAP_PERSISTENCE_SESSION);
$server->handle();
} catch(SoapFault $e) {
error_log("SOAP FEHLER: ". $e->getMessage());
}
?>
]]>
</programlisting>
</example>
</para>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><methodname>SoapServer::setClass</methodname></member>
</simplelist>
</para>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->