Fehlerlösungen
[unmarkierte Version] | [unmarkierte Version] |
(→CustomTitle) |
(→Warnungen) |
||
Zeile 72: | Zeile 72: | ||
==MagicWordArray.php== | ==MagicWordArray.php== | ||
Die Fehlermeldung das in einer Zeile des MagicWordArray.php wurde auf der Wiki Seite dargestellt und hatten den Grund, dass die Funktion in der MagicWordArray.php veraltet war. | Die Fehlermeldung das in einer Zeile des MagicWordArray.php wurde auf der Wiki Seite dargestellt und hatten den Grund, dass die Funktion in der MagicWordArray.php veraltet war. | ||
+ | <pre> Fehlercode: The each() function is deprecated. This message will be suppressed for further calls in /var/www/vhosts/hl7.at/wiki.hl7.at/MagicWordArray.php on line 206</pre> | ||
Fehler: | Fehler: | ||
<pre> | <pre> | ||
Zeile 107: | Zeile 108: | ||
} | } | ||
</pre> | </pre> | ||
+ | |||
+ | ==count() in FRUserActivity.php== | ||
+ | Der Fehler in der Funktion count() in FRUserActivity.php (liegt in der Extension FlaggedRevision/backend) konnte durch ein Update des PHP behoben werden. | ||
+ | |||
+ | <pre>Fehlercode: count(): Parameters Array or an object that implements Countable in /var/www/vhosts/hl7.at/wiki.hl7.at/extensions/FlaggedRevs/backend/FRUserActivity.php</pre> |
Version vom 16. Mai 2018, 15:33 Uhr
Diese Seite dient zur Erklärung von verschiedensten Fehlern, die aufgetreten und behoben worden sind.
Inhaltsverzeichnis
1 Fehler
1.1 Internal Server Error
Wenn beim Abspeichern eines Beitrag der Internal Server Error auftritt, kann der Beitrag nicht gespeichert werden, da die Seite kollabiert.
Der Fehlergrund hierfür liegt in zwei hintereinanderfolgenden -, die am Zeilenbeginn stehen.
Daher bitte niemals zwei hintereinanderfolgende - (--) am Zeilenbeginn einfügen!
1.2 CustomTitle
Mit der Extension CustomTitle trat das Problem auf, dass im Text immer wieder Codeteile dargestellt wurden, wie z.B.
Um dies zu Unterbinden wurden in der CustomTitle.php die Funktion onOutputPageBeforeHTML verändert.
vorheriger Code:
function onOutputPageBeforeHTML(&$out, &$text) { if (($found = strpos($text, 'xxx-CustomTitleStart-xxx')) !== false) { if (preg_match("//", $text, $matches)) { $this->customTitle = $matches[1]; $text = str_replace($matches[0], "", $text); } } if (($found = strpos($text, 'xxx-CustomPageTitleStart-xxx')) !== false) { if (preg_match("//", $text, $matches)) { $this->customPageTitle = $matches[1]; $text = str_replace($matches[0], "", $text); } } return true; }
Lösung:
function onOutputPageBeforeHTML(&$out, &$text) { if (($found = strpos($text, 'xxx-CustomTitleStart-xxx')) !== false) { if (preg_match("//", $text, $matches)) { $this->customTitle = $matches[1]; $text = str_replace($matches[0], "", $text); // replace any remaining occurrences while (preg_match("//", $text, $matches)) { $text = str_replace($matches[0], "", $text); } } } if (($found = strpos($text, 'xxx-CustomPageTitleStart-xxx')) !== false) { if (preg_match("//", $text, $matches)) { $this->customPageTitle = $matches[1]; $text = str_replace($matches[0], "", $text); // replace any remaining occurrences while (preg_match("//", $text, $matches)) { $text = str_replace($matches[0], "", $text); } } } return true; }
2 Warnungen
Warnungen stehen am Beginn der Seite und sind keine Errors, die eine Seite lahmlegen. Warnungen sollten trotzdem ausgebessert werden, da Funktionen ansonsten nicht richtig ausgeführt werden.
2.1 MagicWordArray.php
Die Fehlermeldung das in einer Zeile des MagicWordArray.php wurde auf der Wiki Seite dargestellt und hatten den Grund, dass die Funktion in der MagicWordArray.php veraltet war.
Fehlercode: The each() function is deprecated. This message will be suppressed for further calls in /var/www/vhosts/hl7.at/wiki.hl7.at/MagicWordArray.php on line 206
Fehler:
public function parseMatch( $m ) { reset( $m ); while ( list( $key, $value ) = each( $m ) ) { if ( $key === 0 || $value === '' ) { continue; } … }
Lösung:
public function parseMatch( $m ) { reset( $m ); while ( ( $key = key( $m ) ) !== null ) { $value = current( $m ); next( $m ); if ( $key === 0 || $value === '' ) { continue; } $parts = explode( '_', $key, 2 ); if ( count( $parts ) != 2 ) { // This shouldn't happen // continue; throw new MWException( __METHOD__ . ': bad parameter name' ); } list( /* $synIndex */, $magicName ) = $parts; $paramValue = next( $m ); return [ $magicName, $paramValue ]; } // This shouldn't happen either throw new MWException( __METHOD__ . ': parameter not found' ); }
2.2 count() in FRUserActivity.php
Der Fehler in der Funktion count() in FRUserActivity.php (liegt in der Extension FlaggedRevision/backend) konnte durch ein Update des PHP behoben werden.
Fehlercode: count(): Parameters Array or an object that implements Countable in /var/www/vhosts/hl7.at/wiki.hl7.at/extensions/FlaggedRevs/backend/FRUserActivity.php