2

我应该首先说我从来没有 php 经验,但我知道这个脚本不可能那么雄心勃勃。

我正在使用 Wordpress 的 metaWeblog API 来批量创建数百个帖子。每个帖子都需要一个独立的标题、描述和两个图像的 url,后者是自定义字段。

我通过手动将数据输入到以下文件中成功地制作了一篇文章;

<?php    // metaWeblog.Post.php
$BLOGURL = "http://path/to/your/wordpress";
$USERNAME = "username";
$PASSWORD = "password";

function get_response($URL, $context) {
if(!function_exists('curl_init')) {
die ("Curl PHP package not installed\n");
}

/*Initializing CURL*/
$curlHandle = curl_init();

/*The URL to be downloaded is set*/
curl_setopt($curlHandle, CURLOPT_URL, $URL);
curl_setopt($curlHandle, CURLOPT_HEADER, false);
curl_setopt($curlHandle, CURLOPT_HTTPHEADER, array("Content-Type: text/xml"));
curl_setopt($curlHandle, CURLOPT_POSTFIELDS, $context);

/*Now execute the CURL, download the URL specified*/
$response = curl_exec($curlHandle);
return $response;
}

function createPost(){
/*The contents of your post*/
$description = "post description";

/*Forming the content of blog post*/
$content['title'] = $postTitle;
$content['description'] = $description;
/*Pass custom fields*/
   $content['custom_fields'] = array(
array( 'key' => 'port_thumb_image_url', 'value' => "$imagePath" ),
array( 'key' => 'port_large_image_url', 'value' => "$imagePath" )
);
/*Whether the post has to be published*/
$toPublish = false;//false means post will be draft
$request = xmlrpc_encode_request("metaWeblog.newPost",
array(1,$USERNAME, $PASSWORD, $content, $toPublish));

/*Making the request to wordpress XMLRPC of your blog*/
$xmlresponse = get_response($BLOGURL."/xmlrpc.php", $request);
$postID = xmlrpc_decode($xmlresponse);
echo $postID;
}
?>

为了保持简短,这里是脚本的最基本示例,它遍历目录并“假定”传递变量 $postTitle 和 $imagePath 并创建帖子。

<?php     // fileLoop.php
require('path/to/metaWeblog.Post.php');

$folder = 'foldername';
$urlBase = "images/portfolio/$folder";//truncate path to images

if ($handle = opendir("path/to/local/images/portfolio/$folder/")) {

/*Loop through files in truncated directory*/
while (false !== ($file = readdir($handle))) {
    $info = pathinfo($file);
    $file_name =  basename($file,'.'.$info['extension']);   // strip file extension

    $postTitle = preg_replace("/\.0|\./", " ", $file_name); // Make file name suitable for post title !LEAVE!
        echo "<tr><td>$postTitle</td>";

    $imagePath = "$urlBase/$file";
        echo " <td>$urlBase/$file</td>";

    createPost($postTitle, $imagePath);

    }

closedir($handle);
}

?>

它应该像这样工作,

  1. fileLoop.php 打开目录并遍历每个文件
  2. 对于目录中的每个文件,都会创建一个合适的帖子标题(postTitle),并创建一个指向服务器文件的 url 路径(imagePath)
  3. 每个 postTitle 和 imagePath 都被传递给 metaWeblog.php 中的 createPost 函数
  4. metaWeblog.php 创建帖子并传回帖子 ID 以完成为目录中的每个文件创建表行。

我试过在 fileLoop.php 中声明函数,我试过完全组合文件。它要么创建包含所有文件的表,要么不以这种方式遍历目录。我错过了一些东西,我知道。我不知道如何在此处合并 $POST_,或者使用会话,因为我说我对 php 编程非常陌生。

4

1 回答 1

0

您需要更新createPost()函数的声明,以便它考虑到您尝试发送的参数。

所以它应该是这样的:

function createPost($postTitle, $imagePath){
    /*The contents of your post*/
    $description = "post description";

    ...

}

有关 PHP 函数参数的更多信息可以在相关的手册页上找到。

解决此问题后,您可以使用 CURL 调试来获取有关外部请求的更多信息。要获取有关 CURL 请求的更多信息,请尝试设置以下选项:

/*Initializing CURL*/
$curlHandle = curl_init();

/*The URL to be downloaded is set*/
curl_setopt($curlHandle, CURLOPT_URL, $URL);
curl_setopt($curlHandle, CURLOPT_HEADER, false);
curl_setopt($curlHandle, CURLOPT_HTTPHEADER, array("Content-Type: text/xml"));
curl_setopt($curlHandle, CURLOPT_POSTFIELDS, $context);


curl_setopt($curlHandle, CURLOPT_HEADER, true); // Display headers
curl_setopt($curlHandle, CURLOPT_VERBOSE, true); // Display communication with server

/*Now execute the CURL, download the URL specified*/
$response = curl_exec($curlHandle);

print "<pre>\n";
print_r(curl_getinfo($ch));  // get error info
echo "\n\ncURL error number:" .curl_errno($ch); // print error info
echo "\n\ncURL error:" . curl_error($ch); 
print "</pre>\n";

上面的调试示例代码来自eBay 的帮助页面

它应该显示 Wordpress 是否拒绝请求。

于 2011-11-25T18:02:01.333 回答