【问题标题】:Symfony 2 Persist a JQueryFileUpload file in a Sonata MediaSymfony 2 在 Sonata Media 中保留一个 JQueryFileUpload 文件
【发布时间】:2017-02-06 22:17:04
【问题描述】:

我正在尝试将JqueryFileUpload 上传的文件保留在 Sonata Media 中,但它不起作用。 我使用 OneUpUploaderBundle 将 JQueryFileUpload 与 Symfony2 集成

我已经尝试过postUploadEventpreUploadEvent

还有来自 jQuery 脚本的 data.files。

如果有人知道如何在 Symfony 中或通过 JQuery 获取包含内容的文件对象,那将是一个很大的帮助。

public function onUpload(PreUploadEvent $event) {

    $request = $event->getRequest();

    $files = $request->files->get('uploadFiles');

    foreach ($request->files->get('uploadFiles') as $fotoTemporaria) {

    $foto = new Media();

    $foto->setProviderName('sonata.media.provider.image');
    $foto->setContext('default');
    $foto->setBinaryContent($fotoTemporaria);
    $foto->setEnabled(true);

    $mediaManager->persist($foto);
    $mediaManager->flush();

    }

    $response = $event->getResponse();

    $response['uploadedFiles'] = $files;

    $response['success'] = true;
    return $response;
}

services.yml 文件

media_upload_listener:
     class: AppBundle\ClassServices\UploadListener
     arguments: [@doctrine.orm.entity_manager]
     tags:
         - { name: kernel.event_listener, event: oneup_uploader.post_persist, method: onUpload }

还有 jQuery 文件

$(document).ready(function ()
    {
        $('#fileupload').fileupload({
            add: function (e, data) {
                if (data.files && data.files[0]) {
                    var reader = new FileReader();
                    reader.onload = function (e) {
                        $('#uploaded').append("<div id='imageNumber' class='imageContainer'><img class='imagePreview' src='" + e.target.result + "'> \n\
                <input type='file' name='realMedia[]' style='display:none' value='" + e.target.result + "'></div>");
                    }
                    data.result = data.files[0];
                    reader.readAsDataURL(data.files[0]);
                    data.submit();
                }
            },
            progress: function (e, data) {
                var progress = parseInt(data.loaded / data.total * 100, 10);
                $('#progress .bar').css(
                        'width',
                        progress + '%'
                        );
            },
            done: function (e, data) {
                var out ='';
                var obj = data;
                for (var i in obj) {
                    out += i + ": " + obj[i] + "\n";
                }

                this attribute is empty
                alert(data.files);

              }
        });
    });

【问题讨论】:

  • 如果我错了,请纠正我,但我认为您可能会误解将文件作为 XHR 请求与父表单的主提交一起发送。
  • 是的。这是因为我需要对像 facebook 这样的画廊进行编程。需要上传和图像,预览它并在画廊中发布。我正在使用 SonataMediaBundle、OneUpUploaderBundle 和 JqueryFileUpload。

标签: php jquery symfony


【解决方案1】:

我发现了正在发生的事情。这是因为我在构造中使用 ObjectManager 而不是 EntityManager。

类 UploadListener {

protected $em;

public function __construct(EntityManager $em) {
    $this->em = $em;
}

public function getEm() {
    return $this->em;
}

public function onUpload(PostPersistEvent $event) {

    $file = $event->getFile();

    $entityManager = $this->getEm();

    $foto = new Media();

    $foto->setProviderName('sonata.media.provider.image');
    $foto->setContext('default');
    $foto->setBinaryContent($file);
    $foto->setUsuario($event->getRequest()->get('user'));
    $foto->setEnabled(true);

    $entityManager->persist($foto);
    $entityManager->flush();

    $response = $event->getResponse();

    $response['success'] = true;

    return $response;
}

}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2015-05-09
    • 1970-01-01
    • 1970-01-01
    • 2013-11-25
    • 2016-01-05
    • 1970-01-01
    • 2018-07-03
    相关资源
    最近更新 更多