Menghantar e -mel menggunakan node.js
node.js Mail Hantar Panduan: Hantar dan terima e -mel menggunakan NodeMailer
Artikel ini akan membimbing anda tentang cara menghantar dan menerima e -mel menggunakan node.js dan menyelesaikan masalah biasa. Nodemailer adalah modul NPM yang popular dengan lebih daripada tiga juta muat turun setiap minggu, tetapi memerlukan sokongan pelayan SMTP.
mata teras:
- Nodemailer adalah modul NPM yang paling biasa digunakan untuk aplikasi Node.js untuk menghantar e -mel.
- Oleh kerana enjin rendering yang berbeza dan sekatan pelanggan e -mel yang berbeza, ia mencabar untuk membuat mesej HTML yang serasi dengan pelbagai pelanggan. Alat dan sumber seperti templat pasang siap, alat reka bentuk, dan bahasa markup e -mel dapat memudahkan proses.
- Untuk memastikan kebolehpercayaan, disarankan untuk menghantar data mel ke barisan tugas dan bukannya menghantar mel terus ke dalam aplikasi Node.js. Dengan cara ini, pengguna boleh terus menggunakan aplikasi semasa memproses mesej.
- Gunakan modul seperti imapflow untuk membaca e -mel yang diterima dalam aplikasi Node.js, yang sangat berguna untuk pengendalian pendaftaran perkhidmatan, berhenti berlangganan, sokongan automasi, dll.
Hantar e -mel
Kebanyakan aplikasi web memerlukan menghantar e -mel seperti pendaftaran, tetapan semula kata laluan, laporan status, dan kempen pemasaran lengkap seperti surat berita dan promosi. Tutorial ini menerangkan cara menghantar e -mel dalam node.js, dan konsep dan cabaran juga digunakan untuk sistem lain.Anda boleh menemui banyak modul berkaitan e-mel pada npm. Yang paling popular adalah Nodemailer.
Menggunakan NodeMailer memerlukan pelayan SMTP untuk menghantar mel. Anda boleh menggunakan penyedia e -mel anda sendiri, tetapi demo ini menggunakan pelayan SMTP Ujian WPOVEN percuma.
- Buat projek:
mkdir emailtest cd emailtest
- Buat pakej.json:
{ "name": "emailtest", "type": "module", "main": "index.js", "dependencies": { "nodemailer": "^6.0.0" } }
- Memasang nodemailer:
npm install
- menulis index.js:
import nodemailer from 'nodemailer'; const transporter = nodemailer.createTransport({ host: 'smtp.freesmtpservers.com', port: 25 }); try { const send = await transporter.sendMail({ from: '"测试邮件" <test@email.com>', to: 'your_email@example.com', subject: '你好!', text: '你好,世界!', html: '<p>你好,世界!</p>', }); console.dir(send, { depth: null, color: true }); } catch (e) { console.dir(e, { depth: null, color: true }); }
to:
Selepas menjalankan kod, anda akan melihat hasil dengan 250 OK Response dan MessageId. Masukkan alamat e -mel anda di halaman pelayan SMTP Ujian WPOVEN, klik "Kotak Masuk Akses" untuk melihat "Hello!"
Asas Nodemailer
Untuk menghantar mel, anda mesti membuat objek NodeMailer
untuk menentukan jenis perkhidmatan. SMTP adalah yang paling biasa, tetapi perkhidmatan lain boleh didapati. ID Pengguna dan Kata Laluan Pengesahan biasanya diperlukan:
anda boleh menggunakan kaedahimport nodemailer from 'nodemailer'; const transporter = nodemailer.createTransport({ host: 'smtp.yourserver.com', port: 587, auth: { user: 'myid@yourserver.com', pass: 'my-password' }, });
sendMail()
const send = await transporter.sendMail({ from: '"测试邮件" <test@email.com>', to: 'someone@example.com, sometwo@example.com', cc: 'somethree@example.com', bcc: 'somefour@example.com', subject: '你好!', text: '纯文本邮件内容', html: '<p>HTML邮件内容</p>', });
Nodemailer menyediakan banyak pilihan mesej lain, tetapi yang paling biasa adalah lampiran. Pelbagai objek mentakrifkan nama dan kandungan fail. Contohnya: Hantar Perkhidmatan dan Senibina Asynchronous Semasa menghantar satu mel biasanya cepat, pelayan SMTP mungkin turun dan perlu mencuba lagi, atau mel mungkin terjebak di tengah -tengah penghantaran mel batch. Lebih baik menghantar data ke barisan tugas dan bukannya menghantar e -mel terus dalam aplikasi Node.js. Pengguna akhir boleh terus menggunakan aplikasi tanpa menunggu respons. Proses lain boleh memantau barisan mel, menghantar surat seterusnya, dan membalas item sekiranya berlaku kegagalan. Buat e -mel html HTML5 dan CSS3 berfungsi dengan baik dalam pelayar moden, tetapi tidak dalam pelanggan mel. Anda akan menghadapi masalah berikut: Menulis surat HTML secara manual adalah sukar. Alat dan sumber berikut disyorkan: Baca e -mel yang diterima Kebanyakan aplikasi hanya perlu menghantar e -mel, tetapi kadang -kadang anda mungkin perlu menyemak e -mel yang anda terima (seperti pendaftaran perkhidmatan, berhenti melanggan pemprosesan, sokongan automasi, dll.). Walaupun di luar skop tutorial ini, modul Node.js seperti IMAPFlow membolehkan aplikasi anda menyambung ke peti masuk IMAP, dapatkan e -mel dan respons proses: Kesimpulan Menghantar e -mel dari aplikasi web Node.js mudah, tetapi menghantar e -mel yang dipaparkan dengan betul, dijalankan dengan pasti dalam semua pelanggan mel tanpa menyebabkan masalah spam lebih sukar. Kami mengesyorkan agar anda bermula dengan e -mel teks biasa yang mudah. FAQ (bahagian FAQ yang panjang dari dokumen asal ditinggalkan di sini kerana masalah ini pada dasarnya dilindungi di atas. Jika perlu, anda boleh menambahkannya mengikut soalan -soalan tertentu.) Atas ialah kandungan terperinci Menghantar e -mel menggunakan node.js. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!mkdir emailtest
cd emailtest
{
"name": "emailtest",
"type": "module",
"main": "index.js",
"dependencies": {
"nodemailer": "^6.0.0"
}
}

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Soalan dan penyelesaian yang sering ditanya untuk percetakan tiket kertas terma depan dalam pembangunan front-end, percetakan tiket adalah keperluan umum. Walau bagaimanapun, banyak pemaju sedang melaksanakan ...

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Tidak ada gaji mutlak untuk pemaju Python dan JavaScript, bergantung kepada kemahiran dan keperluan industri. 1. Python boleh dibayar lebih banyak dalam sains data dan pembelajaran mesin. 2. JavaScript mempunyai permintaan yang besar dalam perkembangan depan dan stack penuh, dan gajinya juga cukup besar. 3. Faktor mempengaruhi termasuk pengalaman, lokasi geografi, saiz syarikat dan kemahiran khusus.

Pembelajaran JavaScript tidak sukar, tetapi ia mencabar. 1) Memahami konsep asas seperti pembolehubah, jenis data, fungsi, dan sebagainya. 2) Pengaturcaraan asynchronous tuan dan melaksanakannya melalui gelung acara. 3) Gunakan operasi DOM dan berjanji untuk mengendalikan permintaan tak segerak. 4) Elakkan kesilapan biasa dan gunakan teknik debugging. 5) Mengoptimumkan prestasi dan mengikuti amalan terbaik.

Perbincangan mengenai realisasi kesan animasi tatal dan elemen Parallax dalam artikel ini akan meneroka bagaimana untuk mencapai yang serupa dengan laman web rasmi Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ... ...

Bagaimana cara menggabungkan elemen array dengan ID yang sama ke dalam satu objek dalam JavaScript? Semasa memproses data, kita sering menghadapi keperluan untuk mempunyai id yang sama ...

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.

Perbincangan mendalam mengenai punca-punca utama perbezaan dalam output konsol.log. Artikel ini akan menganalisis perbezaan hasil output fungsi Console.log dalam sekeping kod dan menerangkan sebab -sebab di belakangnya. � ...
