如何开启WordPress基础调试外的更多高级调试功能?

调试WordPress是从WP_DEBUG开始的,但是还有更多的调试功能可以使用。在本文中,我们将:请参阅如何将调试消息写入日志文件以及该文件的位置学习如何使用未压缩的JavaScript和CSS核心文件进行调试,了解如何记录在一个页面上运行的所有SQL查询,了解一些增强调试体验的插件

将调试消息写入日志文件

要开始调试,请转到wp-config.php在WordPress文件系统的根目录下创建一个文件,并打开debug变量,即将debug设置为true:

define( 'WP_DEBUG',true );将此常量定义为true将导致所有PHP错误、通知和警告显示在屏幕上。强烈建议在项目的开发阶段这样做,因为它会在开发过程中向您显示代码中的错误,并且您可以立即修复它们。

但是如果您想检查生产站点上的错误呢?在屏幕上显示错误是你最不想做的事情,因为它不仅扰乱网站的外观,还可能是信息泄露的来源。

那么,我们怎样才能捕捉到生产中发生的bug呢?有没有一种方法可以在不与站点访问者共享的情况下查看调试信息?确实存在,这就是wp-config.php文件定义wp中的其他常量。

WP_DEBUG_DISPLAY和WP_DEBUG_LOG介绍

WordPress Codex提供了解决方案:

打开WP_DEBUG后,再打开WP_DEBUG_LOG。这样,跟踪的错误就会写入日志文件。

现在,您可能会问自己谁将创建该日志文件,它将保存在哪里?答案是WordPress为我们解决了这个问题,也就是说,不需要手动创建:一旦出现错误,就会创建一个日志文件,并将其放在wp content文件夹中。太简单了!

接下来要做的是不允许在屏幕上显示错误。为此,需要关闭WP_DEBUG_DISPLAY。

// Disable display of errors and warnings

define('WP_DEBUG_DISPLAY',false);因此,允许我们向文件而不是屏幕发送错误消息的命令集如下:

// Enable WP_DEBUG mode

define('WP_DEBUG',true);

// Enable Debug logging to the /wp-content/debug.log file

define('WP_DEBUG_LOG',true);

// Disable display of errors and warnings

define('WP_DEBUG_DISPLAY',false);如果服务器php.ini文件display_errors设置为1的时候还需要添加这一行,以便在屏幕上隐藏错误。

@ini_set('display_errors',0);

将您自己的消息写入日志文件,或者当ECHO没有正常输出显示的时候

在显示错误的过程中,最方便的调试方法之一是使用echo和var_dump。但是,有时,这些命令无法使用。有时原因很清楚-例如,当创建一个小部件时,save方法出错,echo to the screen将不起作用,因为该函数使用AJAX,因此刷新小部件中您将要回显的部分…其他时候,原因可能不清楚-你只是得到一些致命的错误,不允许页面呈现,你的回声只是没有显示在屏幕上…无论哪种方式,无论原因是否清楚,结果是相同的,你必须找到一个不同的方式来显示变量的值的问题。

解决方案是在wp的wp_config.php配置文件中同时启用wp_debug和wp_debug_ log,即将它们都设置为true。

这将在wp content文件夹中创建一个error.log文件。

如何不使用echo输出变量

现在,不再使用echo命令来输出变量,而是使用error_log PHP命令。

所以,下面的写法就应该被替换了

echo "I'm on line 38";替换成:

error_log("I'm on line 38");

如何记录变量而不是var_dump

现在假设我们没有一个错误字符串或任何字符串,但是我们想检查某些变量的值,就像我们使用var_dump一样。

几年前,我在一篇解释如何将var_dump转储到文件中的帖子中发现了这个代码片段,它是这样的:

$x = "My string";

// Dump x,or any other variable for that matter

ob_start();

var_dump($x);

$contents = ob_get_contents();

ob_end_clean();

error_log($contents);

把我们聪明的调试器变成函数

为了避免每次都要写这8行,最有效的方法是让它成为你的生活中一个永久的函数放在functions.php主题文件,如果你正在开发一个主题,或在你的插件文件之一,如果你正在开发一个插件。函数应该接受一个参数,该参数是应该转储到文件中的变量。

其他错误日志参数

如果您查看error_ log命令,您将看到它还获得3个可选参数。第二个、$message_type和第三个、$destination的组合,在某些情况下还有第四个、$extra_headers,定义了可以写入错误日志的附加位置。

WP配置文件config.php中的更多调试可能性

SCRIPT_DEBUG

有时-不经常-你可能会有问题的JS或CSS文件属于WordPress核心,你想调试他们-插入一些console.log命令或其他形式的调试,

但是WordPress在加载脚本和样式方面非常有效,并且使用JS和CSS文件的缩小版本,但是这些都很难调试。

幸运的是,WordPress为这种情况提供了良好的设备,并提供了每个JS和CSS文件的未统一版本。告诉WordPress使用这些文件的方法是打开wp中的SCRIPT_DEBUG常量,即设置为true。这迫使WordPress使用核心CSS和JavaScript文件的“dev”版本,而不是通常加载的小型版本。

define('SCRIPT_DEBUG',true);

SAVEQUERIES

有时可能需要调试数据库查询。这可能是因为您怀疑其中一个查询花费的时间比它应该花费的时间长,或者它返回了错误的结果,或者其他任何原因导致的,解决方法是查看正在加载的页面上运行的查询。

