Rumah > pembangunan bahagian belakang > tutorial php > E -mel paip ke aplikasi Laravel

E -mel paip ke aplikasi Laravel

Joseph Gordon-Levitt
Lepaskan: 2025-02-22 10:34:10
asal
599 orang telah melayarinya

Piping Emails to a Laravel Application

mata teras

    alat perintah baris Laravel boleh dilanjutkan untuk menerima mel mentah dan menggunakannya dalam permohonan anda. Ini melibatkan membuat arahan baru, seperti
  • , yang boleh didaftarkan dan dilaksanakan di Artisan untuk mengambil mesej asal dari aliran IO. php artisan email:parse
  • Gunakan
  • dan lain -lain untuk menyelesaikan mesej asal ke bahagian yang berasingan. Ini membolehkan pengambilan tajuk seperti subjek dan badan e -mel. Mel yang dihuraikan kemudiannya boleh disimpan dengan mudah dalam pangkalan data. php-mime-mail-parser
  • Tetapan ini juga boleh mengendalikan sebarang lampiran dalam mesej. Selepas mengambil lampiran, anda boleh membuat objek sistem fail untuk menyimpan fail pada pelayan. Di samping itu, bergantung kepada alat atau pelayan mel yang digunakan, kaedah yang berbeza boleh digunakan untuk menghantar mel ke aplikasi.

Pengenalan

anda akan melihatnya selalunya dalam pengurusan projek atau alat pengurusan sokongan: Anda boleh membalas e -mel dan ia akan muncul secara automatik dalam aplikasi web anda. Alat ini dapat mengimport e -mel ini terus ke dalam sistem mereka.

Dalam artikel ini, kami akan belajar bagaimana untuk menghantar e -mel ke aplikasi Laravel 4 kami. Untuk melakukan ini, kami memulakan dengan projek baru Laravel 4 yang dipasang melalui komposer seperti yang ditunjukkan di bawah.

composer create-project laravel/laravel your-project-name --prefer-dist
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Buat perintah artisan

Untuk dapat mengimport e -mel ke dalam permohonan kami, kami mesti menghantar e -mel kepada permohonan kami melalui baris arahan. Nasib baik, Laravel mempunyai alat baris arahan yang dipanggil Artisan yang mampu melaksanakan pelbagai tugas. Untuk melihat senarai semua tugas yang boleh dijalankan oleh Artisan, anda boleh menjalankan

dalam direktori akar projek anda. php artisan list

Dalam kes ini, kami mahu melaksanakan tugas yang sangat spesifik: Terima e -mel asal dan gunakannya dalam permohonan kami. Malangnya, ini bukan salah satu ciri asas Artisan boleh mengendalikan. Kita boleh dengan mudah melanjutkannya dengan arahan baru:

. Kami kemudian akan memulakan Artisan dan melaksanakan tugas tertentu, yang dipanggil php artisan email:parse dalam kes ini. email:parse

Langkah pertama kami adalah untuk membuat arahan ini. Anda boleh membuat arahan baru melalui arahan Artisan sendiri untuk membuat arahan baru. Cukup jalankan arahan berikut dalam direktori root projek:

php artisan command:make EmailParserCommand
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Jika semuanya berjalan lancar, anda kini akan mencari fail bernama

dalam direktori app/commands. Buka di editor kegemaran anda dan lihat sifat EmailParserCommand.php dan $name. Kita boleh menyesuaikannya seperti yang diperlukan. Dengan memberikan nama dan keterangan yang jelas, arahan akan disenaraikan dengan baik dalam senarai arahan Artisan. $description Contohnya, saya mengubahnya kepada ini:

/**
 * 控制台命令名称。
 *
 * @var string
 */
protected $name = 'email:parse';

/**
 * 控制台命令描述。
 *
 * @var string
 */
protected $description = '解析传入的电子邮件。';
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Perintah mendaftar

Apabila kami menjalankan php artisan email:parse dalam akar projek kami, anda akan menerima mesej yang menyatakan bahawa arahan ini belum didaftarkan. Langkah seterusnya ialah memastikan arahan ini didaftarkan di Artisan. Mari buka fail app/start/artisan.php dan tambahkan Artisan::add(new EmailParserCommand); ke akhir fail untuk mendaftarkan arahan yang baru dibuat. Kita kini boleh menjalankan perintah list sekali lagi untuk melihat perintah email:parse yang kami disenaraikan. Sila ambil perhatian bahawa nama dan keterangan yang anda isi akan dipaparkan di sini.

Dapatkan e -mel asal

Setiap kali arahan dipanggil melalui Artisan, ia selalu memanggil kaedah fire. Jadi pada mulanya kita perlu menambah parsing e -mel kami di sini. E -mel kini sedang dalam aliran IO kami dan kami boleh mengambilnya dari php://stdin. Kami membuka aliran IO ini dan mengumpul sedikit e -mel sehingga kami membaca keseluruhan aliran.

composer create-project laravel/laravel your-project-name --prefer-dist
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

e -mel yang dihantar ke perintah artisan kami kini terletak di pembolehubah $rawEmail. Ia adalah keseluruhan e -mel, yang mengandungi tajuk, badan dan sebarang lampiran.

Jadual e -mel

Kami kini mempunyai e -mel asal, tetapi saya lebih suka memecah e -mel ke beberapa bahagian. Saya mahu mengambil tajuk seperti topik dan badan e -mel. Kita boleh menulis kod kita sendiri untuk memecah semua bahagian ini, tetapi seseorang telah membuat pakej yang boleh kita gunakan dalam aplikasi kita. Pakej ini dapat membahagikan keseluruhan e -mel kami ke bahagian logik. Tambahkan baris berikut ke fail composer.json anda dan jalankan composer update

php artisan command:make EmailParserCommand
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Sekarang kita perlu pastikan kita benar -benar boleh menggunakan pakej ini dalam perintah kita, jadi kita membuka app/command/EmailParserCommand.php kita sekali lagi dan menambah baris berikut ke bahagian atas:

/**
 * 控制台命令名称。
 *
 * @var string
 */
protected $name = 'email:parse';

/**
 * 控制台命令描述。
 *
 * @var string
 */
protected $description = '解析传入的电子邮件。';
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Sekarang kita boleh menghuraikan e -mel asal ke bahagian berasingan. Tambah baris kod berikut ke hujung kaedah fire.

/**
 * 执行控制台命令。
 *
 * @return void
 */
public function fire()
{
    // 从 stdin 读取
    $fd = fopen("php://stdin", "r");
    $rawEmail = "";
    while (!feof($fd)) {
        $rawEmail .= fread($fd, 1024);
    }
    fclose($fd);
}
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

kita mula -mula membuat parser baru. Seterusnya, kami menetapkan e -mel asal ke teks parser, dan akhirnya, kami memanggil pelbagai kaedah yang berbeza untuk mendapatkan data dari tajuk atau badan.

Anda kini boleh menyimpan e -mel dengan mudah dalam pangkalan data anda. Sebagai contoh, jika anda mempunyai entiti e -mel, anda boleh menyimpan e -mel ke pangkalan data anda seperti ini:

"messaged/php-mime-mail-parser": "dev-master"
Salin selepas log masuk
Salin selepas log masuk

Lampiran pemprosesan

anda mungkin mahu menyimpan sebarang lampiran yang dilampirkan pada e -mel anda pada pelayan anda. Kelas parser e -mel boleh mengendalikan sebarang lampiran yang tersedia. Pertama, tambahkan baris berikut sekali lagi ke bahagian atas kelas app/command/EmailParserCommand.php.

use MimeMailParser\Parser;
Salin selepas log masuk
Salin selepas log masuk

Sekarang kita perlu memperluaskan kaedah fire kita:

composer create-project laravel/laravel your-project-name --prefer-dist
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

mari kita lihat apa sebenarnya bahagian ini. Baris pertama mengambil lampiran dari e -mel. $attachments Pembolehubah adalah pelbagai objek lampiran. Seterusnya, kami pastikan untuk membuat objek sistem fail baru yang akan mengendalikan menyimpan fail pada pelayan kami. Kemudian kita mula melangkah ke atas semua lampiran. Kami memanggil kaedah put objek sistem fail, yang menerima laluan dan kandungan fail. Dalam kes ini, kami mahu menambah fail ke direktori public/uploads dan menggunakan nama fail yang sebenarnya ada. Parameter kedua ialah kandungan fail sebenar.

itu sahaja! Fail anda kini disimpan dalam public/uploads. Hanya pastikan pelayan mel anda sebenarnya boleh menambah fail ke direktori ini dengan menetapkan keizinan yang betul.

Konfigurasikan pelayan mel kami

Setakat ini, kami telah menyediakan keseluruhan aplikasi untuk mendapatkan, memecah dan menyimpan e -mel kami. Walau bagaimanapun, jika anda tidak tahu bagaimana untuk menghantar e -mel kepada perintah artisan yang baru dibuat, kod ini tidak berguna.

