How to publish extended information in php
Publish extended information
Extensions can publish phpinfo()
or the information required by the reflection API. Let's take a look together.
This chapter won’t be too long because it’s really simple.
Related learning recommendations: PHP programming from entry to proficiency
MINFO() hook
If declared, everything will Do it in the declared MINFO()
hook. If not declared, the engine will run a default function to print information about the extension. This function will only print the extension's version and the final declared INI entry.
If you want to join this process, you must declare a MINFO()
hook in the extension structure.
NOTE
Everything happens in ext/standard/info.c, which you can read. The engine prints information about PHP extensions by calling php_info_print_module()
The following is a simple MINFO()
case:
#include "php/main/SAPI.h" #include "ext/standard/info.h" #define PIB_TXT "PHPInternalsBook Authors" #define PIB_HTML "<h3 id="nbsp-PIB-TXT-nbsp">" 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 };
The main thing you have to do is deal with the php_info_print_*()
API, which allows you to print information to the generated output stream. If you want to print some raw information, a simple php_write()
will suffice. php_write()
treats the information you pass in as a parameter of the SAPI output stream, and php_info_print_*()
API is the same, but it will be formatted as required before. If If you want HTML format, you will use HTML's table-tr-td tag. If you don't need to format it into HTML, you will simply use spaces to separate it.
As you can see, you have to include ext/standard/info.h to introduce the php_info_print_*()
API, and you also need to include php /main/SAPI.h to get the sapi_module
symbol. This symbol is global and represents the SAPI used by the current PHP process. The phpinfo_as_text
field tells you if you are going to write a "Web" SAPI like php-fpm or write a "Web" like php-cli text” (SAPI).
What can trigger your MINFO()
hook is the following:
- Call the client’s
phpinfo()
function -
php -i
,php-cgi -i
,php-fpm -i
. Or a more abstract expression is<sapi_binary> - i</sapi_binary>
- ##php --ri
or the client's
ReflectionExtension::info()
Note: Pay attention to the output format. If you need to convert between text and HTML, look intoIf you want to display your INI settings, just call thesapi_module.phpinfo_as_text
. You have no way of knowing how the extended information on the client side is called.
DISPLAY_INI_ENTRIES() macro in your
MINFO(). For the analysis of this macro, see display_ini_entries().
MINFO() are the following:
- Calling the client's
- phpinfo()
Function
- php -i
,
php-cgi -i,
php-fpm -i. Or a more abstract expression is
- i ##php --ri - or the client's
ReflectionExtension::info()
DISPLAY_INI_ENTRIES()Pay attention to the output format. If you need to convert between text and HTML, look into
sapi_module.phpinfo_as_text. You have no way of knowing how the extended information on the client side is called.
If you want to display your INI settings, just call the
macro in your MINFO()
. For the analysis of this macro, see display_ini_entries().Instructions on the reflection API
Reflection uses your
zend_module_entry structure extensively. For example, when you call ReflectionExtension::getVersion()
, the API will only read the version field of the zend_module_entry
structure. Same as discovering functions, your
has a const struct _zend_function_entry * functions
member, which is used to register PHP functions. <p>Basically, the PHP userland reflection API just reads your <code>zend_module_entry
structure and publishes that information. It can also use your module_number
to collect information about extensions registered in different places in the engine. For example, ReflectionExtension::getINIentries()
or ReflectionExtension::getClasses()
use this.
The above is the detailed content of How to publish extended information in php. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.