在这种情况下,打开wp配置文件config.php中的savequerys常量,所有查询都将被保存,此外还将保存有关执行该查询所用的时间以及调用该查询的函数的信息。所有这些数据都存储在全局$wpdb->queries中。

define('SAVEQUERIES',true);

调试插件

除了WordPress允许您调试的内置方式之外,还有一些插件也可以帮助您进行调试。它们提供的信息比内在的可能性多得多,并以更复杂的方式显示出来。这些是最上面的,它们的描述来自WP插件库中的插件页面。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


我想将wordpress的默认接口路由改掉,愿意是默认的带一个 wp-json,我想换成 api,直接简单明了。默认路由https://www.xxzhuti.com/wp-json/wp/v2/posts/1新的路由https://www.xxzhuti.com/api/wp/v2/posts/1路由修改wordpress提供了一个钩子来修改 wp-json 的地址,代码入汛function r
wordpress自定义分类法之后,我看到链接都自动在后面添加了一个斜杠,如下图所示打开链接后都是先从一个链接301后到另外一个链接,我这个纳闷,然后一顿找原因,最后竟然是因为固定链接看我后台的固定链接是 /%post_id%/ 这么写的,然后每次都会301自动跳转。正确的写法是 /%post_id%.html 这样写才不会301跳转。一个小问题,往往一个小问题就会折腾好长时间,在这记录一下吧..
事情是这样的,我用 get_post_type 函数创建了一个自定义分类法类型,然后自定义了文件的访问路径代码如下。function tblog_chat_template( $template_path ){    if ( get_post_type() == 'aichat' ) {         if ( is_single() )         {             $temp
最近网站莫名其妙的被顶上了,过一个多小时,就注册一个账号,虽然不多,但是也挺烦,时间一长垃圾注册的就多了。由于我前台把注册关掉了,只允许用第三方登录,经过查找发现是通过后台注册的,后台无须邮箱验证即可注册,也是就想着在后台加个验证码。效果如下实现方法一将下面的代码加入到 function.php 中,刷新页面就会看到。//WordPress新用户注册随机数学验证码function add_s...
最近服务器要到期了,就想着把网站转移到另外一台服务器,本来打算要续费的,但是腾讯云的服务器有了新的规定,域名必须在腾讯云备案才能使用,在别的地方备案的域名需要转到腾讯云,在腾讯云在走一遍备案流程,若是备案简单,时间短也就无所谓了,就转一下,可是这个备案大家也知道,至少得一个月,于是就只能放弃腾讯云了,将站点转回备案的阿里云,以后就用阿里云了,贵点就贵点吧。这不网站迁移过去了,死活图片不显示,各..
今天在写wordpress的接口,然后碰到个奇怪的问题,怎么访问都提示 rest_no_route 的错误,然后就一直跟踪代码,终于找到原因所在。报错信息{'code': 'rest_no_route','message': '未找到匹配URL和请求方式的路由。','data': {'status': 404}}原因分析register_rest_route( string $namespace,
今天看到群友突然滴滴滴的找我QQ,好像出什么大事情一样。原来他由于误操作导致网站文章被删除。
今天遇到一个网友提示网站访问速度比较慢,然后通知日志看到有他的网站WordPress默认登录地址wp-login.php一直在被爬虫抓取,因为是有被破解后台账户信息,导致的占用数据库资源使得网站资源带宽不足后访问降低导致
今天老左在帮助客户升级WordPress的时候我看他网站也比较简单就直接在后台手工升级的。升级后打开网站有出现"There has been a critical error on your website."的错误提示。
我们在使用WordPress搭建的网站是否有留意查看源代码的时候看到标题中的原本"-",被转义成"&#8211"。其实这样并不影响用户阅读体验和搜索引擎,搜索引擎在收录后也会反向转义的。就是感觉看
WordPress默认是无法上传.webp格式的文件,如果要上传需要对上传文件限制进行解除后才能上传。
GTranslate 是一个流行的翻译插件,在免费和付费版本中提供不同的体验。 使用免费版本,您可以轻松提供任何语言的动态翻译,而付费版本提供可索引、可编辑的翻译版本,就像 Weglot 一样。
时下主流的浏览器都自带了广告屏蔽功能,还有ADSafe、ADB等软件插件,不断更新,屏蔽网站代码!
您是否正在寻找可用于显示数据的 WordPress 表格插件? WordPress 表格插件可让您以表格格式存储和呈现数据,以方便访问者阅读。
wordPress数据库除了本身的表以外,部分插件会增加表来存储数据。如果插件已经删除了,这些插件生成的表还在数据库中,那么怎么删除呢?
WordPress几乎是世界上最安全的开源程序,但其后台登录注册的地址始终是众所周知的,所以不少人觉得隐藏WordPress的登录地址后可能会更加安全。下面浩子就针对这个问题来简单说明一下方法。WordPress隐藏后台登录地址
自 WordPress 5.8 正式版发布 以后,后台的小工具就默认是块编辑器的界面样式,很多老用户还没有来得及学习就一脸茫然了,今天浩子就来教大家如何恢复WordPress经典小工具。
您想用您的语言翻译 WordPress 插件吗?许多 WordPress 插件是完全可翻译的,世界上任何人都可以轻松翻译。在本文中,我们将向您展示如何轻松地将 WordPress 插件翻译成您的语言(无需任何代码)。
WordPress新手不清楚WordPress调试模式怎么开启,今天来教大家认识和开启。什么是WordPress的调试模式
最近不少用户反馈说WordPress后台的外观-自定义点开后直接报错,错误信息如下: