明確化
この質問は、異なるアップロードライブラリを使用しているという点で同様の質問Plupload
とは異なります(この質問とFineUploader
同様の質問)。
この質問を書いている時点では、問題がどこにあるのかわかりませんでした。そのため、別のライブラリを使用すると問題を解決できると期待していました。
前書き
OneupUploaderBundle
3 週間前に、FineUploaderライブラリを使用して、アップロードに関する同様の質問を作成しました。残念ながら、まだ答えはありません。その間、別のアップロード ライブラリ (Blueimp) をセットアップしてみました。
OneupUploaderBundle
1 週間前に、Blueimp jQuery アップロードライブラリを使用して、アップロードに関する同様の質問を作成しました。残念ながら、まだ答えはありません。その間、別のアップロード ライブラリ (Plupload) をセットアップしてみました。
を含む [1] をWindows 10 Pro
開発中です。XAMPP
PHP v7.0.8
- [1] Windows用XAMPP
ファイルをサーバーにアップロードするために、Symfony v3.1.2、OneupUploaderBundle、およびPluploadライブラリを使用しています。
セットアップ中はOneUpUploaderBundle
[2]のドキュメントに従いPlupload
、ライブラリ [3]、[4] をアップロードしました。
問題
ファイルをいくつかのディレクトリにアップロードしてから、それらのMIME タイプを確認し、アップロードが許可されているファイル MIME タイプであることを確認した後、それらをカスタム ディレクトリ (ファイルからファイルに変更できる) に移動し、最後にファイル パスを保持し、データベースへのファイル名。
ファイルのアップロードは正常に機能し、ファイルは にアップロードされoneup_uploader_endpoint('gallery')
ます。カスタム ファイルでもNamer
機能し、カスタム ディレクトリにアップロードできます。
ただし、リスナーは呼び出されず、Symfony プロファイラーのイベントセクションに表示されますNot Called Listeners
!
ファイルをカスタムディレクトリに移動し、ファイルに関する情報をデータベース unsing Post_Persist
eventに保存したいので、残念です。さらに、検証はイーサとは呼ばれません。
コード
私のservices.yml
services:
app.upload_listener:
class: AppBundle\EventListener\UploadListener
arguments: ["@doctrine.orm.entity_manager"]
tags:
- { name: kernel.event_listener, event: oneup_uploader.post_persist.default_uploader, method: onPostUpload }
- { name: kernel.event_listener, event: oneup_uploader.post_persist.default_uploader, method: onUpload }
app.upload_unique_namer:
class: AppBundle\Uploader\Naming\UploadUniqueNamer
arguments: ["@session"]
私のカスタム Namer
<?php
namespace AppBundle\Uploader\Naming;
use Oneup\UploaderBundle\Uploader\File\FileInterface;
use Oneup\UploaderBundle\Uploader\Naming\NamerInterface;
use Symfony\Component\HttpFoundation\Session\Session;
class UploadUniqueNamer implements NamerInterface
{
private $session;
public function __construct(Session $session)
{
$this->session = $session;
}
/**
* Creates a user directory name for the file being uploaded.
*
* @param FileInterface $file
* @return string The directory name.
*/
public function name(FileInterface $file)
{
$upload_files_path = $this->session->get('upload_files_path');
$unique_name = uniqid();
return sprintf('%s/%s_%s',
$upload_files_path,
$unique_name,
$file->getClientOriginalName()
);
}
}
私のconfig.yml
oneup_uploader:
mappings:
gallery:
frontend: plupload
enable_progress: true
namer: app.upload_unique_namer
use_orphanage: false
allowed_mimetypes: [image/png, image/jpg, image/jpeg, image/gif]
max_size: 200M
私のアップロードリスナー:
<?php
namespace AppBundle\EventListener;
use Oneup\UploaderBundle\Event\PreUploadEvent;
use Oneup\UploaderBundle\Event\PostUploadEvent;
use Oneup\UploaderBundle\Event\PostPersistEvent;
use Doctrine\ORM\EntityManager;
use AppBundle\Entity\Product;
class UploadListener
{
/**
* @var EntityManager
*/
private $entityManager;
//protected $originalName;
public function __construct(EntityManager $entityManager)
{
$this->entityManager = $entityManager;
}
public function onUpload(PostPersistEvent $event)
{
$file = $event->getFile();
$this->originalName = $file->getClientOriginalName();
var_dump('In -- OnUpload');
die();
}
public function onPostUpload(PostPersistEvent $event)
{
$file = $event->getFile();
$object = new Product();
$object->setName($file->getClientOriginalName());
//$object->setName($file->getPathName());
$this->entityManager->persist($object);
$this->entityManager->flush();
var_dump('In -- OnPostUpload');
die();
}
}
upload.html.twig
{% extends 'base.html.twig' %}
{% block stylesheets %}
{{ parent() }}
<link type="text/css" rel="stylesheet" href="{{ asset('js/jquery-ui-1.12.0/jquery-ui.css') }}" />
<link type="text/css" rel="stylesheet" href="{{ asset('js/plupload/jquery.ui.plupload/css/jquery.ui.plupload.css') }}" media="screen" />
{% endblock %}
{% block content %}
<div id="box-upload">
<div id="uploader">
<p>Your browser doesn't have HTML5 support.</p>
</div>
</div>
{% endblock %}
{% block javascripts %}
<script type="text/javascript" src="{{ asset('js/jquery-2.2.4.js') }}"></script>
<script type="text/javascript" src="http://bp.yahooapis.com/2.4.21/browserplus-min.js"></script>
<script type="text/javascript" src="{{ asset('js/jquery-ui-1.12.0/jquery-ui.js') }}"></script>
<script type="text/javascript" src="{{ asset('js/plupload/plupload.full.min.js') }}"></script>
<script type="text/javascript" src="{{ asset('js/plupload/jquery.ui.plupload/jquery.ui.plupload.js') }}"></script>
<script type="text/javascript">
$(function()
{
$("#uploader").plupload(
{
// General settings
runtimes : 'html5',
url: "{{ oneup_uploader_endpoint('gallery') }}",
multi_selection: false,
// Maximum file size
max_file_size: '10mb',
chunk_size: '1mb',
// Resize images on clientside if we can
resize: {
width: 200,
height: 200,
quality: 90,
crop: true // crop to exact dimensions
},
// Specify what files to browse for
filters: [
{title: "Image files", extensions : "jpg,jpeg,png,gif"},
{title: "Zip files", extensions : "zip,avi"}
],
// Rename files by clicking on their titles
rename: true,
// Sort files
sortable: true,
// Enable ability to drag'n'drop files onto the widget (currently only HTML5 supports that)
dragdrop: true,
// Views to activate
views: {
list: true,
thumbs: false, // Show thumbs
active: 'list'
},
// Flash settings
flash_swf_url: '/plupload/js/Moxie.swf',
// Silverlight settings
silverlight_xap_url: '/plupload/js/Moxie.xap'
});
});
</script>
{% endblock %}
アップデート
- まだありません
結論
お知らせ下さい。
お時間と知識をありがとうございました。