Des liens directs pour les articles virtuels

Ceci est une ARCHIVE, peut-être périmée. Vérifiez bien les compatibilités !

Un tout petit hack pour faire pointer les articles virtels directement sur leur destination réelle.

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");

Notes

[1Voir dans l’aide en ligne de spip pour une explication de cette fonctionnalité.

Discussion

4 discussions

  • 4

    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 :-)

    • François Schreuer

      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 avec spip_redirect.php3).

      Ajoute ces lignes au début de ton fichier inc-urls.php3 et ça devrait fonctionner :

      # On charge les fonctions de connection au cas où le fichier est appelé hors contexte spip
      require("ecrire/inc_version.php3");
      require("ecrire/inc_connect.php3");
      include_ecrire("inc_db_mysql.php3");
      include_ecrire("inc_filtres.php3");
    • 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 :

    <ul>
    <BOUCLE_articles(ARTICLES)>
    <BOUCLE_externe(ARTICLES){id_article}{virtuel!=''}>
    <li>[(#_articles:TITRE)], <a href="[(#_articles:VIRTUEL)]">Lire... </a></li>
    </BOUCLE_externe>
    </BOUCLE_articles>
    </ul>

    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

  • 1

    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,

      bonjour, j’ai essayé mais aucun modification aucun message d’erreur j’ai modifié le fichier inc-url-html.php3 qui peut m’aider ?

      Il faudrait être plus précis. Je ne comprends pas ton problème.

      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

      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 :

  • Désactiver tous les plugins que vous ne voulez pas tester afin de vous assurer que le bug vient bien du plugin X. Cela vous évitera d’écrire sur le forum d’une contribution qui n’est finalement pas en cause.
  • Cherchez et notez les numéros de version de tout ce qui est en place au moment du test :
    • version de SPIP, en bas de la partie privée
    • version du plugin testé et des éventuels plugins nécessités
    • version de PHP (exec=info en partie privée)
    • version de MySQL / SQLite
  • Si votre problème concerne la partie publique de votre site, donnez une URL où le bug est visible, pour que les gens puissent voir par eux-mêmes.
  • En cas de page blanche, merci d’activer l’affichage des erreurs, et d’indiquer ensuite l’erreur qui apparaît.

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.

Qui êtes-vous ?
[Se connecter]

Pour afficher votre trombine avec votre message, enregistrez-la d’abord sur gravatar.com (gratuit et indolore) et n’oubliez pas d’indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom