1

コードイグナイター、prototype.js、swfUploadを使用して大きなビデオファイルを管理している継承されたプロジェクトがあります。大きなビデオファイルのアップロードで窒息するという問題に遭遇しました。

小さいファイル(〜198mbmpgファイルと3mbmovファイル)を正常にアップロードしましたが、1.57GBのmovファイルのアップロードで問題のデバッグに問題があります。

私のローカルマシンでは、アップロードは約1分でアップロードを完了し、正常に返されます。しかし、ファイルが存在するはずのアップロードフォルダー(および小さいファイルが正常にアップロードされたフォルダー)に移動すると、ファイルが見つかりません。

エラーログにエラーはありません。

私の.htaccessファイルで私は設定しています:

php_value upload_max_filesize 6143M  
php_value post_max_size 6143M  

ini_get()を呼び出して、これが機能していることを確認しました

これは私のSWFUploadオブジェクトです:

swfu = new SWFUpload({
   debug: true,
   upload_url: '" . BASE_URL . "/content_management/ajax_asset_upload_files',
   flash_url: '" . BASE_URL . "/js/swfupload/Flash/swfupload.swf',

   post_params: {'PHPSESSID' : '" . $this->session->userdata('session_id') . "'},
   file_size_limit : '10000 MB',
   file_types : '*.*',
   file_types_description : 'All Files',
   file_upload_limit : 100,
   file_queue_limit : 0,
   custom_settings : {
      progressTarget : 'fsUploadProgress'
   },

   // Button settings
   button_image_url: '" . BASE_URL . "/images/buttons/btn_select_file.gif',
   button_width: '105',
   button_window_mode: 'transparent',
   button_height: '20',
   button_placeholder_id: 'spanButtonPlaceHolder',
   button_disabled: true,
   button_cursor: SWFUpload.CURSOR.HAND,
   button_action: SWFUpload.BUTTON_ACTION.SELECT_FILE,

   // The event handler functions are defined in handlers.js
   file_queued_handler : fileQueued,
   file_queue_error_handler : fileQueueError,
   file_dialog_complete_handler : fileDialogComplete,
   upload_start_handler : uploadStart,
   upload_progress_handler : uploadProgress,
   upload_error_handler : uploadError,
   upload_success_handler : assetUploadSuccess,
   upload_complete_handler : uploadComplete,
   queue_complete_handler : queueComplete // Queue plugin event
});

そしてデバッグ出力:

---SWFUpload Instance Info---
Version: 2.2.0 2009-03-25
Movie Name: SWFUpload_0
Settings:
   upload_url:               [function location]
   flash_url:                [js_folder]/swfupload.swf?preventswfcaching=1363621116581
   use_query_string:         false
   requeue_on_error:         false
   http_success:             
   assume_success_timeout:   0
   file_post_name:           Filedata
   post_params:              [object Object]
   file_types:               *.*
   file_types_description:   All Files
   file_size_limit:          10000 MB
   file_upload_limit:        100
   file_queue_limit:         0
   debug:                    true
   prevent_swf_caching:      true
   button_placeholder_id:    spanButtonPlaceHolder
   ...
Event Handlers:
   swfupload_loaded_handler assigned:  false
   file_dialog_start_handler assigned: false
   file_queued_handler assigned:       true
   file_queue_error_handler assigned:  true
   upload_start_handler assigned:      true
   upload_progress_handler assigned:   true
   upload_error_handler assigned:      true
   upload_success_handler assigned:    true
   upload_complete_handler assigned:   true
   debug_handler assigned:             true

SWF DEBUG: SWFUpload Init Complete
SWF DEBUG: 
SWF DEBUG: ----- SWF DEBUG OUTPUT ----
SWF DEBUG: Build Number:           SWFUPLOAD 2.2.0
SWF DEBUG: movieName:              SWFUpload_0
SWF DEBUG: Upload URL:             [function location]
SWF DEBUG: File Types String:      *.*
SWF DEBUG: Parsed File Types:      
SWF DEBUG: HTTP Success:           0
SWF DEBUG: File Types Description: All Files (*.*)
SWF DEBUG: File Size Limit:        10485760000 bytes
SWF DEBUG: File Upload Limit:      100
SWF DEBUG: File Queue Limit:       100
SWF DEBUG: Post Params:
SWF DEBUG:                         PHPSESSID=ki7kne5j6co95il6f6hqt8pje4
SWF DEBUG: ----- END SWF DEBUG OUTPUT ----
SWF DEBUG: 
SWF DEBUG: Event: fileDialogStart : Browsing files. Single Select. Allowed file types: *.*
SWF DEBUG: Select Handler: Received the files selected from the dialog. Processing the file list...
SWF DEBUG: Event: fileQueued : File ID: SWFUpload_0_0
SWF DEBUG: Event: fileDialogComplete : Finished processing selected files. Files selected: 1. Files Queued: 1
EXCEPTION: 
SWF DEBUG: StartUpload: First file in queue
SWF DEBUG: Event: uploadStart : File ID: SWFUpload_0_0
SWF DEBUG: Global Post Item: PHPSESSID=ki7kne5j6co95il6f6hqt8pje4
SWF DEBUG: File Post Item: asset_id=131
SWF DEBUG: File Post Item: document_type_id=4
SWF DEBUG: File Post Item: title_id=-1
SWF DEBUG: File Post Item: title=test3
SWF DEBUG: ReturnUploadStart(): File accepted by startUpload event and readied for upload.  Starting upload to [upload function] for File ID: SWFUpload_0_0
SWF DEBUG: Event: uploadProgress (OPEN): File ID: SWFUpload_0_0
SWF DEBUG: Event: uploadProgress: File ID: SWFUpload_0_0. Bytes: 1409024. Total: 1692228612
SWF DEBUG: Event: uploadProgress: File ID: SWFUpload_0_0. Bytes: 5308416. Total: 1692228612
...
...
SWF DEBUG: Event: uploadProgress: File ID: SWFUpload_0_0. Bytes: 1692228612. Total: 1692228612
SWF DEBUG: Event: uploadSuccess: File ID: SWFUpload_0_0 Response Received: true Data: 
SWF DEBUG: Event: uploadComplete : Upload cycle complete.

前もって感謝します。

4

1 に答える 1

0

ホストが set_time_limit(0) などの php 変数を ini_set して最大実行時間を増やす機能を無効にしている可能性があります。その場合、httpd.conf で Apache の「タイムアウト」を使用します。デフォルトは 60 秒です。また、設定します。 FcgidMaxRequestLen は、要求の最大長 (バイト単位) です。

PHP では、以下も確認してください: memory_limit

デバッグを支援するために、以下も試してください: ini_set('display_errors','On'); error_reporting(E_ALL);

コードからアットマークも削除します。例: @$varname または @functionName() @ は、発生しているすべてのエラーを非表示にするように PHP に指示します。

error_reporting レベルの設定が低すぎるため、実際にはエラーが発生しているのに、エラーが表示されていない可能性があります。上記はそれを修正する必要があります。

于 2013-03-19T17:18:49.023 に答える