2012-03-20 12 views
0

私はホームページにワードプレスの登録を埋め込もうとしています。私はすでにカスタムレジスタページを作成しましたが、問題はヘッダー情報を呼び出すことであり、PHPインクルードを含めるとこのエラーが発生します。ホームページにワードプレスの登録を埋め込みます。

警告:ヘッダー情報を変更することはできません - ヘッダが既に

を送った私は、登録フォームが完全に埋め込まれるように/ページで動作しますが、私のコードを使用しますが、何とかそれで何とか/仕事、それを変えることができる方法はありますajaxを使用して、しかしそれは動作します。

電流レジスタコード(自身のページで動作しますが、ホームページテンプレートに含まれていない)

<?php 
require_once(ABSPATH . WPINC . '/registration.php'); 
global $wpdb, $user_ID; 
//Check whether the user is already logged in 
if (!$user_ID) { 

     if($_POST){ 
      //We shall SQL escape all inputs 
      $username = $wpdb->escape($_POST['username']); 
      if(empty($username)) { 
       echo "User name should not be empty."; 
       exit(); 
      } 
      $email = $wpdb->escape($_POST['email']); 
      if(!preg_match("/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,4})$/", $email)) { 
       echo "Please enter a valid email."; 
       exit(); 
      }  

       $random_password = wp_generate_password(12, false); 
       $status = wp_create_user($username, $random_password, $email); 
       if (is_wp_error($status)) 
        echo "Username already exists. Please try another one."; 
       else { 
        $from = get_option('admin_email'); 
        $headers = 'From: '.$from . "\r\n"; 
        $subject = "Registration successful"; 
        $msg = "Registration successful.\nYour login details\nUsername: $username\nPassword: $random_password"; 
        wp_mail($email, $subject, $msg, $headers); 

        echo "Please check your email for login details."; 
       } 

      exit(); 

     } else { 
      echo "";   
      ?> 

      <!-- <script src="http://code.jquery.com/jquery-1.4.4.js"></script> --> <!-- Remove the comments if you are not using jQuery already in your theme --> 


      <?php     
      if(get_option('users_can_register')) { //Check whether user registration is enabled by the administrator 
      ?> 

      <h1><?php the_title(); ?></h1> 
      <br /><br /> 
      <div id="result"></div> <!-- To hold validation results --> 
      <form id="wp_signup_form" action="" method="post"> 

      <label><p>Username:</p></label> 
      <input type="text" name="username" class="text" value="" /> 
      <br /><br /> 
      <label><p>Email address:</p></label> 
      <input type="text" name="email" class="text" value="" /> <br /> 
      <br /> 
      <input type="submit" id="submitbtn" class="Buttons" name="submit" value="Register" /> 
      <br /> 
      <br /> 
      </form> 

      <script type="text/javascript">       
      $("#submitbtn").click(function() { 

      $('#result').html('<img src="<?php bloginfo('template_url'); ?>/images/loader.gif" class="loader" />').fadeIn(); 
      var input_data = $('#wp_signup_form').serialize(); 
      $.ajax({ 
      type: "POST", 
      url: "<?php echo "http://" . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']; ?>", 
      data: input_data, 
      success: function(msg){ 
      $('.loader').remove(); 
      $('<div>').html(msg).appendTo('div#result').hide().fadeIn('slow'); 
      } 
      }); 
      return false; 

      }); 
      </script> 

      <?php 
       } 

      else echo "Registration is currently disabled. Please try again later."; 
      ?> 

      </div> 
      </div> 
      <?php 

      echo ""; 
     } //end of if($_post) 

} 
else { 
    wp_redirect(home_url()); exit; 
} 
?> 

答えて

0

を使用しても安全ではありません。私は、これは愚かな質問がある場合はそう言い訳してくださいPHPで華麗ないです登録と郵送のためのカスタムメソッド。

ので、私はそれはあなたが望むものを願っています。このhttp://digwp.com/2010/12/login-register-password-code/

を見てお勧めします。 よろしくお願いいたします。

0

ウェブファンの示唆しているように、ホームページに登録機能を再現することはお勧めできません。登録ページからログインフォームを切り取って貼り付けるだけで、登録ページにactionのフォームが表示されたままにしておくと便利です。

<form method="post" action="<?php echo site_url('wp-login.php?action=register', 'login_post') ?>"> 
    <!-- registration form HTML goes here --> 
</form> 
関連する問題