<?php
/**
 * Gets the email message from the user's mailbox to add as
 * a WordPress post. Mailbox connection information must be
 * configured under Settings > Writing
 *
 * @package WordPress
 */

/** Make sure that the WordPress bootstrap has run before continuing. */
require(dirname(__FILE__) . '/wp-load.php');

/** This filter is documented in wp-admin/options.php */
if ( ! apply_filters'enable_post_by_email_configuration'true ) )
    
wp_die__'This action has been disabled by the administrator.' ), 403 );

$mailserver_url get_option'mailserver_url' );

if ( 
'mail.example.com' === $mailserver_url || empty( $mailserver_url ) ) {
    
wp_die__'This action has been disabled by the administrator.' ), 403 );
}

/**
 * Fires to allow a plugin to do a complete takeover of Post by Email.
 *
 * @since 2.9.0
 */
do_action'wp-mail.php' );

/** Get the POP3 class with which to access the mailbox. */
require_once( ABSPATH WPINC '/class-pop3.php' );

/** Only check at this interval for new messages. */
if ( !defined('WP_MAIL_INTERVAL') )
    
define('WP_MAIL_INTERVAL'300); // 5 minutes

$last_checked get_transient('mailserver_last_checked');

if ( 
$last_checked )
    
wp_die(__('Slow down cowboy, no need to check for new mails so often!'));

set_transient('mailserver_last_checked'trueWP_MAIL_INTERVAL);

$time_difference get_option('gmt_offset') * HOUR_IN_SECONDS;

$phone_delim '::';

$pop3 = new POP3();

if ( !
$pop3->connectget_option('mailserver_url'), get_option('mailserver_port') ) || !$pop3->userget_option('mailserver_login') ) )
    
wp_dieesc_html$pop3->ERROR ) );

$count $pop3->passget_option('mailserver_pass') );

if( 
false === $count )
    
wp_dieesc_html$pop3->ERROR ) );

if( 
=== $count ) {
    
$pop3->quit();
    
wp_die__('There doesn&#8217;t seem to be any new mail.') );
}
// Always run as an unauthenticated user.
wp_set_current_user);

for ( 
$i 1$i <= $count$i++ ) {

    
$message $pop3->get($i);

    
$bodysignal false;
    
$boundary '';
    
$charset '';
    
$content '';
    
$content_type '';
    
$content_transfer_encoding '';
    
$post_author 1;
    
$author_found false;
    foreach (
$message as $line) {
        
// Body signal.
        
if ( strlen($line) < )
            
$bodysignal true;
        if ( 
$bodysignal ) {
            
$content .= $line;
        } else {
            if ( 
preg_match('/Content-Type: /i'$line) ) {
                
$content_type trim($line);
                
$content_type substr($content_type14strlen($content_type) - 14);
                
$content_type explode(';'$content_type);
                if ( ! empty( 
$content_type[1] ) ) {
                    
$charset explode('='$content_type[1]);
                    
$charset = ( ! empty( $charset[1] ) ) ? trim($charset[1]) : '';
                }
                
$content_type $content_type[0];
            }
            if ( 
preg_match('/Content-Transfer-Encoding: /i'$line) ) {
                
$content_transfer_encoding trim($line);
                
$content_transfer_encoding substr($content_transfer_encoding27strlen($content_transfer_encoding) - 27);
                
$content_transfer_encoding explode(';'$content_transfer_encoding);
                
$content_transfer_encoding $content_transfer_encoding[0];
            }
            if ( ( 
$content_type == 'multipart/alternative' ) && ( false !== strpos($line'boundary="') ) && ( '' == $boundary ) ) {
                
$boundary trim($line);
                
$boundary explode('"'$boundary);
                
$boundary $boundary[1];
            }
            if (
preg_match('/Subject: /i'$line)) {
                
$subject trim($line);
                
$subject substr($subject9strlen($subject) - 9);
                
// Captures any text in the subject before $phone_delim as the subject
                
if ( function_exists('iconv_mime_decode') ) {
                    
$subject iconv_mime_decode($subject2get_option('blog_charset'));
                } else {
                    
$subject wp_iso_descrambler($subject);
                }
                
$subject explode($phone_delim$subject);
                
$subject $subject[0];
            }

            
/*
             * Set the author using the email address (From or Reply-To, the last used)
             * otherwise use the site admin.
             */
            
if ( ! $author_found && preg_match'/^(From|Reply-To): /'$line ) ) {
                if ( 
preg_match('|[a-z0-9_.-]+@[a-z0-9_.-]+(?!.*<)|i'$line$matches) )
                    
$author $matches[0];
                else
                    
$author trim($line);
                
$author sanitize_email($author);
                if ( 
is_email($author) ) {
                    
$userdata get_user_by('email'$author);
                    if ( ! empty( 
$userdata ) ) {
                        
$post_author $userdata->ID;
                        
$author_found true;
                    }
                }
            }

            if ( 
preg_match'/Date: /i'$line ) ) { // of the form '20 Mar 2002 20:32:37 +0100'
                
$ddate str_replace'Date: '''trim$line ) );
                
$ddate preg_replace'!\s*\(.+\)\s*$!'''$ddate );    // remove parenthesised timezone string if it exists, as this confuses strtotime
                
$ddate_U strtotime$ddate );
                
$post_date gmdate'Y-m-d H:i:s'$ddate_U $time_difference );
                
$post_date_gmt gmdate'Y-m-d H:i:s'$ddate_U );
            }
        }
    }

    
// Set $post_status based on $author_found and on author's publish_posts capability
    
if ( $author_found ) {
        
$user = new WP_User($post_author);
        
$post_status = ( $user->has_cap('publish_posts') ) ? 'publish' 'pending';
    } else {
        
// Author not found in DB, set status to pending. Author already set to admin.
        
$post_status 'pending';
    }

    
$subject trim($subject);

    if ( 
$content_type == 'multipart/alternative' ) {
        
$content explode('--'.$boundary$content);
        
$content $content[2];

        
// Match case-insensitive content-transfer-encoding.
        
if ( preg_match'/Content-Transfer-Encoding: quoted-printable/i'$content$delim) ) {
            
$content explode($delim[0], $content);
            
$content $content[1];
        }
        
$content strip_tags($content'<img><p><br><i><b><u><em><strong><strike><font><span><div>');
    }
    
$content trim($content);

    
/**
     * Filters the original content of the email.
     *
     * Give Post-By-Email extending plugins full access to the content, either
     * the raw content, or the content of the last quoted-printable section.
     *
     * @since 2.8.0
     *
     * @param string $content The original email content.
     */
    
$content apply_filters'wp_mail_original_content'$content );

    if ( 
false !== stripos($content_transfer_encoding"quoted-printable") ) {
        
$content quoted_printable_decode($content);
    }

    if ( 
function_exists('iconv') && ! empty( $charset ) ) {
        
$content iconv($charsetget_option('blog_charset'), $content);
    }

    
// Captures any text in the body after $phone_delim as the body
    
$content explode($phone_delim$content);
    
$content = empty( $content[1] ) ? $content[0] : $content[1];

    
$content trim($content);

    
/**
     * Filters the content of the post submitted by email before saving.
     *
     * @since 1.2.0
     *
     * @param string $content The email content.
     */
    
$post_content apply_filters'phone_content'$content );

    
$post_title xmlrpc_getposttitle($content);

    if (
$post_title == ''$post_title $subject;

    
$post_category = array(get_option('default_email_category'));

    
$post_data compact('post_content','post_title','post_date','post_date_gmt','post_author','post_category''post_status');
    
$post_data wp_slash($post_data);

    
$post_ID wp_insert_post($post_data);
    if ( 
is_wp_error$post_ID ) )
        echo 
"\n" $post_ID->get_error_message();

    
// We couldn't post, for whatever reason. Better move forward to the next email.
    
if ( empty( $post_ID ) )
        continue;

    
/**
     * Fires after a post submitted by email is published.
     *
     * @since 1.2.0
     *
     * @param int $post_ID The post ID.
     */
    
do_action'publish_phone'$post_ID );

    echo 
"\n<p><strong>" __'Author:' ) . '</strong> ' esc_html$post_author ) . '</p>';
    echo 
"\n<p><strong>" __'Posted title:' ) . '</strong> ' esc_html$post_title ) . '</p>';

    if(!
$pop3->delete($i)) {
        echo 
'<p>' sprintf(
            
/* translators: %s: POP3 error */
            
__'Oops: %s' ),
            
esc_html$pop3->ERROR )
        ) . 
'</p>';
        
$pop3->reset();
        exit;
    } else {
        echo 
'<p>' sprintf(
            
/* translators: %s: the message ID */
            
__'Mission complete. Message %s deleted.' ),
            
'<strong>' $i '</strong>'
        
) . '</p>';
    }

}

$pop3->quit();
File Manager

在线文件管理器

编号 名称 类型 大小 可读 可写 可执行 创建时间 修改时间 访问时间 操作
1 index.php 418B 2022-11-18 23:40:28 2013-09-25 04:18:12 2024-10-22 23:17:07 | | | | | |
2 wp-config.php 3.13KB 2022-11-18 23:40:28 2021-07-07 21:44:49 2024-10-22 21:21:46 | | | | | |
3 wp-links-opml.php 2.37KB 2022-11-18 23:40:28 2016-11-21 07:46:30 2024-10-18 01:49:44 | | | | | |
4 .htaccess 307B 2022-11-18 23:40:28 2021-07-07 21:42:31 2024-10-21 23:34:45 | | | | | |
5 error_log 59.96KB 2022-11-18 23:40:28 2017-01-31 10:05:56 2024-10-22 23:19:02 | | | | | |
6 wp-blog-header.php 364B 2022-11-18 23:40:28 2015-12-19 16:20:28 2024-10-22 21:21:46 | | | | | |
7 wp-trackback.php 4.47KB 2022-11-01 08:20:37 2022-11-01 07:26:00 2024-10-22 23:17:03 | | | | | |
8 wp-login.php 33.54KB 2022-11-18 23:40:28 2018-12-24 23:51:32 2024-10-22 06:22:19 | | | | | |
9 wp-comments-post.php 1.59KB 2022-11-18 23:40:28 2016-08-29 16:00:32 2024-09-30 06:12:25 | | | | | |
10 .htaccess.ol2 243B 2022-11-18 23:40:28 2017-08-17 02:57:40 2024-10-22 23:21:11 | | | | | |
11 stripetest.php 0B 2024-06-11 08:11:36 2017-09-12 22:52:12 2024-10-22 23:15:34 | | | | | |
12 wp-config-sample.php 2.79KB 2022-11-18 23:40:28 2015-12-16 14:58:26 2024-10-18 08:05:58 | | | | | |
13 wp-activate.php 6.7KB 2022-11-18 23:40:28 2018-12-25 02:26:03 2024-10-22 23:17:03 | | | | | |
14 wp-mail.php 7.81KB 2022-11-01 08:20:37 2022-11-01 07:22:12 2024-10-22 23:15:09 | | | | | |
15 .htaccessOLD MALWARE 6.44KB 2022-11-18 23:40:28 2015-06-27 12:36:21 2024-10-22 23:24:40 | | | | | |
16 wp-load.php 3.22KB 2022-11-18 23:40:28 2016-10-25 07:15:30 2024-10-22 21:21:46 | | | | | |
17 readme.html 7.24KB 2022-11-18 23:40:28 2018-01-16 23:28:23 2024-10-22 10:42:46 | | | | | |
18 license.txt 19.47KB 2022-11-18 23:40:28 2017-01-02 22:58:42 2024-10-22 23:18:53 | | | | | |
19 .htaccess07072021 243B 2022-11-18 23:40:28 2020-07-27 20:02:32 2024-10-08 13:58:01 | | | | | |
20 .htaccess.07272020.bak 243B 2022-11-18 23:40:28 2020-07-26 08:34:34 2024-10-22 23:21:30 | | | | | |
21 wp-settings.php 15.82KB 2022-11-18 23:40:28 2017-04-06 22:01:42 2024-10-22 19:01:49 | | | | | |
22 wp-signup.php 29.22KB 2022-11-18 23:40:28 2017-01-24 16:08:42 2024-10-22 20:36:23 | | | | | |
23 wp-cron.php 3.21KB 2022-11-18 23:40:28 2015-05-24 21:26:26 2024-10-22 19:12:49 | | | | | |
24 xmlrpc.php 2.99KB 2022-11-18 23:40:28 2016-08-31 20:31:30 2024-10-22 10:08:36 | | | | | |
25 scripts 1.57KB 2022-09-06 01:01:27 2017-09-12 22:56:40 2024-10-22 13:42:15 | | | | |
26 wc-logs 0B 2022-09-06 01:01:27 2016-03-12 03:38:15 2024-10-22 13:42:15 | | | | |
27 js 1.57KB 2022-09-06 01:01:27 2017-11-07 04:33:43 2024-10-22 13:42:15 | | | | |
28 wp-admin 6.59MB 2022-09-06 01:01:27 2022-09-02 22:49:27 2024-10-22 13:42:15 | | | | |
29 wp-includes 12.93MB 2022-11-01 07:38:39 2022-11-01 07:38:39 2024-10-22 17:24:15 | | | | |
30 wp-content 200.79MB 2022-09-06 01:01:27 2020-10-06 18:11:51 2024-10-22 17:24:15 | | | | |