Bei meinem aktuellen Projekt stellte sich das Problem, dass die aktuellen Blog Beiträge zusätzlich auf der statischen Homepage dargestellt werden sollten. Bessere Verlinkung mit dem Blog, SEO-technische Vorteile, aber auch bessere Navigation auf der Seite sind die positiven Effekte. So ein „recent Posts“ Widget ist schnell selber gebastelt.
Entscheidend ist ob man den Blog am gleichen Webspace liegen hat und somit direkt auf die php-Files der WordPressinstallation zugreifen kann, oder ob man diese Möglichkeit nicht hat, wodurch man direkt auf die Datenbank zugreifen muss. Sollte wegen Sicherheitseinstellungen auch das nicht möglich sein, könnte man noch ein „Wdiget“ auf dem Webspace des Blogs zusammenbasteln und dieses per iframe einbauen, was aber eher Notlösung sein sollte und hier nicht behandelt wird.
Mit Zugriff auf die WordPress Files
Hat man den Blog z.B. in einem Unterverzeichnis der Seite liegen und hat man somit Zugriff auf die WP-Files, so kann durch inkludieren des Files wp-load.php aus dem WordPress-Hauptverzeichnis praktisch die gesamte WordPress Funktionalität nutzen.
Mit der get_the_excerpt Funktion hatte ich meine Probleme, weshalb ich eine eigene „Exzerpt“ Funktionalität realisiert habe. Der Code ist soweit selbsterklärend.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
include('blog/wp-load.php'); $recent_posts = wp_get_recent_posts( array('numberposts' => 4) ); echo ('<ul>'); foreach($recent_posts as $post) { $timestamp = strtotime($rowblog['post_date']); $titel = $post['post_title']; $link = get_permalink($post['ID']); $post_content = $post['post_content']; //Artikelinhalt $post_content = strip_tags($post_content); //Alle HTML Tags entfernen. Nur reinen Text anzeigen lassen. $post_content = substr($post_content,0,120); //Ausgabe auf 250 Zeichen begrenzen echo ('<li><div class="date">'.$timestamp.'</div><div class="text"><strong><a href="'.$link.'" class="title">'.$titel.'</a></strong><br>'.$post_content.'...</div></li>'); } echo ('</ul>'); |
Ohne Zugriff auf die WordPress php-Files
Alternativ besteht die Möglichkeit die letzten Artikel direkt aus der Datenbank auszulesen. Dies kann (sofern dies die Sicherheitseinstellungen des Providers zulassen) auch von einem anderen Webspace passieren. DB_HOST, DB_USER, DB_PASSWORD, DB_NAME gehören angepasst. Diese findest du unter anderem in deiner wp-config.php im WordPress Verzeichnis. Weiters muss man unten beim Zusammenbau des Links die Blogadresse eingeben.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
try { $verbindung = new PDO("mysql:host= DB_HOST ;dbname= DB_NAME", DB_USER, DB_PASSWORD, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8")); } catch(PDOException $e) { echo $e->getMessage(); } $qu = $verbindung->query("SELECT post_title, post_name, post_content, post_date FROM wp_posts WHERE post_type = 'post' AND post_status = 'publish' ORDER BY post_date DESC LIMIT 0, 5"); $qu->setFetchMode(PDO::FETCH_OBJ); echo('<ul>'); while($row = $qu->fetch()) { // hier erfolgt die Ausgabe der Beiträge z.B. echo ($row->post_date); $link = "http://www.blogadresse.net".$row->post_name; echo ('<a href="'.$link.'">'.$row->post_title.'</a>'); echo ($row->post_content); } echo('</ul>'); |
- Info:
- Recent Posts ausserhalb eines WordPress Blogs ist Beitrag Nr. 8
- Autor:
- codingFreak am 13. April 2014 um 14:29
- Category:
- Wordpress