Comment publier des informations étendues en php

coldplay.xixi
Libérer: 2023-04-09 11:44:02
avant
1737 Les gens l'ont consulté

Comment publier des informations étendues en php

Publié les informations sur l'extension

Expand peut publier des informations sur

ou refléter les exigences de l'API. Jetons un coup d'oeil. phpinfo()

Ce chapitre ne sera pas trop long car il est vraiment simple.

Recommandations d'apprentissage associées :

Programmation PHP de l'entrée à la maîtrise

Hook MINFO()

S'il est déclaré, tout fera l'affaire dans le crochet

de la déclaration. S'il n'est pas déclaré, le moteur exécutera une fonction par défaut pour imprimer des informations sur l'extension. Cette fonction imprimera uniquement la version de l'extension et l'entrée INI finale déclarée. MINFO()

Si vous souhaitez rejoindre ce processus, vous devez déclarer un hook

dans la structure de l'extension. MINFO()

REMARQUE

Tout se passe dans ext/standard/info.c, que vous pouvez lire. Le moteur imprime des informations sur les extensions PHP en appelant php_info_print_module()

Voici un cas

simple : MINFO()

#include "php/main/SAPI.h"
#include "ext/standard/info.h"

#define PIB_TXT  "PHPInternalsBook Authors"
#define PIB_HTML "<h3>" PIB_TXT "</h3>"

PHP_MINFO_FUNCTION(pib)
{
    time_t t;
    char cur_time[32];

    time(&t);
    php_asctime_r(localtime(&t), cur_time);

    php_info_print_table_start();
        php_info_print_table_colspan_header(2, "PHPInternalsBook");
        php_info_print_table_row(2, "Current time", cur_time);
    php_info_print_table_end();

    php_info_print_box_start(0);
        if (!sapi_module.phpinfo_as_text) {
            php_write(PIB_HTML, strlen(PIB_HTML));
        } else {
            php_write(PIB_TXT, strlen(PIB_TXT));
        }
    php_info_print_box_end();
}

zend_module_entry pib_module_entry = {
    STANDARD_MODULE_HEADER,
    "pib",
    NULL, /* Function 入口 */
    NULL, /* Module 初始化 */
    NULL, /* Module 关闭 */
    NULL, /* Request 初始化 */
    NULL, /* Request 关闭 */
    PHP_MINFO(pib), /* Module information */
    "0.1", /* 扩展的版本号写在这里 */
    STANDARD_MODULE_PROPERTIES
};
Copier après la connexion

Comment publier des informations étendues en php

La principale chose que vous devez faire est l'API de traitement

qui vous permet d'imprimer des informations sur le flux de sortie généré. Si vous souhaitez imprimer des informations brutes, un simple php_info_print_*() suffira. php_write() consiste à traiter les informations que vous transmettez comme un paramètre du flux de sortie SAPI, et l'API php_write() est la même, mais elle sera formatée selon les exigences précédentes. Si vous souhaitez le format HTML, vous l'utiliserez. Les balises php_info_print_*() table-tr-td du HTML, si elles n'ont pas besoin d'être formatées en HTML, seront simplement séparées par des espaces.

Comme vous pouvez le voir, vous devez inclure

ext/standard/info.h pour importer l' API, et vous devez également inclure php_info_print_*()php/main/SAPI .h pour obtenir le symbole . Ce symbole est global et représente le sapi_moduleSAPI utilisé par le processus PHP actuel. Le champ vous indique si vous allez écrire un SAPI "Web" comme phpinfo_as_textphp-fpm ou écrire un "texte" comme php-cli ( SAPI).

Ce qui peut déclencher votre

hook est le suivant : MINFO()

    Appelez la fonction
  • du client phpinfo()
  • , php -i, php-cgi -i . Ou une expression plus abstraite est php-fpm -i<sapi_binary> - i</sapi_binary>
  • ou celle du client php --riReflectionExtension::info()
Remarque :

doit faire attention au résultat format. Si vous avez besoin d'effectuer une conversion entre texte et HTML, consultez

. Vous n'avez aucun moyen de savoir comment sont appelées les informations étendues côté client. sapi_module.phpinfo_as_text

Si vous souhaitez afficher vos paramètres INI, appelez simplement la macro

dans votre MINFO(). Pour l'analyse de cette macro, voir display_ini_entries().DISPLAY_INI_ENTRIES()

Ce qui peut déclencher votre

hook est le suivant : MINFO()

    Appelez la fonction
  • côté utilisateur phpinfo()
  • , php -i, php-cgi -i. Ou une expression plus abstraite est php-fpm -i<sapi_binary> - i</sapi_binary>
  • ou celle du client php --riReflectionExtension::info()
Remarque :

doit faire attention au résultat format. Si vous avez besoin d'effectuer une conversion entre texte et HTML, consultez

. Vous n'avez aucun moyen de savoir comment sont appelées les informations étendues côté client. sapi_module.phpinfo_as_text

Si vous souhaitez afficher vos paramètres INI, appelez simplement la macro

dans votre MINFO(). Pour l'analyse de cette macro, voir display_ini_entries().DISPLAY_INI_ENTRIES()

Explication sur l'API de réflexion

Reflection utilise largement votre

structure. Par exemple, lorsque vous appelez zend_module_entry, l'API lira uniquement le champ version de la structure ReflectionExtension::getVersion(). zend_module_entry

Comme pour la découverte de fonctions, votre

possède un membre zend_module_entry qui est utilisé pour enregistrer les fonctions PHP. const struct _zend_function_entry * functions

Fondamentalement, l'API de réflexion PHP userland lit simplement votre zend_module_entry structure et publie ces informations. Il peut également utiliser votre module_number pour collecter des informations sur les extensions enregistrées à différents endroits du moteur. Par exemple, ReflectionExtension::getINIentries() ou ReflectionExtension::getClasses() utilisez ceci.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
php
source:learnku.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal