国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
php文件上傳后端處理小技巧,
首頁(yè) 後端開(kāi)發(fā) php教程 php文件上傳后端處理小技巧,_PHP教程

php文件上傳后端處理小技巧,_PHP教程

Jul 12, 2016 am 08:50 AM
php 文件上傳

php文件上傳后端處理小技巧,

本文就來(lái)說(shuō)說(shuō),php文件上傳后端處理都有些什么技巧吧!

業(yè)務(wù)場(chǎng)景一、我們只會(huì)選擇一個(gè)單個(gè)的文件上傳,而且不需要做一些即時(shí)的驗(yàn)證工作。那么,也許并沒(méi)有什么優(yōu)化可言了,因?yàn)?,最后你要做的,只是將這個(gè)文件放在表單里最后一起提交,直接處理即可!

業(yè)務(wù)場(chǎng)景二、需要上傳多個(gè)文件,而且需要時(shí)時(shí)驗(yàn)證文件內(nèi)部?jī)?nèi)容,并時(shí)行相應(yīng)頁(yè)面顯示。對(duì)于這種況,在用戶(hù)選擇了上傳文件之后,我們需要立即將文件上傳,因?yàn)槲覀冃枰x取文件里的信息,在最后提交的時(shí)候,我們也需要提交一次文件。很明顯,在這里是存在一個(gè)重復(fù)上傳的工作的,一個(gè)耗費(fèi)用戶(hù)時(shí)間,二個(gè)是耗費(fèi)服務(wù)器帶寬資源!優(yōu)化,能夠想得到的方法也很簡(jiǎn)單,能不能在第一次上傳完文件之后,就將文件保留在服務(wù)器,真正提交表單的時(shí)候,去讀取這個(gè)已經(jīng)被上傳的臨時(shí)文件即可。是的,這就是我們的處理思路!

業(yè)務(wù)場(chǎng)景三、與場(chǎng)景二類(lèi)似,需要上傳多個(gè)文件,但是多個(gè)文件可能是分開(kāi)上傳的。即我們可能第一次上傳了10M,第二次上傳了10M,總共上傳了10次,那么,在服務(wù)器端來(lái)說(shuō)的話(huà),一次性提交肯定是超出了上傳大小的限制了,但是如果,我們是分每一次的上傳,這是可以的,而最后提交的時(shí)候,我們只需要將簡(jiǎn)短的文本信息傳上去即可!

  思路的確是簡(jiǎn)單的,看起來(lái),也是沒(méi)什么問(wèn)題,但是,也許我是能力有限,當(dāng)時(shí)著實(shí)花了我不少時(shí)間去處理這個(gè)什么鬼!下面,我將給出一些示例代碼,以供參考:

文件上傳技巧(將單次上傳的文件作為臨時(shí)文件存在在服務(wù)器端)示例代碼:

1. 頁(yè)面js處理

    //點(diǎn)擊選擇完成文件后,觸發(fā)上傳文件操作,將文件上傳至服務(wù)器臨時(shí)目錄
    $('.upload-real-file').off().on('change', function(){
      if(!$(this).val()){
        return false;
      }
      var responseObjId = $(this).attr('response-id');
      var responseObj = $('#' + responseObjId);
      $('#Form').ajaxSubmit({
        url:'/aa/bb/uploadTmpApkTool',
        resetForm: false,
        dataType: 'json',
        beforeSubmit: function(option){
          window.loading = layer.load(2);
        },
        success: function(data, statusText){
          layer.close(window.loading);
          if(data.status == 1){
            responseObj.html(data.apkInfoHtml);
            var parentContainer = responseObj.parent().parent(),
              nameContainer = parentContainer.find('.file-name-container');
            nameContainer.html(data.apkName);
            nameContainer.attr('title', data.apkName);
            responseObj.find('.file-tmp').html(data.fileInfo); //將文件信息存放于隱藏域中,以便在提交時(shí)能找到  
            $(submitId).removeAttr('disabled');
          }else{
            layer.alert(data.info);
          }
        },
        error: function(data){
          layer.close(window.loading);
          layer.alert('未知錯(cuò)誤,請(qǐng)稍后再試!');
        }
      });
      return false;//防止dialog 自動(dòng)關(guān)閉
    });

2. 很明顯,頁(yè)面里面需要獲取文件信息,后臺(tái)處理代碼(PHP)

    $apkConfig = $this->_getApkConfig();
    $params = $this->getFilteredParam('get');
    $subFile = $_FILES['apkToolFiles'];
    $apkName = $apkInfoHtml = "";
    if(empty($subFile))
    {
      $this->ajaxReturn(array('status' => -4, 'info' => '請(qǐng)選擇要上傳的文件'));
    }

    foreach ($subFile['name'] as $subKey => $subVal)
    {
      if ($subFile['name'][$subKey])
      {
        $fileData = $this->_getFileData($subFile, $subKey);
        $checkData = array(
          'maxSize' => $apkConfig['FILE_MAX_SIZE'],
          'savePath' => $apkConfig['TMP_CHILD_PATH'],
          'extArr' => array('apk'),
          'releaseName' => str_replace('.apk', '', $fileData['fileName']), //特有
        );
        $checkResult = $this->_checkFileData($fileData, $checkData);
        if ($checkResult['status'] != 1)
        {
          $this->ajaxReturn($checkResult);
        }
        //移動(dòng)文件
        $filePath = $checkData['savePath'] . '/' . $fileData['fileName'] . '.tmp' . genRandStr(6);;
        $this->_moveUploadedFile($fileData['tmpName'], $filePath);
        $apkInfo = $this->_apkParser($filePath); //解析
        if($apkInfo['UMENG_CHANNEL'] != 'UMENG_CHANNEL_VALUE')
        {
          @unlink($filePath);               //刪除無(wú)效文件
          $this->ajaxReturn(array('status' => 0, 'info' => "UMENG_CHANNEL的值要是 UMENG_CHANNEL_VALUE才行"));
        }
        $tmpFileArr['file_info'] = array(
          'name' => $subFile['name'][$subKey],
          'type' => $subFile['type'][$subKey],
          'tmp_name' => str_replace($apkConfig['TMP_CHILD_PATH'] . '/', '', $filePath),
          'error' => $subFile['error'][$subKey],
          'size' => $subFile['size'][$subKey],
        );       //轉(zhuǎn)存該值,不再重復(fù)上傳文件
      }
      else
      {
        $this->ajaxReturn(array('status' => 0, 'info' => "文件不能為空"));
      }
      foreach ($apkInfo as $key => $val)
      {
        $apkInfoHtml .= "{$key}:{$val} \r\n";
      }
      $apkName = $fileData['fileName'];
      $version = $apkInfo['versionName'];
    }
    $fileInfo = htmlspecialchars(json_encode($tmpFileArr['file_info']));
    $fileInfoHtml = "<input name=\"apkToolFileTmp[]\" value='{$fileInfo}' type=\"hidden\"/>";  //一定要輸出前使用htmlspecialchars, 否則不能正確顯示頁(yè)面值和獲取至正確的文件信息

    $this->ajaxReturn(array('status' => 1, 'info' => "上傳成功", 'version' => $version, 'item' => $item, 'apkName' => $apkName, 'apkInfoHtml' => $apkInfoHtml, 'fileInfo' => $fileInfoHtml));
  }

3. 通過(guò)以?xún)刹糠执a的配合,我們?cè)陧?yè)面上已經(jīng)有正確的信息了,只需要在最后提交表單的時(shí)候,不要將文件提交到服務(wù)器,在服務(wù)器端處理時(shí),只需將之前上傳的臨時(shí)文件移動(dòng)一下位置即可,這樣就算大功告成了!

$('.upload-file-real').attr('disabled', 'disabled');??????? //提交表單前,禁用上傳文件

4. 后續(xù)工作

