php unserialize “_php_incomplete_class” namespace

Ich habe in PHP ein unserialize() ausgeführt. Die darin enthaltenen Daten sind valide und die dazugeörige Klasse ist in meinem Framework bzw. in meiner Library enthalten. Dennoch hat das unserialize() nicht funktioniert und führte zu einem Objekt in dem die Klasse _php_incomplete_class vergeben wurde.

Sofern es zu der Zuordnung der Klasse _php_incomplete_class kommt liegt dies daran, dass die Klasse nicht gefunden werden konnte. Daher ist ein require bzw. include der jeweiligen Klasse notwendig. Ggf. sollte auch die Verarbeitung des Autoloaders überprüft werden, sofern die Klasse normalerweise automatisch geladen werden würde.

Free PHP, HTML, CSS, JavaScript editor (IDE) – Codelobster PHP Edition

For valuable work on creation of sites you need a good comfortable editor necessarily. There are many requiring paid products for this purpose, but we would like to select free of charge very functional and at the same time of simple in the use editor – Codelobster PHP Edition .
 

Free PHP, HTML, CSS, JavaScript editor (IDE) - Codelobster PHP Edition

Let us consider some important possibilities and advantages of this program:

 

  • All code highlights depending on a type, the also mixed code is thus supported, so the area of HTML will be highlighted as HTML, PHP as PHP, and Javascript as Javascript in a the same file. Thre is possibility of choice from color schemes, including popular IDEs.
  • Powerful autocompletion for HTML, PHP, CSS and Javascript, including HTML5 and CSS3. For PHP the structure of project is fully recognized, and the complete list of methods falls out in the proper places.
  • HTML/CSS inspector on the type of Firebug, which allows easily to correlate the selected elements of page with a code and proper style.
  • Context help on all supported languages. By pressing F1 key the page with detailed description for current tag, attribute or function will be opened.
  • PHP debugger. PHP debugger allows to execute PHP scripts incrementally, watching the values of all variables in every line.
  • SQL manager allows to produce all necessary actions with a database – to add, delete, edit a structure and records in tables, to export data, execute SQL queries. Highlighting and autocompletion works for SQL files also.
  • Support of FTP allows to work straight with a remote server and to do all necessary changes with files;
  • The portable option allows to use editor without the preliminary installation.
  • Other useful utilities: pair highlighting, possibility of blocks selection, collapsing, tooltips, navigation on descriptions of functions and included files at withholding of the key of CTRL, viewing of structure of files and project, preview in a browser, book-marks, and all other standard possibilities for work with a code.

Also there are special plugins for work with:

 

  • CMS: Drupal, Joomla, Magento
  • PHP frameworks: CakePHP, CodeIgniter, Symfony, Yii, Laravel
  • JavaScript: JQuery, Node.js, AngularJS, BackboneJS, MeteorJS
  • WordPress blogging engine
  • Smarty and Twig template engines
Developer Codelobster Software
Web Site http://www.codelobster.com/
Language English, Russian, German, Spanish, French, Portuguese

Download link:

Free PHP, HTML, CSS, JavaScript editor (IDE) – Codelobster PHP Edition

Releasewechsel in PHP

Offensichtlich stellt die Auslieferung ein neuen Releases in einigen PHP-Projekten einen hohen manuellen Aufwand dar, da Dateien über die bestehende Installation mehr oder weniger manuell kopiert werden. Dabei müssen selbstverständlich zu löschende Dateien und Ordner berücksichtigt werden, sowie ist darüber hinaus dieser Vorgang nur vorwärtsgerichtet und kann im Falle eines massiven Fehlers nur zurückgerollt werden sofern eine Komplettsicherung vorliegt.
Zu guter Schluss kann dieser manuelle Vorgang mehrere Minuten bis sogar Stunden in Anspruch nehmen und damit eine längere Downtime der Webseite bzw. des Services einfordern. Je nach Projekt kann dies unerwünscht und in Folge dessen auch noch mit hohen Kosten verbunden sein – zum einen durch Personalkosten sowie zum anderen der Nichtverfügbarkeit und dem damit verbundenen Nutzungsausfall. Wer zur Krönung dann noch eine ganze Farm von installierten Applikationen zu aktualisieren hat wird letztlich seinen Aufwand nochmal um die Anzahl der Hosts multiplizieren dürfen.

In diesem Sinne: Prost Mahlzeit!

Releasewechsel in PHP weiterlesen

isset() Prüfung schlägt fehl

Die Prüfung auf definierte Schlüssel in einem PHP-Array kann wie folgt vorgenommen werden:

$data = array(
    'id' => 4711,
    'value' => NULL
);

if( isset( $data['id'] ) ) {
 echo "id existiert!\n";
}
if( isset( $data['value'] ) ) {
 echo "value existiert!\n";
}

Es kann jedoch vorkommen, dass hinter einem Eintrag der Wert NULL gespeichert ist. Die Funktion isset() wird dann das Vorhandensein des Eintrags dennoch als FALSE werten und damit wird dem Entwickler bzw. dem ursprünglichen Programmfluss weisgemacht, dass der Eintrag nicht vorhanden ist und mit dieser falschen Annahme die Programmausführung fortsetzen und zu unbegreiflichen Ergebnissen führen. isset() Prüfung schlägt fehl weiterlesen

Referenzen in PHP

Wer braucht schon Referenzen in PHP? Wenn man nun alles in PHP elegant via objektorientierter Programmierung erledigt ist diese Frage eigentlich gar kein Thema für den Alltag.

Was aber tun wenn man nun doch damit konfrontiert wird, so stelle ich fest, dass man die Referenzierung sowohl bei der Definition als auch beim Abruf explizit aufzeigen muss. Referenzen in PHP weiterlesen

Umstellung mysql auf mysqli

Mit PHP 5.5.0 werden die alten mysql-Funktionen als deprecated markiert und in einer künftigeren – mit dem heutigen Stand jedoch nicht näher spezifizierten Version – gänzlich entfernt. Daher sollte eine Umstellung dessen in den eigenen Projekten mittelfristig eingeplant werden. Dafür habe ich an dieser Stelle eine Umfängliche Schritt-für-Schritt Anleitung zusammengestellt.

MySQL: Das umfassende HandbuchDie Umstellung der mysql_*-Funktionen auf mysqli_*-Funktionen geht relativ reibungslos vonstatten, sofern man eine zentrale Verarbeitung der Datenbankabfragen implementiert hat. Ist dies nicht der Fall so wird sich der hier aufgeführte Aufwand um die Anzahl der zu behandelnden Stellen zuzüglich der notwendigen Tests in ungefähr multiplizieren. Umstellung mysql auf mysqli weiterlesen