Curs Php-mysql

 

Acest script poate sa afiseze in oricare pagina din site, generata cu PHP, ultimile subiecte de pe un Forum, subiecte pe care le preia din pagina XML (Atom 1.0) generasta de forumul respectiv, PHPBB sau MyBB.
Acel forum trebuie sa aibe functionala si activata aplicatia de generare a paginilor XML pentru fluxurile Atom /RSS.
Scriptul preia datele din pagina XML de la adresa mentionata in el (la variabila $file_xml) si le parseaza (parcurge) retinand de la fiecare subiect: titlul, data, adresa URL si o parte din continutul subiectului.
Numarul de subiecte returnate si numarul de cuvinte retinut din fiecare continut pot fi usor modificate in codul php.

Acest script e facut sa functioneze pentru forumurile PHPBB sau MyBB care genereaza fluxuri Atom ca sa fie citite de surse externe, dar poate fi relativ usor modificat ca sa afiseze datele din fluxuri RSS 2.0 sau alte forumuri cu modul de generare pagini .xml. Trebuie doar modficate numele tagurilor din variabila Array "$tags_xml" comform cu cele folosite in pagina .xml citita.

- Pentru MyBB folositi feed-ul Atom 1.0 feed.

Mod de instalare

      1. Copiati codul de mai jos intr-un fisier PHP pe serverul dv. (de ex. cu denumirea "s_forum.php"), in acelasi director in care se afla si fisierul .php in care doriti sa-l includeti. Sau puteti descarca fisierul de la link-ul Download de sus-dreapta.
      2. Modificati valoarea variabilei "$file_xml" cu adresa paginii de flux folosita de forumul dv.
      3. In fisierul in care includeti scriptul, in locul unde vreti sa apara afisate ultimile subiecte, adaugati urmatorul cod:
                        <?php include('s_forum.php'); ?>

Codul scriptului

<?php
// Script shows latest subjects on forum (tested with PHPBB 3.2)
// From: https://coursesweb.net/php-mysql

//HERE add the URL of the RSS feed of your phpbb forum
$file_xml ='https://coursesweb.net/forum/app.php/feed/news';

//to test MyBB (uses atom 1.0 URL)
// $file_xml ='https://community.mybb.com/syndication.php?type=atom1.0'; 

$nr_subj =10; //nr. subjects to display
$nr_cuv =21; //maximum number of words from content to display

//tag names to read from XML
$tags_xml = array('baza'=>'entry', 'titlu'=>'title', 'url'=>'id', 'content'=>'content', 'data'=>'updated');

//gets and parses the XML file
//returns HTML code with latest subjects
function get_last_forum($file_xml) {
 GLOBAL $nr_subj, $nr_cuv, $tags_xml;
 $re ='';

 //get page data with cUrl
 $ch = curl_init();
 curl_setopt($ch, CURLOPT_URL, $file_xml);
 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); 
 curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
 curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
 curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.6) Gecko/20070725 Firefox/2.0.0.6');
 $pg_dat = curl_exec($ch);

 if(!curl_errno($ch) && is_string($pg_dat) && strlen($pg_dat)>11 && ($obj = @simplexml_load_string($pg_dat, null, LIBXML_NOCDATA))){
 $pg_dat ='';
 $baza = $obj->{$tags_xml['baza']};
 $nr_subj = min($nr_subj, count($baza));

 for($i=0; $i<$nr_subj; $i++){
 $titlu = $baza[$i]->{$tags_xml['titlu']};
 $url = str_ireplace(['http://'. $_SERVER['SERVER_NAME'] .'/', '&'], ['', '&amp;'], $baza[$i]->{$tags_xml['url']});
 $content =strip_tags(preg_replace('#\<p\>(.*?)\</p\>#i', '', $baza[$i]->{$tags_xml['content']})); //delete <p> content and tags

 //gets and formats subjects date
 $data = $baza[$i]->{$tags_xml['data']}; 
 $data = date_parse($data);
 $data = $data['day'].'-'.$data['month'].'-'.$data['year'];

 //keep specified nr. words
 if(preg_match('/([^ ]*[ ]{0,1}){1,'.$nr_cuv.'}/i', $content, $m)) $content = $m[0] .' ..';

 $link ='<a href="'. $url. '" title="'. $titlu .'">'. $titlu. '</a> <sup>'. $data.'</sup>';
 $re .='<li>'. $link.'<div>'. $content.'</li>';
 }
 if($re !='') $re ='<ol>'.$re.'</ol>';
 }

 return $re;
}

echo get_last_forum($file_xml); //outputs the result


- Scriptul este gratuit, prin urmare nu se acorda suport, dar daca aveti intrebari legate de el, puteti posta pe Forum.

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Clic pe tag-ul care creaza o lista ordonata numeric
<ul> <tr> <ol>
<ol>
  <li>List-1</li>
  <li>List-2</li>
</ol>
Care selector reprezinta ID-ul unui element in CSS
.nume #nume nume
#id {
  color: #0110fb;
}
Ce cod creaza un obiect in JavaScript?
{} [] new Date()
var obj = {"site": "CoursesWeb.net", "pr": 5};
alert(obj.site);
Indicati instructiunea prin care se verifica daca o conditie este True sau False
else if() switch()
$var = 8;
if($var == 8) echo $var;
Indicati timpul Prezent pentru verbul "to be" (a fi).
be were is
Now, it is here.
- Acum este aici.
Care este conjugarea la timpul prezent al verbului "divertirse" (a se distra) la forma "yo"?
te diviertas me divierto se divierta
Yo me divierto.
- Eu ma distrez.
Script afisare ultimile subiecte de pe forum

Last accessed pages

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (277905)
  2. Prezentul simplu si continuu - Present Tense Simple and Continuous (149607)
  3. Creare clase in JavaScript cu Metode care pot fi inlantuite (1182)
  4. Prezentul continuu - Exercitii si teste incepatori (39478)
  5. Aliniere DIV-uri pe aceeasi linie (5377)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (21)
  2. Curs HTML gratuit Tutoriale HTML5 (12)
  3. Limba spaniola curs online incepatori si avansati (8)
  4. Prezentul simplu si continuu - Present Tense Simple and Continuous (6)
  5. Coduri pt culori (6)