將臨時(shí)文件上傳到服務(wù)器后,是沒(méi)辦法判斷用戶(hù)是否取消當(dāng)前操作的,如果取消了,則臨時(shí)文件將一直存在于服務(wù)器,所以,我們需要一個(gè)定時(shí)清理臨時(shí)目錄的腳本。當(dāng)然,這個(gè)很簡(jiǎn)單,就只需要找到這個(gè)目錄,比較一下時(shí)間,比如超過(guò)一天前的文件就給刪除。注意控制清理頻率即可!

5. 題外話(huà)

日志真的很重要,哪里出錯(cuò)了,哪里刪除文件了,哪里清理數(shù)據(jù)庫(kù)了,一定要做好記錄!  

上傳文件到服務(wù)器臨時(shí)目錄,后端處理原理看起來(lái)很簡(jiǎn)單,但是也需要你仔細(xì)調(diào)試,至少當(dāng)初我在做這個(gè)小功能時(shí),著實(shí)費(fèi)了不少勁才縷清楚的!

以上就是本文的全部?jī)?nèi)容,希望大家可以掌握php文件上傳后端處理的技巧,謝謝大家的閱讀。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1133112.htmlTechArticlephp文件上傳后端處理小技巧, 本文就來(lái)說(shuō)說(shuō),php文件上傳后端處理都有些什么技巧吧! 業(yè)務(wù)場(chǎng)景一 、我們只會(huì)選擇一個(gè)單個(gè)的文件上傳,...
本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線(xiàn)上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門(mén)話(huà)題

如何在PHP中牢固地處理文件上傳? 如何在PHP中牢固地處理文件上傳? Jul 08, 2025 am 02:37 AM

要安全處理PHP文件上傳需驗(yàn)證來(lái)源與類(lèi)型、控製文件名與路徑、設(shè)置服務(wù)器限制並二次處理媒體文件。 1.驗(yàn)證上傳來(lái)源通過(guò)token防止CSRF並通過(guò)finfo_file檢測(cè)真實(shí)MIME類(lèi)型使用白名單控制;2.重命名文件為隨機(jī)字符串並根據(jù)檢測(cè)類(lèi)型決定擴(kuò)展名存儲(chǔ)至非Web目錄;3.PHP配置限制上傳大小及臨時(shí)目錄Nginx/Apache禁止訪(fǎng)問(wèn)上傳目錄;4.GD庫(kù)重新保存圖片清除潛在惡意數(shù)據(jù)。

您如何按值與PHP中的參考傳遞變量? 您如何按值與PHP中的參考傳遞變量? Jul 08, 2025 am 02:42 AM

InPHP,variablesarepassedbyvaluebydefault,meaningfunctionsorassignmentsreceiveacopyofthedata,whilepassingbyreferenceallowsmodificationstoaffecttheoriginalvariable.1.Whenpassingbyvalue,changestothecopydonotimpacttheoriginal,asshownwhenassigning$b=$aorp

PHP標(biāo)頭位置AJAX調(diào)用不起作用 PHP標(biāo)頭位置AJAX調(diào)用不起作用 Jul 10, 2025 pm 01:46 PM

AJAX請(qǐng)求中header('Location:...')無(wú)效的原因是瀏覽器不會(huì)自動(dòng)執(zhí)行頁(yè)面跳轉(zhuǎn)。因?yàn)樵贏JAX請(qǐng)求中,服務(wù)器返回的302狀態(tài)碼和Location頭信息會(huì)被作為響應(yīng)數(shù)據(jù)處理,而不是觸發(fā)跳轉(zhuǎn)行為。解決方法有:1.在PHP中返回JSON數(shù)據(jù)包含跳轉(zhuǎn)URL;2.在前端AJAX回調(diào)中檢查redirect字段並用window.location.href手動(dòng)跳轉(zhuǎn);3.確保PHP輸出僅為JSON避免解析失敗;4.處理跨域問(wèn)題需設(shè)置合適的CORS頭;5.防止緩存干擾可加時(shí)間戳或設(shè)置cache:f

