mediaentry.php
来自「Bug tracker, and reporter.」· PHP 代码 · 共 161 行
PHP
161 行
<?php/** * Zend Framework * * LICENSE * * This source file is subject to the new BSD license that is bundled * with this package in the file LICENSE.txt. * It is also available through the world-wide-web at this URL: * http://framework.zend.com/license/new-bsd * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to license@zend.com so we can send you a copy immediately. * * @category Zend * @package Zend_Gdata * @copyright Copyright (c) 2005-2008 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License *//** * @see Zend_Gdata_App_Entry */require_once 'Zend/Gdata/App/Entry.php';/** * @see Zend_Gdata_App_MediaSource */require_once 'Zend/Gdata/App/MediaSource.php';/** * @see Zend_Mime */require_once 'Zend/Mime.php';/** * @see Zend_Mime_Message */require_once 'Zend/Mime/Message.php';/** * Concrete class for working with Atom entries containing multi-part data. * * @category Zend * @package Zend_Gdata * @copyright Copyright (c) 2005-2008 Zend Technologies USA Inc. (http://www.zend.com) * @license http://framework.zend.com/license/new-bsd New BSD License */class Zend_Gdata_App_MediaEntry extends Zend_Gdata_App_Entry{ /** * The attached MediaSource/file * * @var Zend_Gdata_App_MediaSource */ protected $_mediaSource = null; /** * The Zend_Mime object used to generate the boundary * * @var Zend_Mime */ protected $_mime = null; /** * Constructs a new MediaEntry, representing XML data and optional * file to upload * * @param DOMElement $element (optional) DOMElement from which this * object should be constructed. */ public function __construct($element = null, $mediaSource = null) { parent::__construct($element); $this->_mime = new Zend_Mime(); $this->_mediaSource = $mediaSource; } /** * Return the Zend_Mime object associated with this MediaEntry. This * object is used to generate the media boundaries. * * @return Zend_Mime The Zend_Mime object associated with this MediaEntry. */ public function getMime() { return $this->_mime; } /** * Return the MIME multipart representation of this MediaEntry. * * @return string The MIME multipart representation of this MediaEntry */ public function encode() { $xmlData = $this->saveXML(); if ($this->getMediaSource() === null) { // No attachment, just send XML for entry return $xmlData; } else { $mimeMessage = new Zend_Mime_Message(); $mimeMessage->setMime($this->_mime); $xmlPart = new Zend_Mime_Part($xmlData); $xmlPart->type = 'application/atom+xml'; $xmlPart->encoding = null; $mimeMessage->addPart($xmlPart); $binaryPart = new Zend_Mime_Part($this->getMediaSource()->encode()); $binaryPart->type = $this->getMediaSource()->getContentType(); $binaryPart->encoding = null; $mimeMessage->addPart($binaryPart); return $mimeMessage->generateMessage(); } } /** * Return the MediaSource object representing the file attached to this * MediaEntry. * * @return Zend_Gdata_App_MediaSource The attached MediaSource/file */ public function getMediaSource() { return $this->_mediaSource; } /** * Set the MediaSource object (file) for this MediaEntry * * @param Zend_Gdata_App_MediaSource $value The attached MediaSource/file * @return Zend_Gdata_App_MediaEntry Provides a fluent interface */ public function setMediaSource($value) { if ($value instanceof Zend_Gdata_App_MediaSource) { $this->_mediaSource = $value; } else { require_once 'Zend/Gdata/App/InvalidArgumentException.php'; throw new Zend_Gdata_App_InvalidArgumentException( 'You must specify the media data as a class that conforms to Zend_Gdata_App_MediaSource.'); } return $this; } /** * Return the boundary used in the MIME multipart message * * @return string The boundary used in the MIME multipart message */ public function getBoundary() { return $this->_mime->boundary(); }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?