Définition du problème
Actuellement, les « articles redirigés » [1] (ou « articles virtuels ») fonctionnent de la manière suivante : le lien public vers l’article ne se différencie pas du lien pointant vers un article « normal ». Ce n’est qu’au moment où l’on appelle cet article que l’on est redirigé vers sa véritable destination (une page qui peut être un article du site ou une page extérieure). Pratiquement, cela oblige les internautes à « naviguer en aveugle ».
Nous allons ici faire en sorte que le lien affiché sur le site public soit directement le bon.
Avantages
- C’est plus propre : on donne une information plus précise à l’internaute, on lui permet de savoir où il va (le lien réel s’affiche dans la barre d’état (status bar)).
- On accélère la navigation : il y a une requête html de moins pour l’internaute. C’est donc plus rapide. Marginalement, pour la même raison, ça allège la charge du serveur (une requête http en moins et quelques dizaines de lignes de code en moins à exécuter). L’effet pour le serveur est cependant minime dans la mesure où il n’y a pas d’appel à la base de données (la redirection est stockée telle quelle dans le cache de spip).
Inconvénients
- On alourdit le calcul des pages. Le gain obtenu au moment de la navigation se paie par une plus grande complexité lors du calcul des pages (plus grand nombre d’appels à la base de données,...). A la rigueur, sur un serveur très lent ou très chargé, avec des pages très longues, ça peut provoquer un timeout de php.
Mise en œuvre
Il vous suffit de remplacer votre fonction generer_url_article()
par celle qui suit (dans votre fichier inc-urls-html.php3
ou inc-urls-standard.php3
selon le mode d’écriture des urls que vous avez choisi).
function generer_url_article($id_article) {
$r = spip_fetch_array(spip_query("SELECT chapo FROM spip_articles WHERE id_article='$id_article' LIMIT 1"));
if(substr($r['chapo'], 0, 1) == '=') {
if(ereg('^(art(icle)?|rub(rique)?|br(.ve)?|aut(eur)?|mot|site|doc(ument)?|im(age|g))? *([[:digit:]]+)$', substr($r['chapo'], 1),$match)) {
switch (substr($match[1], 0, 2)) {
case 'ru': return generer_url_rubrique($match[8]); break;
case 'br': return generer_url_breve($match[8]); break;
case 'au': return generer_url_auteur($match[8]); break;
case 'mo': return generer_url_mot($match[8]); break;
case 'im':
case 'do': return generer_url_document($match[8]); break;
case 'si':
$row = @spip_fetch_array(@spip_query("SELECT nom_site,url_site FROM spip_syndic WHERE id_syndic='$id_lien' LIMIT 1"));
if ($row) return $row['url_site']; break;
default: return generer_url_article($match[8]); break;
}
}
else
return substr($r['chapo'], 1);
}
else
// Version html
# return "article".$id_article.".html";
// Version standard
return "article.php?id_article=".$id_article;
}
Notez qu’il faut éventuellement modifier la dernière ligne de la fonction si vous utiliser les urls « html » (comme expliqué en commentaire du code).
Enfin, ajoutez les quatre lignes suivantes au début de votre fichier inc-urls-....php3
:
// On charge les fonctions de connection au cas ou le fichier
// est appele hors contexte spip
require("ecrire/inc_version.php3");
require("ecrire/inc_connect.php3");
include_ecrire("inc_db_mysql.php3");
include_ecrire("inc_filtres.php3");
Discussions par date d’activité
4 discussions
Merci, c’est simple et génial :-)
Un petit bémol, en 1.7+ quand j’essaye d’utiliser « Voir cet article » de n’importe quel article à partir de l’espace privé j’ai le message d’erreur suivant :
Fatal error : Call to undefined function : spip_fetch_array() in /home/missmopi/www/inc-urls-html.php3 on line 8
Pas encore eu le temps de creuser, mais comme c’est un site où je suis la seule à saisir je préfère encore utiliser votre contrib qui m’ote une épine du pied :-)
Salut,
De fait, j’aurais du le signaler dans l’article (je vais corriger ça).
Quand on utilise des requêtes sql dans le fichier
inc-urls.php3
, il faut charger les librairies ad hoc pour les cas où ces librairies n’ont pas déjà été chargées dans le contexte (ce qui est le cas avecspip_redirect.php3
).Ajoute ces lignes au début de ton fichier
inc-urls.php3
et ça devrait fonctionner :Merci pour cette réponse ultra-rapide. Je mets ça en place ce soir !
Ca a marché, merci beaucoup :-)
Répondre à ce message
Dans SPIP 3, il existe un nouveau champ nommé « virtuel » (à ma connaissance non encore documenté) dans la table articles. Si l’article est virtuel, ce champ contient l’URL de l’article, sinon le champ est vide.
Un exemple affichant uniquement les articles redirigés :
Je vous laisse le soin de fignoler, mettre par exemple une classe « spip_out » sur le lien , etc.
Répondre à ce message
Je viens de mettre une alternative plus simple dans les variantes, rien que du code (PHP) à mettre dans le squelette et seulement là.
Pour SPIP version 1.8.2
Répondre à ce message
bonjour,
j’ai essayé mais aucun modification aucun message d’erreur j’ai modifié le fichier inc-url-html.php3
qui peut m’aider ?
voila sinon je voudrais que quand on clique sur une sous rubrique, l’article apparaissent directement sans passer par le résumé ce qui oblige le visiteur à recliquer une autre fois pour voir l’article en entier
merci de votre aide
Bonjour,
Il faudrait être plus précis. Je ne comprends pas ton problème.
Ca, si je comprends bien ce que tu cherches, c’est un autre problème. Va par exemple jeter un oeil ici.
FS
Répondre à ce message
Ajouter un commentaire
Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :
Merci d’avance pour les personnes qui vous aideront !
Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.
Suivre les commentaires : |