簡體   English   中英

節點mandrill通過服務器發送郵件

[英]node-mandrill sending mail via server

這是關於正確使用node-mandrill的一個新手問題,很可能是關於節點本身的,因為我仍在嘗試學習它。 但是,由於我已經看到許多示例直接從客戶端使用mandrill的api密鑰並因此進行揭示,因此我想知道當服務時它到底有多有效,但此時卻卡住了:

我有一個提供公共文件夾的app.js ...

app.js

var express = require('express');
var mandrill = require('node-mandrill')(API_KEY); 
var app = express();
app.use(express.static('public'));
app.listen(PORT);

function sendEmail ( _name, _email, _subject, _message) {
    mandrill('/messages/send', {
        message: {
            to: 'EMAIL',
            from: [{email: _email , name: _name}],
            subject: _subject,
            text: _message
        }
    }, function(error, response){
        if (error) console.log( error );
        else console.log(response);
    });
}

...使用客戶端腳本從聯系表單收集信息並在單擊提交按鈕后發送電子郵件。

form.js

var contactForm = document.getElementById( 'contactForm' );
            new stepsForm( contactForm, {
                onSubmit : function( form ) {

                    // send email
                    var _subject = 'Contact Request';
                    var _email = contactForm.elements['q4'].value;
                    var _name = contactForm.elements['q5'].value;
                    var _message = contactForm.elements['q6'].value;

                    sendEmail(_name,_email,_subject,_message);

                }
            } );

您能告訴我什么缺失/錯誤嗎? 謝謝。

您不能從客戶端調用后端函數。 您可以使用Jquery進行Ajax調用,例如:

$(document).ready(function(){

      $('#contactForm').submit(function(event) {
        event.preventDefault();
        var _subject = 'Contact Request';
        var _email = contactForm.elements['q4'].value;
        var _name = contactForm.elements['q5'].value;
        var _message = contactForm.elements['q6'].value;

        $.ajax({
          url: '/sendEmail',
          method: 'post',
          contentType: 'application/json',
          data: JSON.stringify({ subject: _subject, email: _email}),
          success: function(res) {

          }
        })

      })

})

在您的后端:

// some lines skipped

app.post('/sendEmail', function(req, res) {

     //do your stuff
})

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM