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 HTML care afiseaza o linie orizontala.
<br> <em> <hr>
Continut ...
<hr />
Alt continut sub linie ...
Care proprietate CSS defineste culoarea textului?
font-style font-variant color
h2 {
  color: #cbdafb;
}
Clic pe functia care cauta daca un anume caracter sau text e intr-un sir.
indexOf() toString() split()
var str = "Web courses - http://CoursesWeb.net/";
if(str.indexOf("http://") == -1) alert("http:// nu e in sir");
else alert("http:// e in sir");
Care e functia ce imparte un sir in parti de siruri intr-un array, pe baza unui separator?
array_merge() explode() implode()
$str = "mar,banana,pepene,para";
$arr = explode(",", $str);
var_export($arr);      // array (0=>"mar", 1=>"banana", 2=>"pepene", 3=>"para")
Indicati asocierea corecta: "luna-anotimp".
April - Autumn October - Spring July - Summer
July is a beautiful summer month.
- Iulie este o frumoasa luna de vara.
Indicati asocierea corecta: "luna-anotimp".
Octubre - Primavera Julio - Verano Abril - Otoño
Julio es un hermoso mes de verano.
- Iulie este o frumoasa luna de vara.
Script afisare ultimile subiecte de pe forum

Last accessed pages

  1. Coduri pt culori (73187)
  2. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (277003)
  3. Curs PHP MySQL, Tutoriale si Scripturi PHP (129052)
  4. PHP MySQL - Introducere si Tipuri de Date (3466)
  5. Verbe reflexive 1 (11657)

Popular pages this month

  1. Curs HTML gratuit Tutoriale HTML5 (532)
  2. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (501)
  3. Coduri pt culori (307)
  4. Creare si editare pagini HTML (177)
  5. Formatare text in pagina html (175)