wp trackback.php,WordPress工作原理

WordPress是一个单入口的文件,所有的前端处理都必须经过index.php,这是通过修改web服务器的rewrite规则来实现的。这种做法的好处是显而易见的,这样URL更好看,不必为每一个url新建一个文件。

我们看看wp大致的文件调用是什么样子的。

1d8f88d0dcf48308e0230a0fcf547d8c.gif

wordpress可以分为3个阶段,一是初始化阶段,即初始化常量、环境、加载核心文件等等;二是内容处理阶段,即根据用户的请求调用相关函数获取和处理数据,为前端展示准备数据;三是主题应用阶段,在这个阶段,需要展示的数据已经准备完毕,需要根据用户的请求加载相应的主题模板,即对主题进行路由。经过这三各阶段,用户请求的页面就可以完全的展现出来了。从上图可以看到wp的初始化阶段相当的繁琐。

index.php文件

WordPress初始化的过程:当你输入你的网址对wordpress进行初始化时,wordpress默认会找

根目录下的index.php页面,看一下index.php页面。

//该常量定义为false时,不使用主题,站点会显示为空白,为true时,则正常显示。

define('WP_USE_THEMES', true);

//加载wp-blog-header.php

require('./wp-blog-header.php');

wp-blog-header.php文件

你会发现,它会去调用根目录下的wp-blog-header.php,我们继续看wp-blog-header.php

//wp_did_header变量,相当于一个flag,确保每次刷新时,wp-blog-header.php文件只执行一次。

if ( !isset($wp_did_header) ) {

$wp_did_header = true;//设置为true,确保只执行一次。

//初始化阶段。加载wp-load.php,

require_once( dirname(__FILE__) . '/wp-load.php' );

//内容处理阶段 wp()位于functon.php中,创建WordPress查询

wp();

//主题应用阶段。ABSPATH wordpress目录的绝对路径

require_once( ABSPATH . WPINC . '/template-loader.php' );

}

wp-load.php 文件

接下来会调用wp-load.php 文件,wp-load.php 主要用来判断WordPress 程序根目录中是否包含 wp-config.php 文件。如果有则加载;

如果没有则检查是否用户将该文件移到其他文件夹下,并且如果在其他文件夹下发现 WordPress 配置文件后还有检查该文件夹下是否有 wp-settings.php 文件以避免同一个服务器安装多个网站时调用的是其他 WordPress 程序的配置文件;

最后如果还是找不到 wp-config.php 文件,那么程序会运行 wp-admin 文件夹下的 setup-config.php文件以及 wp-includes 文件夹下的 load.php 、 functions.php 、 version.php 这几个文件引导用户重新生成一个 wp-config.php 文件,一般说来就像我们重新安装 WordPress 弹出的界面一样。该文件下代码比较多就不复制了,大家可自行看下。

通过wp-load.php,wordpress先后把wp-config.php, wp-setting.php,classes.php,fucntions.php,

query.php等文件加载进来,并建立了三个全局变量,$wp_the_query,$wp_rewrite和$wp ,分别为WP_Query,

WP_Rewrite和WP类的实例。然后,wp-blog-header执行wp()函数,并通过其调用$wp所属WP类的main方法,

这个方法又调用一系列方法,但最重要的是parse_request方法, WP从这里开始解析URL并建立主循环。

wp-config.php

// ** MySQL 设置 - 具体信息来自您正在使用的主机 ** //

/** WordPress 数据库的名称 */

define('DB_NAME', SAE_MYSQL_DB);

/** MySQL 数据库用户名 */

define('DB_USER', SAE_MYSQL_USER);

/** MySQL 数据库密码 */

define('DB_PASSWORD', SAE_MYSQL_PASS);

/** MySQL 主机 */

define('DB_HOST', SAE_MYSQL_HOST_M.':'.SAE_MYSQL_PORT);

/** 创建数据表时默认的文字编码 */

define('DB_CHARSET', 'utf8');

/** 数据库整理类型。如不确定请勿更改 */

define('DB_COLLATE', '');

define('WP_USE_MULTIPLE_DB', true);

