我想用一个Php脚本在WPMU中创建一个新博客。我在调用wpmu_create_user和wpmu_create_blog等wordpress函数时遇到问题。
我希望从命令行将此脚本作为cron作业运行,从外部数据库中获取新的博客创建请求,使用wordpress函数创建新博客,并使用新的博客信息更新数据库。
答案 0 :(得分:41)
在php脚本文件中包含wp-load.php文件(在wordpress安装的根目录中),如下所示,
require_once("/path/to/wordpress/wp-load.php");
你必须提供wp-load文件的abspath, 现在你可以在php脚本中使用wordpress的所有功能
了答案 1 :(得分:28)
我已经获得了通用的解决方案可以在wp-content
文件夹内的任何php文件中工作,无需任何调整或需要知道什么是神秘的{ {1}}
'path/to/wordpress'
它会自动上升到wordpress的根目录并加载wp-load.php
无论是插件还是主题文件,您都可以将它粘贴到任何地方。
我认为像require_once( explode( "wp-content" , __FILE__ )[0] . "wp-load.php" );
这样的东西看起来非常糟糕,当你修改主题/插件文件夹的结构时,你会发疯的。
注意 :此解决方案假设您没有重命名您的../../../..
文件夹。
答案 2 :(得分:15)
对于wordpress 3.1,我必须指定主机/域,因为wp-includes / ms-settings.php:100需要它或它死掉。所以我的脚本看起来像(注意我将它用于网络/多博客网站):
#!/usr/bin/php -q
<?php
#for multi-blog only
$blog_id = 1;
#specify host or domain (needed for wp-includes/ms-settings.php:100)
$_SERVER[ 'HTTP_HOST' ] = 'localhost';
#location of wp-load.php so we have access to database and $wpdb object
$wp_load_loc = "/path/to/wordpress/wp-load.php";
require_once($wp_load_loc);
#for multi-blog only
switch_to_blog($blog_id);
#test to make sure we can access database
echo $wpdb->prefix;
?>
答案 3 :(得分:4)
这应该有效:
require_once($_SERVER['DOCUMENT_ROOT'].'/wp-load.php');
即。当php脚本在同一台服务器上并且WP安装在根目录上时。大多数情况都是如此。
答案 4 :(得分:2)
require_once('../../../wp-load.php');
我认为您必须在自定义文件中使用wordpress功能之前添加此行。并确保我已按照我的wordpress安装结构添加../3次。这取决于您的结构检查手动。 恩。如果您的自定义文件位于您的主题/ yourtheme / custom.php中,则上述代码将完美运行,如果没有,则根据您的路径添加../或删除一个或多个../。
答案 5 :(得分:1)
以下是我正在使用的代码:
<?PHP
require_once ('/path/to/wordpress/wp-load.php');
require_once ('/path/to/wordpress/wp-blog-header.php');
require_once ('/path/to/wordpress/wp-includes/registration.php');
do_action('wpmuadminedit', '');
//Code to Connect and Select the external database
//Code to Connect to the external DB and get the new order details:
NewBlogName=$name and AdminEmail=$email
if ( !email_exists($email) )
{
// email does exist, create a new user
$name = create_name_from_email($email);
$password = "use a default password";
$user_id=wpmu_create_user($name, $password, $email);
create_blog($email, $title, $user_id, $password);
}
else
{
// user exists, create new blog
$user_id=email_exists($email);
$password = "use existing wordpress password";
create_blog($email, $title, $user_id, $password);
}
function create_name_from_email ($email) {
preg_match('/[^@]+)@/',$email,$matches);
$name = $matches[1];
return $name;
}
//Creates a new blog, expects user to already exist.
function create_blog($email, $title, $user_id, $password)
{
//Code to Update external DB that the order is in process
$public = array("public" => 1);
if (constant('VHOST') == 'yes')
{
$newdomain = $domain . "." . $current_site->domain;
$path = $base;
}
else
{
$newdomain = $current_site->domain; $path = $base . $domain . '/';
}
$domain = strtolower($domain);
$newdomain = strtolower($newdomain);
$path = strtolower($path);
$meta = apply_filters('signup_create_blog_meta', array('lang_id' => 1, $public));
$meta = apply_filters("add_singup_meta", $meta);
wpmu_create_blog($newdomain, $path, $title, $user_id , $meta, $current_site->id);
do_action('wpmu_activate_blog', $blog_id, $user_id, $password, $title, $meta);
// Update external DB with BlogUrl, NewBlogName, AdminPassword,
OrderStatus=Complete.
mysql_close($con);
?>
答案 6 :(得分:0)
wordpress使用phpass函数 -
这对我有用,因为我有一个密码和表中的哈希值(迁移的wp用户),并且必须找到检查登录详细信息的方法 -
在此处抓取此下载内容 - https://github.com/sunnysingh/phpass-starter
所有你需要的是检查WordPress哈希文本密码的基本功能:
<?php
require_once( "PasswordHash.php" );
$hasher = new PasswordHash(8, false);
// Check that the password is correct
$check = $hasher->CheckPassword($password, $stored_hash);
if ($check) {
// password good
} else {
// password wrong
}
?>
所有积分给Sunny Singh!