尝试使用ajax上传(不起作用)

watbbzwu  于 2021-09-13  发布在  Java
关注(0)|答案(1)|浏览(327)

我试图使用ajax上传一个文件和一些文本,但我的问题是它没有上传到数据库。我试图使用console.log来解决这个问题,但它所做的只是将我重定向到我的网站主页,所以这意味着有一个错误。我做错什么了吗?请帮帮我。
javascript:

<script>
  $(document).ready(function() {
    $("#post-btn").click(function(e) {
      var fd = new FormData();
      var pst = ("#txt").value;
      var files = document.getElementById("fileToUpload").files[0];

      e.preventDefault();
      // Check if file selected or not
    if(('#fileToUpload').length != 0 ){
       fd.append('fileToUpload',files[0]);

       $.ajax({
          url: 'posting.php',
          type: 'post',
          data: {pst: txt, fileToUpload: fd},
          contentType: false,
          processData: false,
          complete: function(r){
             if(r != 0){
                console.log(r.responseText);
             }else{
                alert('file not uploaded');
             }
          },
       });
    }else{
       alert("Select a file!");
    }

    });
  });
</script>

posting.php:

<?php 
$thePst = $_POST['txt'];
if (strpos($thePst, '<script>') !== false) {     echo "<script>history.go(-1)</script>";
  exit();
} else {

session_start();

if (isset($_POST['txt'])) {

?>

<?php

    $sender = $_SESSION['username'];
    $post1 = $_POST['txt'];
    $post = nl2br($post1);
    $submit = $_POST['submit'];
    $host = "localhost";
    $user = "root";
    $pass = "";
    $dbName = "posts";
    $id = $_SESSION['id'];
    $img = $_SESSION['img'];
    $stringLength = strlen($post);

    if (isset($post) && $stringLength <= 550 && strpos($post, '<script>') !== true) {
      $target_dir = "attatch/";
      $target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]);
      $uploadOk = 1;
      $imageFileType = strtolower(pathinfo($target_file,PATHINFO_EXTENSION));

        if (file_exists($target_file)) {
          echo "Sorry, file already exists.";
          $uploadOk = 0;
        }

        if ($_FILES["fileToUpload"]["size"] > 30000) {
          $uploadOk = 0;
        }

        if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"
        && $imageFileType != "gif" && $imageFileType != "tiff" && $imageFileType != "mp4" && $imageFileType != "mov" && $imageFileType != "mkv") {
          echo "Sorry, only JPG, JPEG, PNG, TIFF & GIF files are allowed.";
          $uploadOk = 0;
        }

        if ($uploadOk == 0) {
          echo "Sorry, your file was not uploaded.";
        } else {
          $permitted_chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
          $random = substr(str_shuffle($permitted_chars), 0, 25);
          $newfilename = $sender.".".$random.".".$imageFileType;
          if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], "attatch/" . $newfilename)) {

          } else {
            echo "Sorry, there was an error uploading your file.";
          }
        }

        $today = date("F j, Y, g:i a");

      try {
        $attach = 'attatch/'.$newfilename;
        $conn = new PDO("mysql:host=$host;dbname=$dbName", $user, $pass);
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

        $preparedStatement = $conn->prepare('INSERT INTO posts (sender, post, sender_id, image_attach, sender_img, date) VALUES (:sender, :post, :sender_id, :image_attach, :sender_img, :tod)');

        $preparedStatement->bindParam(':sender', $sender);
        $preparedStatement->bindParam(':post', $post);
        $preparedStatement->bindParam(':sender_id', $id);
        $preparedStatement->bindParam(':image_attach', $attach);
        $preparedStatement->bindParam(':sender_img', $img);
        $preparedStatement->bindParam(':tod', $today);
        $preparedStatement->execute();
    } catch(PDOException $e) {
      echo "Error: " . $e->getMessage();
  } finally {
    $sess = $_SESSION['id'];
    echo "<script>history.go(-1)</script>";
  }
  $conn = null;
} else {
  echo "<script>history.go(-1)</script>";
}
?>

<?php 
}else{
     header("Location: index");
     exit();
}
 ?>
<?php } ?>

谢谢你的帮助。

smtd7mpg

smtd7mpg1#

您需要:
将所需的所有数据包括在 FormData 对象
过关 FormData 反对 data: 不直接将其 Package 到另一个对象中

相关问题