表单提交仅在Wordpress中打破的PHP代码

时间:2016-03-31 22:29:22

标签: php mysql wordpress forms

我有一个简单的表格,可以将一些数据提交到MySQL DB中。在本地机器上工作得很好,但在Wordpress页面模板内部不再工作,不会给我任何错误。表单位于页面内#sit; sitename.com/upload"并在提交到同一页面后重定向(如链接栏中所示),但有404页面内容。我试过没有get_header();get_footer();标签,因为我认为它可能与wp中的一些变量冲突,但我得到了相同的结果。 这是代码:

 <?php function renderForm($name, $price, $error)
 {
 // if there are any errors, display them
 if ($error != '')
 {
 echo '<div style="padding:4px; border:1px solid red; color:red;">'.$error.'</div>';
 }
 ?> 
***** LONG HTML FORM IS HERE *****
 <?php 
 }


 // connect to the database
 include('connect-db.php');

 // check if the form has been submitted. If it has, start to process the form and save it to the database
 if (isset($_POST['submit']))
 { 
 // get form data, making sure it is valid
 $name = mysqli_real_escape_string($connection, htmlspecialchars($_POST['name']));
 $price = mysqli_real_escape_string($connection, htmlspecialchars($_POST['price']));
 $shortdesc = mysqli_real_escape_string($connection, htmlspecialchars($_POST['shortdesc']));
 $longdesc = mysqli_real_escape_string($connection, htmlspecialchars($_POST['longdesc']));
 $current_version = mysqli_real_escape_string($connection, htmlspecialchars($_POST['current-version']));   
 $content_rating = $_POST['contentrating'];  

 if(isset($_POST['category'])) {
    $category = implode(",", $_POST['category']);   
 } else {
    $category = "";
 }

 if(isset($_POST['platform'])) {
  $platform = implode(",", $_POST['platform']); 
 } else {
  $platform = "";
 }

 if(isset($_POST['devices'])) {
  $devices = implode(",", $_POST['devices']); 
 } else {
  $devices = "";
 }

  if(isset($_POST['gamemodes'])) {
  $gamemodes = implode(",", $_POST['gamemodes']); 
 } else {
  $gamemodes = "";
 }


//FILE UPLOAD
$images = array();
if(isset($_FILES['files'])){
    $errors= array();
  foreach($_FILES['files']['tmp_name'] as $key => $tmp_name ){
    $file_name =$_FILES['files']['name'][$key];
    $file_size =$_FILES['files']['size'][$key];
    $file_tmp =$_FILES['files']['tmp_name'][$key];
    $file_type=$_FILES['files']['type'][$key];  
        if($file_size > 2097152){
      $errors[]='File size must be less than 2 MB';
        } 
        $desired_dir="uploads/images";
        if(empty($errors)==true){
            if(is_dir($desired_dir)==false){
                mkdir("$desired_dir", 0700);    // Create directory if it does not exist
            }
            if(is_dir("$desired_dir/".$file_name)==true){
                move_uploaded_file($file_tmp,"uploads/images/".$file_name);
            }else{                  //rename the file if another one exist
                $file_name = time()."-".$file_name;
                $new_dir="uploads/images/".$file_name;
                 rename($file_tmp,$new_dir) ;       
            }
            $images[] = $file_name;     
        }else{
                print_r($errors);
        }
    }
  if(empty($error)){
    $imglinks = implode(" | ", $images);
  }
}


//FILE UPLOAD END


 // check to make sure both fields are entered
 if ($name == '' || $price == '')
 {
 // generate error message
 $error = 'ERROR: Please fill in all required fields!';

 // if either field is blank, display the form again
 renderForm($name, $price, $error);
 }
 else
 {
 $sql = "INSERT INTO vr_submitted_apps ". "(name, price, shortdesc, longdesc, crtvers, rating, category, platform, devices, gamemodes, images, dtime) ". "VALUES('$name','$price','$shortdesc','$longdesc','$current_version','$content_rating','$category','$platform','$devices','$gamemodes', '$imglinks', NOW())";

 // save the data to the database
mysqli_query( $connection, $sql )
 or die(mysql_error()); 
$itemId = mysqli_insert_id($connection);
setcookie("last-inserted-id", $itemId, time() + (86400 * 3), "/"); // 86400 = 1 day

 // once saved, redirect back to the view page
header("Location: uploader.html"); 
 }
 }
 else
 // if the form hasn't been submitted, display the form
 {
 renderForm('','','');
 }

1 个答案:

答案 0 :(得分:0)

问题解决了: Wordpress为“name”参数保留了一些重要的内部内容。