本文整理匯總了PHP中ezcMailTools::guessContentType方法的典型用法代碼示例。如果您正苦於以下問題:PHP ezcMailTools::guessContentType方法的具體用法?PHP ezcMailTools::guessContentType怎麽用?PHP ezcMailTools::guessContentType使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類ezcMailTools
的用法示例。
在下文中一共展示了ezcMailTools::guessContentType方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: testGuessContentType
public function testGuessContentType()
{
$fileNames = array('/home/1.jpg', '2.jpe', '3.jpeg', '4.gif', '5.tif', '6.tiff', '7.bmp', '8.png', '9.xxx', '10');
$types = array('image/jpeg', 'image/jpeg', 'image/jpeg', 'image/gif', 'image/tiff', 'image/tiff', 'image/bmp', 'image/png', '/', '/');
for ($i = 0; $i < count($fileNames); $i++) {
$contentType = null;
$mimeType = null;
ezcMailTools::guessContentType($fileNames[$i], $contentType, $mimeType);
$this->assertEquals($types[$i], $contentType . '/' . $mimeType);
}
}
示例2: generateHtmlPart
/**
* Returns an ezcMailPart based on the HTML provided.
*
* This method adds local files/images to the mail itself using a
* {@link ezcMailMultipartRelated} object.
*
* @throws ezcBaseFileNotFoundException
* if $fileName does not exists.
* @throws ezcBaseFilePermissionProblem
* if $fileName could not be read.
* @return ezcMailPart
*/
private function generateHtmlPart()
{
$result = false;
if ($this->htmlText != '') {
$matches = array();
if ($this->options->automaticImageInclude === true) {
// recognize file:// and file:///, pick out the image, add it as a part and then..:)
preg_match_all("/<img[\\s\\*\\s]src=[\\'\"]file:\\/\\/([^ >\\'\"]+)/i", $this->htmlText, $matches);
// pictures/files can be added multiple times. We only need them once.
$matches = array_unique($matches[1]);
}
$result = new ezcMailText($this->htmlText, $this->charset, $this->encoding);
$result->subType = "html";
if (count($matches) > 0) {
$htmlPart = $result;
// wrap already existing message in an alternative part
$result = new ezcMailMultipartRelated($result);
// create a filepart and add it to the related part
// also store the ID for each part since we need those
// when we replace the originals in the HTML message.
foreach ($matches as $fileName) {
if (is_readable($fileName)) {
// @todo waiting for fix of the fileinfo extension
// $contents = file_get_contents( $fileName );
$mimeType = null;
$contentType = null;
if (ezcBaseFeatures::hasExtensionSupport('fileinfo')) {
// if fileinfo extension is available
$filePart = new ezcMailFile($fileName);
} elseif (ezcMailTools::guessContentType($fileName, $contentType, $mimeType)) {
// if fileinfo extension is not available try to get content/mime type
// from the file extension
$filePart = new ezcMailFile($fileName, $contentType, $mimeType);
} else {
// fallback in case fileinfo is not available and could not get content/mime
// type from file extension
$filePart = new ezcMailFile($fileName, "application", "octet-stream");
}
$cid = $result->addRelatedPart($filePart);
// replace the original file reference with a reference to the cid
$this->htmlText = str_replace('file://' . $fileName, 'cid:' . $cid, $this->htmlText);
} else {
if (file_exists($fileName)) {
throw new ezcBaseFilePermissionException($fileName, ezcBaseFileException::READ);
} else {
throw new ezcBaseFileNotFoundException($fileName);
}
// throw
}
}
// update mail, with replaced URLs
$htmlPart->text = $this->htmlText;
}
}
return $result;
}
示例3: generateHtmlPart
/**
* Returns an ezcMailPart based on the HTML provided.
*
* This method adds local files/images to the mail itself using a
* {@link ezcMailMultipartRelated} object.
*
* @throws ezcBaseFileNotFoundException
* if $fileName does not exists.
* @throws ezcBaseFilePermissionProblem
* if $fileName could not be read.
* @return ezcMailPart
*/
private function generateHtmlPart()
{
$result = false;
if ($this->htmlText != '') {
$matches = array();
if ($this->options->automaticImageInclude === true) {
/*
1.7.1 regex is buggy filename are not extract correctly
http://issues.ez.no/IssueView.php?Id=16612&
preg_match_all( '(
<img \\s+[^>]*
src\\s*=\\s*
(?:
(?# Match quoted attribute)
([\'"])file://(?P<quoted>[^>]+)\\1
(?# Match unquoted attribute, which may not contain spaces)
| file://(?P<unquoted>[^>\\s]+)
)
[^>]* >)ix', $htmlText, $matches );
* */
// CJW Newsletter regex change only find all file://ezroot/
// so it is secure
// recognize file://ezroot/ and pick out the image, add it as a part and then..:)
preg_match_all("/<img[\\s\\*\\s]src=[\\'\"]file:\\/\\/ezroot\\/([^ >\\'\"]+)/i", $this->htmlText, $matches);
// pictures/files can be added multiple times. We only need them once.
$matches = array_unique($matches[1]);
}
$result = new ezcMailText($this->htmlText, $this->charset, $this->encoding);
$result->subType = "html";
if (count($matches) > 0) {
$htmlPart = $result;
// wrap already existing message in an alternative part
$result = new ezcMailMultipartRelated($result);
// create a filepart and add it to the related part
// also store the ID for each part since we need those
// when we replace the originals in the HTML message.
foreach ($matches as $fileName) {
if (is_readable($fileName)) {
// @todo waiting for fix of the fileinfo extension
// $contents = file_get_contents( $fileName );
$mimeType = null;
$contentType = null;
if (ezcBaseFeatures::hasExtensionSupport('fileinfo')) {
// if fileinfo extension is available
$filePart = new ezcMailFile($fileName);
} elseif (ezcMailTools::guessContentType($fileName, $contentType, $mimeType)) {
// if fileinfo extension is not available try to get content/mime type
// from the file extension
$filePart = new ezcMailFile($fileName, $contentType, $mimeType);
} else {
// fallback in case fileinfo is not available and could not get content/mime
// type from file extension
$filePart = new ezcMailFile($fileName, "application", "octet-stream");
}
$cid = $result->addRelatedPart($filePart);
// replace the original file reference with a reference to the cid
$this->htmlText = str_replace('file://ezroot/' . $fileName, 'cid:' . $cid, $this->htmlText);
} else {
if (file_exists($fileName)) {
throw new ezcBaseFilePermissionException($fileName, ezcBaseFileException::READ);
} else {
throw new ezcBaseFileNotFoundException($fileName);
}
// throw
}
}
// update mail, with replaced URLs
$htmlPart->text = $this->htmlText;
}
}
return $result;
}