gpt4 book ai didi

symfony - SonataMediaBundle - 如何上传图片?

转载 作者:行者123 更新时间:2023-12-03 15:02:56 25 4
gpt4 key购买 nike

可能应该命名为:“SonataMediaBundle - 缺少的操作方法在哪里?”。

我已经使用 SonataAdminBundle 和 SonataDoctrineORMAdminBundle(以及其他一些)制作了一些管理后端,大多数事情都按预期工作,但我将文件上传和处理留待以后处理,因为我想“这可能有多难?”。

长话短说 - 是否有任何关于最简单事物的文档 - 即将图像附加到帖子或条目,如何配置奏鸣曲管理类,如何以编辑形式显示图像缩略图等?

|首页documentation以“您可以访问您的管理仪表板”结尾,好像我可以期待那里有一些相关的更改,也许媒体管理器已启动并正在运行,或其他什么。但这种情况并非如此。

下一页简要介绍 heplers,然后是另一页,介绍相当复杂的 vimeo 提供商案例研究。

我已经在整个网络上进行了搜索,我能想到的最好的方法是带有 ajax 弹出窗口的上传字段和上传文件列表。

在我的管理类(class)中,我有:

protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->with('general')
->add('title')
->add('body')
->add('categories')
->end()
->with('media')
->add('images', 'sonata_type_model')

在我的新闻课上:
/**
* @ORM\ManyToMany(targetEntity="Application\Sonata\MediaBundle\Entity\Media")
*/
public $images;

并实现了所有 yaml 配置和路由。

结果是: Fatal error: Call to a member function add() on a non-object in [some-entity].php尝试上传图像时,以及带有“加号”符号(我猜是sonata_type_model 字段)的可选图像ID 列表。

我被困住了。我能够在一两个小时内在普通的 sf2 中创建媒体“管理器”,但这是另一个项目,将当前的项目重写为这种模式意味着“从头开始”。那么 - 怎么做才能使 SonataMediaBundle 和 SonataAdminBundle 一起按预期工作?

编辑:这是我所做的:

我的新闻类(或任何其他需要图片上传的类):
<?php

namespace Some\SiteBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;
use Symfony\Component\Validator\Constraints as Assert;


/**
* Some\SiteBundle\Entity\News
*
* @ORM\Table(name="news")
*/
class News
{
/**
* @var integer $id
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;


//some stuff...

/**
* @var Document documents
* @ORM\ManyToMany(targetEntity="Document", cascade={"persist", "remove", "delete"} )
**/
protected $documents;


public function __construct()
{
$this->documents = new ArrayCollection();

}

[...]

/**
* Add documents
*
* @param Festus\SiteBundle\Entity\Document $documents
*/
public function addDocument(\Festus\SiteBundle\Entity\Document $document)
{
$this->documents[] = $document;
}

/**
* set document
*
* @param Festus\SiteBundle\Entity\Document $documents
*/
public function setDocument(\Festus\SiteBundle\Entity\Document $document)
{
foreach ($this->documents as $doc) {
$this->documents->removeElement($doc);
}
$this->documents[] = $document;
}

/**
* Get documents
*
* @return Doctrine\Common\Collections\Collection
*/
public function getDocuments()
{
return $this->documents;
}



// setters, getters...

我的文档类(需要更改表的名称,因为我在某些服务器上遇到了保留字的问题):
<?php  

namespace Some\SiteBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;
use Symfony\Component\Validator\Constraints as Assert;

/**
* Some\SiteBundle\Entity\Document
*
* @ORM\Table(name="docs")
* @ORM\Entity
* @ORM\HasLifecycleCallbacks
*/
class Document
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;

/**
* @ORM\Column(type="string", length=255)
* @Assert\NotBlank
*/
private $name;

/**
* @ORM\Column(type="string", length=255, nullable=true)
*/
private $path;

/**
* @Assert\File(maxSize="6000000")
*/
private $theFile;


/**
* @ORM\Column(type="datetime", name="created_at")
*
* @var DateTime $createdAt
*/
protected $createdAt;


/**
* @ORM\Column(type="integer")
*/
private $type = 1;


public function __construct()
{
$this->createdAt = new \DateTime();
}

public function getAbsolutePath()
{
return null === $this->path ? null : $this->getUploadRootDir().'/'.$this->path;
}

public function getWebPath()
{
return null === $this->path ? null : $this->getUploadDir().'/'.$this->path;
}

protected function getUploadRootDir()
{
// the absolute directory path where uploaded documents should be saved
return __DIR__.'/../../../../web/'.$this->getUploadDir();
}

protected function getUploadDir()
{
// get rid of the __DIR__ so it doesn't screw when displaying uploaded doc/image in the view.
return 'uploads/documents';
}

/**
* @ORM\PrePersist()
* @ORM\PreUpdate()
*/
public function preUpload()
{
if (null !== $this->theFile) {
//var_dump($this);
// do whatever you want to generate a unique name
$this->path = uniqid().'.'.$this->theFile->guessExtension();
}
}

/**
* @ORM\PostPersist()
* @ORM\PostUpdate()
*/
public function upload()
{
if (null === $this->theFile) {
return;
}

// if there is an error when moving the file, an exception will
// be automatically thrown by move(). This will properly prevent
// the entity from being persisted to the database on error
$this->theFile->move($this->getUploadRootDir(), $this->path);

unset($this->theFile);
}

/**
* @ORM\PostRemove()
*/
public function removeUpload()
{
if ($file = $this->getAbsolutePath()) {
unlink($file);
}
}

public function __toString()
{
return 'Document';
}


/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}

/**
* Set name
*
* @param string $name
*/
public function setName($name)
{
$this->name = $name;
}

/**
* Get name
*
* @return string
*/
public function getName()
{
return $this->name;
}

/**
* Set file
*
* @param string $file
*/
public function setTheFile($file)
{
$this->theFile = $file;
}

/**
* Get file
*
* @return string
*/
public function getTheFile()
{
return $this->theFile;
}

/**
* Set path
*
* @param string $path
*/
public function setPath($path)
{
$this->path = $path;
}

/**
* Get path
*
* @return string
*/
public function getPath()
{
return $this->path;
}


/**
* Set type
*
* @param string $type
*/
public function setType($type)
{
$this->type = $type;
}

/**
* Get type
*
* @return string
*/
public function getType()
{
return $this->type;
}


/**
* Gets an object representing the date and time the user was created.
*
* @return DateTime A DateTime object
*/
public function getCreatedAt()
{
return $this->createdAt;
}


/**
* Gets an object representing the date and time the user was created.
*
* @return DateTime A DateTime object
*/
public function getCreatedAtString()
{
return date_format($this->createdAt, "Y-m-d");
}


/**
* Set createdAt
*
* @param datetime $createdAt
*/
public function setCreatedAt($createdAt)
{
$this->createdAt = $createdAt;
}


}

如您所见,其中大部分内容是从 symfony2 教程中复制而来的。

现在,对于 Controller :
<?php 

namespace Some\SiteBundle;

use Some\SiteBundle\Form\Type\ImageShowType;
use Some\SiteBundle\Entity\Document;
use Sonata\AdminBundle\Admin\Admin;
use Sonata\AdminBundle\Datagrid\ListMapper;
use Sonata\AdminBundle\Datagrid\DatagridMapper;
use Sonata\AdminBundle\Validator\ErrorElement;
use Sonata\AdminBundle\Form\FormMapper;
use Sonata\AdminBundle\Show\ShowMapper;
use Symfony\Component\HttpFoundation\File\File;
use Symfony\Component\HttpFoundation\Request;


class NewsAdmin extends Admin
{

public function __construct($code, $class, $baseControllerName) {
parent::__construct($code, $class, $baseControllerName);

$this->setFormTheme(array_merge($this->getFormTheme(),
array('FestusSiteBundle:Form:image_form.html.twig')
));
}


protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->with('ogólne')
->add('title', NULL, array('label' => 'tytuł:'))
->add('body', NULL, array('label' => 'treść:', 'attr' => array(
'class' => 'tinymce', 'data-theme' => 'simple')))
->add('categories', NULL, array('label' => 'kategorie:'))
->end()
->with('media')
->add('fileName', 'text', array(
"label" => 'tytuł obrazka:',
'property_path' => false,
'required' => false
))
->add('theFile', 'file', array(
"label" => 'wybierz plik',
'property_path' => false,
'required' => false
))
->end()
;
}

