0

我有这个页面,您可以在其中向多个人发送消息并将文件附加到其中...

这是我的代码

<?php
    session_start();
    $inboxfrom = $_SESSION['loginusername'];
    $inboxto = $_POST['inboxto'];
    $inboxsubject = $_POST['inboxsubject'];
    $inboxcontent = $_POST['inboxcontent'];
    $inboxtime = date('g:i A', time()+(6*60*60));
    $inboxdate = date('Y-m-d', time()+(6*60*60));
    mysql_connect("127.0.0.1", "root", "")or die("Cannot Connect toDb");
    mysql_select_db("Abbot_db");
    $count = 0;
    function generateRandomString($length = 8){    
        $string = ""; 
        $possible = "0123456789bcdfghjkmnpqrstvwxyz"; //character that can be used 
        for($i=0;$i < $length;$i++){ 
            $char = substr($possible, rand(0, strlen($possible)-1), 1); 
            if (!strstr($string, $char)){ 
                $string .= $char; 
            } 
        } 
        return $string; 
    } 
    if (count($inboxto) != 0){
        $count = 0;
        while ($count < count($inboxto)){
            $recepient = $_POST['inboxto'][$count];

            mysql_query("INSERT INTO Inbox_tbl(InboxTo, InboxFrom, InboxSubject, InboxContent, InboxTime, InboxDate,InboxStatus,ToDelete,FromDelete)VALUES ('$recepient','$inboxfrom','$inboxsubject','$inboxcontent','$inboxtime','$inboxdate','Unread','No','No')");
            $recepient_result = mysql_query("SELECT * FROM Accounts_tbl WHERE UserID='$recepient'");
            if (mysql_result($recepient_result, 0, "UserTypeID") == 1){
                $notiurl = "LMSadmin_inbox.php";
            } else if (mysql_result($recepient_result, 0, "UserTypeID") == 2) {
                $notiurl = "LMSteacher_inbox.php";
            } else {
                $notiurl = "LMSstud_inbox.php";
            }
            mysql_query("INSERT INTO Noti_tbl(NotiTo,NotiFrom,NotiContent,NotiDate,NotiTime,NotiType,NotiUrl)
                VALUES('$recepient','$inboxfrom','has sent you a message','$inboxdate','$inboxtime','Message','$notiurl')");



//---------------------------------------------------------         
            $countto = 0;
            $cont = generateRandomString(128);
            $folder = "./Attachments/".$cont;
            $name = $_FILES['file']['name'];
            if (!empty($name)){
                    while (is_dir($folder)){
                        $cont = generateRandomString(128);
                        $folder = "./Attachments/".$cont;
                    }   
                    mkdir($folder, 0700, true);

            }
            while ($countto < count($_FILES['file']['name'])){
                $name = $_FILES['file']['name'][$countto];
                $type = $_FILES['file']['type'][$countto];
                $tmp_name = $_FILES['file']['tmp_name'][$countto];
                $folder = "Attachments/".$cont."/";
                move_uploaded_file($tmp_name, $folder.$name);
                $fileurl = $cont."/".$name;
                $dummypost = mysql_query("SELECT * FROM Inbox_tbl ORDER BY InboxID DESC");
                $msgid = mysql_result($dummypost, 0, "InboxID");

                mysql_query("INSERT INTO Attachments_tbl(FileUrl,FileName,AttachType,AttachID)
                    VALUES('$fileurl','$name','Message',$msgid)");
                $countto++;
            }
//----------------------------------------------            


            $count++;   
        }
    }
    header('Location: ' . $_SERVER['HTTP_REFERER']);
?>

现在我放置多个接收者和倍数后的结果是......第一个接收者将获得附件......这意味着附件文件夹将随机生成,文件将放在那里......但在下一个接收者附件不会在各自的文件夹中移动。我可以看到文件夹已创建,但文件没有移动。

我的问题是.. 使用“move_uploaded_file”代码后“temp_name”会消失吗?因为我认为这就是文件没有移动的原因。你能建议我可以使用的任何替代代码吗?

4

2 回答 2

0

是的,文件被移动了,这就是你找不到它的原因。我建议你:

  1. 将内部 while 循环(用于上传文件的循环)移动到第一个 while 循环(用于收件人)之前,并将上传的文件移动到您指定的位置
  2. 创建一个新的内部 while 循环,将文件从您之前指定的位置复制到每个用户的附件文件夹
于 2012-08-08T11:15:38.117 回答
0

move_uploaded_file()将文件重新定位到设置的目标位置,tmp_name然后渲染无用。

您应该做的是在最初移动上传文件的位置创建一个“puffer”文件夹,然后copy()根据需要多次调用以将文件传递到收件人文件夹。当文件被放置到每个需要的位置时,您可以unlink()从这个 puffer 文件夹中获取文件。

或者,您可以将文件仅放在一个位置(以消除冗余和过度使用存储空间),并在您Attachments_tbl的设置文件夹中创建指向同一文件的链接attachments。但是,这需要对系统的工作方式进行改造,以确保(现在是唯一的)附件文件仅在指向它的每条记录也被删除后才被删除。

于 2012-08-08T11:22:55.283 回答