發(fā)電機(jī)如何在PHP中工作? 發(fā)電機(jī)如何在PHP中工作? Jul 11, 2025 am 03:12 AM

AgeneratorinPHPisamemory-efficientwaytoiterateoverlargedatasetsbyyieldingvaluesoneatatimeinsteadofreturningthemallatonce.1.Generatorsusetheyieldkeywordtoproducevaluesondemand,reducingmemoryusage.2.Theyareusefulforhandlingbigloops,readinglargefiles,or

PHP找到了最後一次發(fā)生的位置 PHP找到了最後一次發(fā)生的位置 Jul 09, 2025 am 02:49 AM

在PHP中查找子字符串最後一次出現(xiàn)的位置,最直接的方法是使用strrpos()函數(shù)。 1.使用strrpos()函數(shù)可直接獲取子字符串在主字符串中最後一次出現(xiàn)的起始位置索引,若未找到則返回false,語(yǔ)法為strrpos($haystack,$needle,$offset=0)。 2.若需忽略大小寫(xiě),可使用strripos()函數(shù)實(shí)現(xiàn)不區(qū)分大小寫(xiě)的查找。 3.對(duì)於中文等多字節(jié)字符,應(yīng)使用mbstring擴(kuò)展中的mb_strrpos()函數(shù)以確保返回字符位置而非字節(jié)位置。 4.注意strrpos()返回f

如何防止PHP中的會(huì)話(huà)劫持? 如何防止PHP中的會(huì)話(huà)劫持? Jul 11, 2025 am 03:15 AM

要防止PHP中的會(huì)話(huà)劫持,需採(cǎi)取以下措施:1.使用HTTPS加密傳輸並在php.ini中設(shè)置session.cookie_secure=1;2.設(shè)置安全Cookie屬性,包括httponly、secure和samesite;3.在用戶(hù)登錄或權(quán)限變更時(shí)調(diào)用session_regenerate_id(true)更換SessionID;4.限制Session生命週期,合理配置gc_maxlifetime並記錄用戶(hù)活動(dòng)時(shí)間;5.禁止將SessionID暴露在URL中,設(shè)置session.use_only

php獲得字符串的第一個(gè)N字符 php獲得字符串的第一個(gè)N字符 Jul 11, 2025 am 03:17 AM

在PHP中取字符串前N個(gè)字符可用substr()或mb_substr(),具體步驟如下:1.使用substr($string,0,N)截取前N個(gè)字符,適用於ASCII字符且簡(jiǎn)單高效;2.處理多字節(jié)字符(如中文)時(shí)應(yīng)使用mb_substr($string,0,N,'UTF-8'),並確保啟用mbstring擴(kuò)展;3.若字符串含HTML或空白字符,應(yīng)先用strip_tags()去除標(biāo)籤、trim()清理空格,再截取以保證結(jié)果乾淨(jìng)。

如何用urlencode在PHP中編碼字符串 如何用urlencode在PHP中編碼字符串 Jul 11, 2025 am 03:22 AM

urlencode()函數(shù)用於將字符串編碼為URL安全格式,其中非字母數(shù)字字符(除-、_和.外)會(huì)被替換為百分號(hào)後跟兩位十六進(jìn)制數(shù)的形式。例如,空格轉(zhuǎn)為 號(hào),感嘆號(hào)轉(zhuǎn)為!,而中文字符則轉(zhuǎn)換為其UTF-8編碼形式。使用時(shí)應(yīng)僅對(duì)參數(shù)值進(jìn)行編碼,而非整個(gè)URL,以避免破壞URL結(jié)構(gòu)。對(duì)於URL的其他部分如路徑段,應(yīng)使用rawurlencode()函數(shù),其將空格轉(zhuǎn)為 。處理數(shù)組參數(shù)時(shí)可使用http_build_query()自動(dòng)編碼,或手動(dòng)對(duì)每個(gè)值調(diào)用urlencode()以確保安全傳輸數(shù)據(jù)。正

See all articles