-1

明確化

この質問は、異なるアップロードライブラリを使用しているという点で同様の質問Pluploadとは異なります(この質問とFineUploader同様の質問)。

この質問を書いている時点では、問題がどこにあるのかわかりませんでした。そのため、別のライブラリを使用すると問題を解決できると期待していました。

前書き

OneupUploaderBundle3 週間前に、FineUploaderライブラリを使用して、アップロードに関する同様の質問を作成しました。残念ながら、まだ答えはありません。その間、別のアップロード ライブラリ (Blueimp) をセットアップしてみました。

OneupUploaderBundle1 週間前に、Blueimp jQuery アップロードライブラリを使用して、アップロードに関する同様の質問を作成しました。残念ながら、まだ答えはありません。その間、別のアップロード ライブラリ (Plupload) をセットアップしてみました。

を含む [1] をWindows 10 Pro開発中です。XAMPPPHP v7.0.8

ファイルをサーバーにアップロードするために、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 %}

アップデート

  1. まだありません

結論

お知らせ下さい。

お時間と知識をありがとうございました。

4

1 に答える 1