$db_list = array(

'write'=> array(

array(

'db_host' => SAE_MYSQL_HOST_M.':'.SAE_MYSQL_PORT,

'db_user'=> SAE_MYSQL_USER,

'db_password'=> SAE_MYSQL_PASS,

'db_name'=> SAE_MYSQL_DB,

'db_charset'=> 'utf8'

)

),

'read'=> array(

array(

'db_host' => SAE_MYSQL_HOST_S.':'.SAE_MYSQL_PORT,

'db_user'=> SAE_MYSQL_USER,

'db_password'=> SAE_MYSQL_PASS,

'db_name'=> SAE_MYSQL_DB,

'db_charset'=> 'utf8'

)

),

);

$global_db_list = $db_list['write'];

/**#@+

* 身份密匙设定。

*

* 您可以随意写一些字符

* 或者直接访问 {@link https://api.wordpress.org/secret-key/1.1/salt/ WordPress.org 私钥生成服务},

* 任何修改都会导致 cookie 失效,所有用户必须重新登录。

*

* @since 2.6.0

*/

define('AUTH_KEY', hash_hmac('sha1', SAE_ACCESSKEY . 'AUTH_KEY', SAE_SECRETKEY ));

define('SECURE_AUTH_KEY', hash_hmac('sha1', SAE_ACCESSKEY . 'SECURE_AUTH_KEY', SAE_SECRETKEY ));

define('LOGGED_IN_KEY', hash_hmac('sha1', SAE_ACCESSKEY . 'LOGGED_IN_KEY', SAE_SECRETKEY ));

define('NONCE_KEY', hash_hmac('sha1', SAE_ACCESSKEY . 'NONCE_KEY', SAE_SECRETKEY ));

define('AUTH_SALT', hash_hmac('sha1', SAE_ACCESSKEY . 'AUTH_SALT', SAE_SECRETKEY ));

define('SECURE_AUTH_SALT', hash_hmac('sha1', SAE_ACCESSKEY . 'SECURE_AUTH_SALT', SAE_SECRETKEY ));

define('LOGGED_IN_SALT', hash_hmac('sha1', SAE_ACCESSKEY . 'LOGGED_IN_SALT', SAE_SECRETKEY ));

define('NONCE_SALT', hash_hmac('sha1', SAE_ACCESSKEY . 'NONCE_SALT', SAE_SECRETKEY ));

/**#@-*/

/**

* WordPress 数据表前缀。

*

* 如果您有在同一数据库内安装多个 WordPress 的需求,请为每个 WordPress 设置不同的数据表前缀。

* 前缀名只能为数字、字母加下划线。

*/

$table_prefix = 'wp_';

/**

* WordPress 语言设置,默认为英语。

*

* 本项设定能够让 WordPress 显示您需要的语言。

* wp-content/languages 内应放置同名的 .mo 语言文件。

* 要使用 WordPress 简体中文界面,只需填入 zh_CN。

*/

define ('WPLANG', 'zh_CN');

/**

* 开发者专用:WordPress 调试模式。

*

* 将这个值改为“true”,WordPress 将显示所有开发过程中的提示。

* 强烈建议插件开发者在开发环境中启用本功能。

*/

define('WP_DEBUG', false);

/* 好了!请不要再继续编辑。请保存该文件。 */

/** WordPress 目录的绝对路径。 */

if ( !defined('ABSPATH') )

define('ABSPATH', dirname(__FILE__) . '/');

/** 设置 WordPress 变量和包含文件。 这个文件内容很多啊,分析较困难*/

require_once(ABSPATH . 'wp-settings.php');

wp-config.php 主要用来连接网站数据库并将数据库中的一些必要信息返回,具体关于该文件的介绍大家可参考这篇文章>>> WordPress基础配置文件wp-config.php详解 。同时该文件还会调用 wp-settings.php 文件以读取用户对文件的设置并加载相关内容。

wp-setting.php

前面那些文件没有什么问题的话,WordPress 会自动加载该文件。该文件主要是一些 require 的语句,用来加载一些类库文件及函数文件等,为 WordPress 的运行做准备,这些文件一般都在 wp-include 文件夹下,大家可以简单浏览下该文件夹下的文件结构理解 WordPress 的运行原理。

template-loader.php

当运行到第二步 wp-blog-header.php 时,程序除了加载wp-load.php 文件还会加载 wp-include 文件夹下的 template-loader.php 文件,该文件主要用于根据用户URL返回加载相应模板,包括页面模板、文章模板、分类模板、首页模板等。另外该文件还会根据是否启用 trackback 来确定是否加载 wp-trackback.php 文件。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值