protected function configureDatagridFilters(DatagridMapper $datagridMapper)
{
$datagridMapper
->add('title')
->add('body')
;
}

protected function configureListFields(ListMapper $listMapper)
{
$listMapper
->addIdentifier('title')
->add('categories')

->add('_action', 'actions', array(
'actions' => array(
'view' => array(),
'edit' => array(),
)
))
;
}

protected function configureShowFields(ShowMapper $showMapper)
{
$showMapper->add('title')
->add('body');

}

public function validate(ErrorElement $errorElement, $object)
{
$errorElement
->with('title')
->assertMinLength(array('limit' => 2))
->end()
;
}

public function prePersist($news) {
$this->saveFile($news);
}

public function preUpdate($news) {
$this->saveFile($news);
}

public function saveFile($news) {
$request = Request::createFromGlobals();
$requestData = current($request->request->all());
$filesData = current($request->files->all());
$document = new Document();
$theFile = $filesData['theFile'];
$name = $requestData['fileName'];

if($theFile != NULL){
$document->setName($name);
$document->setTheFile($theFile);
$news->setDocument($document);
}
}
}

我的基本包类扩展了管理包类,我可以覆盖模板:
<?php

namespace Some\SiteBundle;

use Symfony\Component\HttpKernel\Bundle\Bundle;

class SomeSiteBundle extends Bundle
{

public function getParent()
{
return 'SonataAdminBundle';
}

}

而在 SomeSiteBundle/resources/views/CRUD/base_edit.html.twig我稍微改变了模板,让用户看到当前设置的图片:
<div class="sonata-ba-collapsed-fields">                    
{% for field_name in form_group.fields %}
{% if admin.formfielddescriptions[field_name] is defined %}
{% if field_name == 'fileName' %}

<h5 style="margin-left: 40px">Obecny obrazek:</h5>
{% if object.documents[0] is defined %}
<img style="margin: 0 0 0 40px; border: 1px dotted #ccc" src="{{ asset(object.documents[0].webPath) }}" />
{% else %}
<div style="margin-left: 40px">brak</div>
{% endif %}
<hr><h5 style="margin-left: 40px">Wczytaj nowy:</h5>
{% endif %}
{{ form_row(form[field_name])}}
{% endif %}
{% endfor %}
</div>

现在我每条新闻只使用一张图片(“特色图片”),无论如何这有点矫枉过正,因为我使用的是带有 jbimages 插件的 tinyMCE,所以无论如何我都可以将图片放入新闻正文中。要使 jbimages 插件正常工作,您必须设置一些 tinyMCE 选项:

------ 这部分处理tinymce和tinymce包和tinymce插件: ---------
$config['img_path'] = '/web/uploads/documents'; (或任何其他适合您的路径)在 web/bundles/stfalcontinymce/vendor/tiny_mce/plugins/jbimages/config.php . (当然,您需要先安装 stfalcon tinymce 包)。然后我编辑了一下 web/bundles/stfalcontinymce/js/init.jquery.js允许来自 config.yml 的更多选项阅读:
themeOptions.script_url = options.jquery_script_url;
//mine:
themeOptions.convert_urls = options.convert_urls;
themeOptions.relative_urls = options.relative_urls;
themeOptions.remove_script_host = options.remove_script_host;
themeOptions.document_base_url = options.document_base_url;

最后在 config.yml :
[...]
stfalcon_tinymce:
include_jquery: true
tinymce_jquery: true
textarea_class: "tinymce"
relative_urls : false
convert_urls : false
remove_script_host : false
document_base_url : "http://somesite.home.pl/web/"
theme:
[...]

仅此而已,AFAIR。希望这可以帮助 ;-)

最佳答案

也许您可以在以下内容中找到问题的答案:
/admin/sonata/media/media/create?provider=sonata.media.provider.image&context=default

我对您的其他解决方案感兴趣,请发布代码。谢谢

关于symfony - SonataMediaBundle - 如何上传图片?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11526457/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com