我想为我的WordPress博客创建一个自定义页面,将在其中执行我的PHP代码,同时保留整体网站CSS/主题/设计的一部分。

PHP代码将使用第三方api(因此我需要包括其他PHP文件)。

我该怎么做呢?

注:我没有特定的需要与WordPress API交互-除了包括某些其他PHP库,我需要我没有其他依赖的PHP代码,我想包括在WordPress页面。所以很明显,任何不需要学习WordPress API的解决方案都是最好的。


当前回答

我知道这是个老问题,但没人这么说过: 您还可以在theme目录中创建一个名为page-my-custom-page.php的文件,并使用my-custom-page slug发布一个页面。 也可以使用wp函数来显示页面细节(如the_content()来显示页面内容)。

现在您可以使用example.com/my-custom-page访问该页面。

我不确定这是否是一种合适的方式,但在WP 5.7.3中进行了测试和工作

其他回答

如果你像我一样,有时你希望能够在CMS中不存在的页面中引用WordPress函数。这样,它仍然是后端特定的,不会被客户端意外删除。

这实际上很简单,只需使用PHP require()包含wp-blog-header.php文件即可。

下面是一个使用查询字符串为任何帖子生成Facebook Open Graph (OG)数据的示例。

以http://example.com/yourfilename.php?1这样的链接为例,其中1是我们想为其生成OG数据的帖子的ID:

现在在yourfilename.php的内容中,为了方便起见,它位于WordPress根目录中:

<?php
    require( dirname( __FILE__ ) . '/wp-blog-header.php' );

    $uri = $_SERVER['REQUEST_URI'];
    $pieces = explode("?", $uri);
    $post_id = intval( $pieces[1] );

    // og:title
    $title = get_the_title($post_id);

    // og:description
    $post = get_post($post_id);
    $descr = $post->post_excerpt;

    // og:image
    $img_data_array = get_attached_media('image', $post_id);
    $img_src = null;
    $img_count = 0;

    foreach ( $img_data_array as $img_data ) {
        if ( $img_count > 0 ) {
            break;
        } else {
            ++$img_count;
            $img_src = $img_data->guid;
        }
    } // end og:image

?>
<!DOCTYPE HTML>
<html>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, user-scalable=yes" />
<meta property="og:title" content="<?php echo $title; ?>" />
<meta property="og:description" content="<?php echo $descr; ?>" />
<meta property="og:locale" content="en_US" />
<meta property="og:type" content="website" />
<meta property="og:url" content="<?php echo site_url().'/your_redirect_path'.$post_id; ?>" />
<meta property="og:image" content="<?php echo $img_src; ?>" />
<meta property="og:site_name" content="Your Title" />
</html>

有了它:为任何使用帖子的实际图像、摘录和标题的帖子生成共享模型!

我们本可以创建一个特殊的模板并编辑永久链接结构来实现这一点,但由于它只需要一个页面,而且我们不希望客户端从CMS中删除它,因此这似乎是一个更干净的选择。


2017年编辑: 请注意,这种方法现在已被弃用

关于2016年以上的WordPress安装,请参阅如何将PHP页面添加到WordPress?用于在将页面数据输出到浏览器之前包含的额外参数。

你会想看看WordPress的插件API。

这篇文章解释了如何“挂钩”和“过滤”到WordPress机制的不同部分,所以你可以在任何给定的时间在任何地方执行自定义PHP代码。这种挂钩、过滤和自定义代码创作都可以在任何主题的functions.php文件中进行。快乐编码:)

WordPress插件API WordPress挂钩/过滤数据库 WordPress PHPXHref by Yoast

除了创建一个自定义模板文件并将该模板分配给一个页面(就像在已接受答案的例子中),还有一种方法是使用模板命名约定,WordPress用于加载模板(模板层次结构)。

创建一个新页面,并使用该页的slug作为模板文件名(创建一个名为page-{slug}.php的模板文件)。WordPress将自动加载符合此规则的模板。

任何答案都不包括如果你需要在WordPress主题之外添加一个PHP页面。就是这条路。

您需要包含wp-load.php。

<?php require_once('wp-load.php'); ?>

然后你就可以使用该页面上的任何WordPress功能了。

你不需要与API交互或使用插件。

首先,在主题文件夹(在/wp-content/themes/themename/下)中复制post.php或page.php。

将新文件重命名为templatename.php(其中templatename是对新模板的称呼)。要将新模板添加到可用模板列表中,请在新文件的顶部输入以下内容:

<?php
/*
Template Name: Name of Template
*/
?>

您可以修改这个文件(使用PHP)以包含其他文件或任何您需要的文件。

然后在WordPress博客中创建一个新页面,在页面编辑屏幕中,您将在右边的Attributes小部件中看到一个Template下拉菜单。选择新模板并发布页面。

新页面将使用templatename.php中定义的PHP代码

来源:创建供全局使用的自定义页面模板