উত্তর:
এম 2 বাক্সের বাইরে আসে না তবে এটি জেন্ড ফ্রেমওয়ার্কের মধ্যে নির্মিত বৈশিষ্ট্য। এই কার্যকারিতাটি ম্যাজেন্টোতে কীভাবে যুক্ত করবেন তা এখানে একটি ভাল রেফারেন্স রয়েছে: https://blog.bitexpert.de/blog/sending-mails-with-attachments-in-magento-2/
যদি লিঙ্কটি মারা যায় তবে নিম্নলিখিতটি তৈরি করুন
<?php
namespace Your\CustomModule\Magento\Mail\Template;
class TransportBuilder
extends \Magento\Framework\Mail\Template\TransportBuilder
{
public function addAttachment(
$body,
$mimeType = Zend_Mime::TYPE_OCTETSTREAM,
$disposition = Zend_Mime::DISPOSITION_ATTACHMENT,
$encoding = Zend_Mime::ENCODING_BASE64,
$filename = null
) {
$this->message->createAttachment($body, $mimeType, $disposition, $encoding, $filename);
return $this;
}
}
তারপরে ইত্যাদি / di.xML এ যুক্ত করুন
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">
<preference for="\Magento\Framework\Mail\Template\TransportBuilder"
type="\Your\CustomModule\Magento\Mail\Template\TransportBuilder" />
</config>
এখন আপনি addAttachment()
আপনার সাইট জুড়ে ব্যবহার করতে পারেন ।
Magento 2.2.7 এর মতো সমাধান উপরে বর্ণিত আর কাজ করে না যেহেতু \Magento\Framework\Mail\Message
ব্যাপ্ত বাদ \Zend_Mail
।
পরিবহন বিল্ডারের মাধ্যমে সংযুক্তি যুক্ত করার সহজ পদ্ধতির অভাবকে রোধ করার জন্য (যা বর্তমানে এই জাতীয় কোনও ফাংশনের সঠিক জায়গা বলে মনে হয়), একজনকে ট্রান্সপোর্টবিল্ডারের প্রতিস্থাপন তৈরি করতে হবে এবং ব্যবহার করতে হবে \Zend\Mime\Part
:
<?php
namespace Your\CustomModule\Magento\Mail\Template;
use Magento\Framework\Mail\MessageInterface;
use Magento\Framework\Mail\MessageInterfaceFactory;
use Magento\Framework\Mail\Template\FactoryInterface;
use Magento\Framework\Mail\Template\SenderResolverInterface;
use Magento\Framework\Mail\TransportInterfaceFactory;
use Magento\Framework\ObjectManagerInterface;
use Zend\Mime\Mime;
use Zend\Mime\Part as MimePart;
use Zend\Mime\PartFactory as MimePartFactory;
use Zend\Mime\Message as MimeMessage;
use Zend\Mime\MessageFactory as MimeMessageFactory;
class TransportBuilder extends \Magento\Framework\Mail\Template\TransportBuilder
{
/** @var MimePart[] */
private $parts = [];
/** @var MimeMessageFactory */
private $mimeMessageFactory;
/** @var MimePartFactory */
private $mimePartFactory;
public function __construct(
FactoryInterface $templateFactory,
MessageInterface $message,
SenderResolverInterface $senderResolver,
ObjectManagerInterface $objectManager,
TransportInterfaceFactory $mailTransportFactory,
MimePartFactory $mimePartFactory,
MimeMessageFactory $mimeMessageFactory,
MessageInterfaceFactory $messageFactory = null
) {
parent::__construct(
$templateFactory,
$message,
$senderResolver,
$objectManager,
$mailTransportFactory,
$messageFactory
);
$this->mimePartFactory = $mimePartFactory;
$this->mimeMessageFactory = $mimeMessageFactory;
}
protected function prepareMessage()
{
parent::prepareMessage();
$mimeMessage = $this->getMimeMessage($this->message);
foreach ($this->parts as $part) {
$mimeMessage->addPart($part);
}
$this->message->setBody($mimeMessage);
return $this;
}
public function addAttachment(
$body,
$mimeType = Mime::TYPE_OCTETSTREAM,
$disposition = Mime::DISPOSITION_ATTACHMENT,
$encoding = Mime::ENCODING_BASE64,
$filename = null
) {
$this->parts[] = $this->createMimePart($body, $mimeType, $disposition, $encoding, $filename);
return $this;
}
private function createMimePart(
$content,
$type = Mime::TYPE_OCTETSTREAM,
$disposition = Mime::DISPOSITION_ATTACHMENT,
$encoding = Mime::ENCODING_BASE64,
$filename = null
) {
/** @var MimePart $mimePart */
$mimePart = $this->mimePartFactory->create(['content' => $content]);
$mimePart->setType($type);
$mimePart->setDisposition($disposition);
$mimePart->setEncoding($encoding);
if ($filename) {
$mimePart->setFileName($filename);
}
return $mimePart;
}
private function getMimeMessage(MessageInterface $message)
{
$body = $message->getBody();
if ($body instanceof MimeMessage) {
return $body;
}
/** @var MimeMessage $mimeMessage */
$mimeMessage = $this->mimeMessageFactory->create();
if ($body) {
$mimePart = $this->createMimePart((string)$body, Mime::TYPE_TEXT, Mime::DISPOSITION_INLINE);
$mimeMessage->setParts([$mimePart]);
}
return $mimeMessage;
}
}
\Magento\Framework\Mail\Template\TransportBuilder
মাধ্যমে বাস্তবায়নের মাধ্যমে আসলটি প্রতিস্থাপন করতে ভুলবেন না di.xml
।
নোট করুন যে এই বাস্তবায়নটি সম্ভবত অবহিত হিসাবে ম্যাগন্টো-র আসন্ন প্রকাশের সাথে ভেঙে \Magento\Framework\Mail\MessageInterface::setBody()
যাবে এবং শীঘ্রই অপসারণ করা যেতে পারে।
আছে HTH
ম্যাগেন্টো 2 মডিউল থেকে কাস্টম ইমেল, চিত্র সংযুক্তি সরবরাহ করে না।
আপনি যদি ম্যাজেন্টো 2 এ ইমেল টেমপ্লেটগুলির সাথে চিত্র সংযুক্তিটি ব্যবহার করতে চান তবে আপনাকে ক্লাস ওভাররাইড করতে হবে, ম্যাজেন্টো me ফ্রেমওয়ার্ক \ মেল \ টেমপ্লেট \ ট্রান্সপোর্টবিল্ডার
ম্যাজেন্টো-অফ-বাক্স ইমেলের জন্য সংযুক্তি বৈশিষ্ট্য সরবরাহ করে না। আপনি বিশদে ইমেল সংযুক্তি প্রেরণের জন্য ব্লগগুলি উল্লেখ করতে পারেন,
আপনি নীচের উপায় মত যুক্তি যুক্ত করতে হবে,
public function addAttachment(
$body,
$mimeType = \Zend_Mime::TYPE_OCTETSTREAM,
$disposition = \Zend_Mime::DISPOSITION_ATTACHMENT,
$encoding = \Zend_Mime::ENCODING_BASE64,
$filename = null
) {
$this->message->createAttachment($body, $mimeType, $disposition, $encoding, $filename);
return $this;
}
মেগেটনো ২.৩-তে ইমেলের পিডিএফ প্রেরণের উপযুক্ত উত্তর এখানে
$transport = $_transportBuilder->setTemplateIdentifier(20)
->setTemplateOptions($templateOptions)
->setTemplateVars($templateVars)
->setFrom($from)
->addTo($vendor_email)
->getTransport();
$html = $transport->getMessage()>getBody()->generateMessage();
$bodyMessage = new \Zend\Mime\Part($html);
$bodyMessage->type = 'text/html';
$attachment = $_transportBuilder->addAttachment($pdfData,$fileName);
$bodyPart = new \Zend\Mime\Message();
$bodyPart->setParts(array($bodyMessage,$attachment));
$transport->getMessage()->setBody($bodyPart);
$transport->sendMessage();
$inlineTranslation->resume();
এটি ম্যাগেন্টো ২.৩ এর জন্য আমার উত্তর ছিল যেহেতু গুগলে এটি শীর্ষস্থানীয় প্রশ্ন ছিল এবং মন্তব্যগুলিতে এমন অনেক লোক রয়েছেন বলে মনে হয়।
ডিফল্ট TransportBuilder
ক্লাসের মাধ্যমে ওভাররাইট করা সম্পর্কে অন্যান্য পোস্টে প্রচুর আকাঙ্ক্ষা রয়েছে বলে মনে হয় etc/di.xml
, তবে আমি যে মডিউলটি নিয়ে কাজ করছি তা এত ছোট যে আমি এটি ডিফল্টর জন্য দায়বদ্ধ হতে চাই না TransportBuilder
তাই আমি একটি সহায়ক শ্রেণি তৈরি করেছি (উচিত এটি ঘোষিত ইমেল টেমপ্লেটের সাথে একত্রে কতটা মিলিত - তার ভিত্তিতে একটি মডেল হোন - তবে আমি খনন করি)।
এতে TransportBuilder
জনসাধারণের অ্যাক্সেস নেই TransportInterface
, তবে পরিবর্তে প্রতিবার একটি ক্লোন তৈরি করে এবং তারপরে নির্মাতাকে পুনরায় সেট করুন। আমি আমার TransportInterface
উদাহরণটি তৈরি করা এবং তারপরে Part
পরিবহণের বার্তায় আমার সংযুক্তিগুলি যুক্ত করতে আরও সহজ পেয়েছি । আপনি যদি TransportBuilder
নির্ভরতা ইনজেকশন পছন্দের মাধ্যমে ডিফল্টটিকে ওভাররাইট করার প্রয়োজন মনে করেন , সর্বজনীন পদ্ধতি আপডেট করার বিষয়ে সতর্ক হন। আপনার কোডটি সলিড রাখার সময় ও অনুশীলন করতে ভুলবেন না !
namespace Vendor\Module\Helper;
use Magento\Framework\App\Area;
use Magento\Framework\App\Helper\AbstractHelper;
use Magento\Framework\App\Helper\Context;
use Magento\Framework\DataObject;
use Magento\Framework\Filesystem\Io\File;
use Magento\Framework\Mail\Template\TransportBuilder;
use Magento\Framework\Mail\TransportInterface;
use Magento\Store\Model\StoreManagerInterface;
use Zend_Mime;
use Zend\Mime\Part;
/**
* This was initially built out to send a single email. Abstract this as you
* wish.
*
* @package Vendor\Module\Helper
*/
class Mail extends AbstractHelper
{
/**
* @var Context
*/
protected $context;
/**
* @var TransportBuilder
*/
protected $transportBuilder;
/**
* @var StoreManagerInterface
*/
protected $storeManager;
/**
* @var Config
*/
protected $config;
/**
* Mail constructor.
*
* @param Context $context
* @param TransportBuilder $transportBuilder
* @param StoreManagerInterface $storeManager
* @param Config $config
* @param File $file
*/
public function __construct(
Context $context,
TransportBuilder $transportBuilder,
StoreManagerInterface $storeManager,
Config $config,
File $file
) {
parent::__construct($context);
$this->transportBuilder = $transportBuilder;
$this->storeManager = $storeManager;
$this->config = $config;
$this->file = $file;
}
/**
* Send the email for a Help Center submission.
*
* @param DataObject $templateParams
* @param array $attachments
* @return void
*/
public function send(DataObject $templateParams, array $attachments = [])
{
$storeId = $this->storeManager->getStore()->getId();
// Build transport
/** @var \Magento\Framework\Mail\TransportInterface $transport */
$transport = $this->transportBuilder
->setTemplateOptions(['area' => Area::AREA_FRONTEND, 'store' => $storeId])
->setTemplateIdentifier($this->config->getEmailTemplate())
->setTemplateVars($templateParams->toArray())
->setFrom($this->config->getEmailSender())
->addTo($this->config->getEmailRecipient(), 'Help Center')
/**
* Something important to note is that when the getTransport()
* function is run, the message is compiled and then the builder
* class resets (as of 2.3.1).
*
* This is note worthy because if you want to send > 1 attachment,
* your $builder will be reset -- losing all of the ->set* functions
* you just used above as well as your attachment.
*
* Since we append attachments to the transport, it's easier to:
* build -> attach -> send. And this way multiple attachments
* can be included. :thumbsup:
*/
->getTransport();
// Attach Images to transport
foreach ($attachments as $a) {
$transport = $this->addAttachment($transport, $a);
}
// Send transport
$transport->sendMessage();
}
/**
* Add an attachment to the message inside the transport builder.
*
* @param TransportInterface $transportBuilder
* @param array $file Sanitized index from $_FILES
* @return TransportInterface
*/
protected function addAttachment(TransportInterface $transport, array $file): TransportInterface
{
$part = $this->createAttachment($file);
$transport->getMessage()->addPart($part);
return $transport;
}
/**
* Create an zend mime part that is an attachment to attach to the email.
*
* This was my usecase, you'll need to edit this to your own needs.
*
* @param array $file Sanitized index from $_FILES
* @return Part
*/
protected function createAttachment(array $file): Part
{
$ext = '.' . explode('/', $file['type'])[1];
$fileName = md5(uniqid(microtime()), true) . $ext;
$attachment = new Part($this->file->read($file['tmp_name']));
$attachment->disposition = Zend_Mime::TYPE_OCTETSTREAM;
$attachment->encoding = Zend_Mime::ENCODING_BASE64;
$attachment->filename = $fileName;
return $attachment;
}
}
MessageInterface::getBody
পদ্ধতি স্বাক্ষর একটি স্ট্রিং রিটার্ন টাইপ দেখায়। আপনাকে আপনার TransportInterface
অবজেক্টের আশেপাশে খনন করতে হবে , তবে আমি আপনাকে বলতে পারি যে addPart
পদ্ধতিটি কোনও Zend\Mime\Message
অবজেক্টে বিদ্যমান । যেহেতু ম্যাজেন্টো সম্ভবত তাদের নিজস্ব বর্গের জন্য এই শ্রেণিটি বাড়িয়েছে Message
, আমি মনে করি এটি চেষ্টা করা স্মার্ট হবে$transport->getMessage()->addpart($part);
পূর্ববর্তী উত্তরগুলি দ্বারা উল্লিখিত হিসাবে, ম্যাজেন্টো 2-এ সংযুক্তি সহ মেলগুলি প্রেরণের বাইরে কোনও ফাংশন নেই।
এটি সর্বোত্তম অনুশীলন কিনা তা আমি জানি না, তবে আপনি Zend_Mail
কোনও কাস্টম ফাংশন তৈরি না করে এবং Magento\Framework\Mail\Template\TransportBuilder
নীচের মতো ওভাররাইড না করেই এটি করতে সরাসরি ক্লাস করতে পারেন
$mail = new \Zend_Mail('utf-8');
$mail->setFrom($senderEmail);
$mail->addTo($receiverEmail);
$mail->setSubject($subject);
$mail->setBodyHtml($text);
$content = file_get_contents($attachmentAbsolutePath);
$attachment = new \Zend_Mime_Part($content);
$attachment->type = 'text/xml'; // attachment's mime type
$attachment->disposition = \Zend_Mime::DISPOSITION_ATTACHMENT;
$attachment->encoding = \Zend_Mime::ENCODING_BASE64;
$attachment->filename = $filename;
$mail->addAttachment($attachment);
$mail->send();