Di bawah ini anda akan menemui cara yang berbeza untuk menghantar e -mel ke aplikasi anda, bergantung pada alat atau pelayan mel yang anda gunakan. Sebagai contoh, saya ingin meneruskan support@peternijssen.nl ke aplikasi saya, yang terletak di /var/www/supportcenter. Perhatikan bahawa dalam arahan sebenar yang akan anda lihat di bawah, saya menambah --env=local setiap kali untuk memastikan artisan berjalan seperti yang kita lakukan pada mesin pembangunan. Jika anda berada dalam persekitaran pengeluaran, anda boleh memadamkan bahagian ini.

cPanel

Jika anda menggunakan cPanel, anda boleh mengklik pada forwarder dalam menu umum. Tambahkan pengiriman baru dan tentukan alamat yang anda mahu hantar ke permohonan anda. Klik Tetapan Lanjutan dan pilih pilihan Program Pipa ke Program. Dalam medan input, anda boleh memasukkan baris berikut:

php artisan command:make EmailParserCommand
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Perhatikan bahawa cPanel menggunakan jalan berbanding direktori rumah anda.

exim

Jika pada EXIM, buka fail /etc/valiases/peternijssen.nl. Pastikan baris berikut wujud dalam fail ini:

/**
 * 控制台命令名称。
 *
 * @var string
 */
protected $name = 'email:parse';

/**
 * 控制台命令描述。
 *
 * @var string
 */
protected $description = '解析传入的电子邮件。';
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Run newaliases untuk membina semula pangkalan data alias.

Postfix

pada postfix, pastikan bahawa sebelum meneruskan, baris berikut wujud dalam fail /etc/postfix/main.cf anda dan tidak mengulas:

/**
 * 执行控制台命令。
 *
 * @return void
 */
public function fire()
{
    // 从 stdin 读取
    $fd = fopen("php://stdin", "r");
    $rawEmail = "";
    while (!feof($fd)) {
        $rawEmail .= fread($fd, 1024);
    }
    fclose($fd);
}
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Jika anda perlu menukar fail, tambah semula postfix dengan menjalankan service postfix reload.

kita kini boleh membuat alias baru yang akan diserahkan kepada permohonan kami. Buka /etc/aliases dan tambahkan baris berikut:

"messaged/php-mime-mail-parser": "dev-master"
Salin selepas log masuk
Salin selepas log masuk

Run newaliases untuk membina semula pangkalan data alias.

sendmail

dengan sendmail, anda harus terlebih dahulu membuat alias dalam fail /etc/aliases:

use MimeMailParser\Parser;
Salin selepas log masuk
Salin selepas log masuk

Run newaliases untuk membina semula pangkalan data alias. Seterusnya, pastikan chmod fail artisan adalah 755 supaya ia dapat dilaksanakan.

Akhirnya, symlink fail artisan dan php sendiri untuk /etc/smrsh

composer create-project laravel/laravel your-project-name --prefer-dist
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

qmail

Bergantung pada pemasangan anda, anda mesti memastikan bahawa fail berikut wujud:

php artisan command:make EmailParserCommand
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

atau:

/**
 * 控制台命令名称。
 *
 * @var string
 */
protected $name = 'email:parse';

/**
 * 控制台命令描述。
 *
 * @var string
 */
protected $description = '解析传入的电子邮件。';
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Buka sebarang fail dan tambahkan baris berikut sebagai kandungan:

/**
 * 执行控制台命令。
 *
 * @return void
 */
public function fire()
{
    // 从 stdin 读取
    $fd = fopen("php://stdin", "r");
    $rawEmail = "";
    while (!feof($fd)) {
        $rawEmail .= fread($fd, 1024);
    }
    fclose($fd);
}
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Kesimpulan

Mana -mana rangka kerja dengan alat baris perintah yang tersedia dapat memproses e -mel anda. Kod yang disediakan di sini hanyalah persediaan asas. Bergantung pada projek anda, anda mungkin hanya mahu membenarkan alamat e -mel tertentu untuk menghantar e -mel ke aplikasi anda. Sebelum lulus ke aplikasi anda, pastikan anda telah menapis e -mel anda dalam alat seperti Postfix.

Jika anda ingin menggunakan beberapa jenis sistem tiket, anda boleh dengan mudah cuba mengekstrak ID tiket sokongan dari subjek e -mel dan melakukan pelbagai tindakan yang berbeza pada e -mel berdasarkan ID itu.

Perhatikan fail log pelayan mel. Ia memberi anda beberapa petua apabila saluran paip sebenar gagal dalam cara menyelesaikannya.

(disebabkan oleh batasan ruang, sebahagian daripada Soalan Lazim ditinggalkan. Kandungan Soalan Lazim asal lemah berkaitan dengan topik artikel, dan beberapa kandungan diduplikasi dengan kandungan artikel, jadi tidak ada pseudo -Prossifikasi Original dilakukan.)

Atas ialah kandungan terperinci E -mel paip ke aplikasi Laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan