最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

Send Email Directly From JavaScript using EmailJS - Stack Overflow

programmeradmin0浏览0评论

Send Email Directly From JavaScript using EmailJS.

Please look the below answer and I'm getting so many ments for malicious attacks.. because this file is loading in browser so malicious user can easily get your key configuration. So, how to avoid it?

 var templateParams = {
    to_name: 'xyz',
    from_name: 'abc',
    message_html: 'Please Find out the attached file'
  };

  emailjs.send('YOUR_SERVICE_ID', 'YOUR_TEMPLATE_ID', templateParams)
    .then(function(response) {
      console.log('SUCCESS!', response.status, response.text);
    }, function(error) {
      console.log('FAILED...', error);
    });

Send Email Directly From JavaScript using EmailJS.

Please look the below answer and I'm getting so many ments for malicious attacks.. because this file is loading in browser so malicious user can easily get your key configuration. So, how to avoid it?

 var templateParams = {
    to_name: 'xyz',
    from_name: 'abc',
    message_html: 'Please Find out the attached file'
  };

  emailjs.send('YOUR_SERVICE_ID', 'YOUR_TEMPLATE_ID', templateParams)
    .then(function(response) {
      console.log('SUCCESS!', response.status, response.text);
    }, function(error) {
      console.log('FAILED...', error);
    });

Share Improve this question edited Nov 14, 2019 at 5:10 Prabhat asked Nov 10, 2019 at 18:22 PrabhatPrabhat 8021 gold badge10 silver badges23 bronze badges 2
  • What problem are you seeing when executing this code? – Mike Commented Nov 12, 2019 at 3:30
  • How to avoid malicious attacks? – Prabhat Commented Nov 12, 2019 at 5:37
Add a ment  | 

4 Answers 4

Reset to default 4

Hi you can directly send email through using EmailJS without using the server side code. It'll totally client side.

For sending you need to configure below details.

1)First,Go to this site [https://www.emailjs./] and create free account.

2)below 'Connect your email service' button click and configure. You'll get 'YOUR_SERVICE_ID'

3)Then 'Create email template' button click and configure. You'll get 'YOUR_TEMPLATE_ID'

4)click on 'Send email from JavaScript' button. You'll get code.

5)You'll get the 'YOUR_USER_ID' in [https://dashboard.emailjs./account]

I did all configuration and added code please check. below code.

NOTE : - "Please encrypted or embedded your use_id for malicious attacks."

<script type="text/javascript" src="https://cdn.jsdelivr/npm/[email protected]/dist/email.min.js">
</script>
<script type="text/javascript">
  (function() {
    emailjs.init("YOUR_USER_ID"); //please encrypted user id for malicious attacks
  })();
//set the parameter as per you template parameter[https://dashboard.emailjs./templates]
  var templateParams = {
    to_name: 'xyz',
    from_name: 'abc',
    message_html: 'Please Find out the attached file'
  };

  emailjs.send('YOUR_SERVICE_ID', 'YOUR_TEMPLATE_ID', templateParams)
    .then(function(response) {
      console.log('SUCCESS!', response.status, response.text);
    }, function(error) {
      console.log('FAILED...', error);
    });
</script>

Using JavaScript can expose your credentials like user id , service id to the public. For this , you can store these keys values in a variable (half value) and then manipulating it in runtime like appending remaining half of the key etc. But its not totally safe.

Code :

<html>
<head>
  <title>Contact Us</title>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link href="https://cdn.jsdelivr/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet">
  <script src="https://cdn.jsdelivr/npm/[email protected]/dist/js/bootstrap.bundle.min.js"></script>
  <script type="text/javascript" src="https://cdn.jsdelivr/npm/emailjs-@2/dist/email.min.js"></script>
</head>
<body>
  <div class="container">
    <div class="card col-md-6 offset-md-3" style="margin-top:50px;">
      <div class="card-body">
        <h2>Contact Us</h2>
        <label for="thename">Name</label>
        <input type="text" class="form-control" id="thename" placeholder="Enter Name">
        <label for="themail">Email:</label>
        <input type="email" class="form-control" id="themail" placeholder="Enter Email">
        <label for="themsg">Message</label>
        <textarea class="form-control" id="themsg" placeholder="Enter Message"></textarea>
        <button class="btn btn-danger btn-sm" style="margin-top:10px;" onCLick="sendemail();">Send</button>
        </form>
      </div>
    </div>
  </div>
  <script>
    function sendemail() {
      var userid = "YourUserID"
      emailjs.init(userid);
      var thename = document.getElementById('thename').value;
      var themail = document.getElementById('themail').value;
      var themsg = document.getElementById('themsg').value;
      var validmail = /^w+([.-]?w+)*@w+([.-]?w+)*(.w{2,3})+$/;
      if (thename == "") {
        alert("Please Enter Name");
      }
      else if (themail == "" || themail.match(!validmail)) {
        alert("Please Enter Valid Email");
      }

      else if (themsg == "") {
        alert("Please Enter Message");
      }
      else {
        var contactdetail = {
          from_name: thename,
          from_email: themail,
          message: themsg
        };

        emailjs.send('YourServiceID', 'YourTemplateID', contactdetail).then(function (res) {
          alert("Email Sent Successfully");
        },
          reason => {
            alert("Error Occur");
          })
      }
    }
  </script>
</body>
</html>

Make sure to replace "YourUserID" , "YourServiceID" & "YourTemplateID" with your own ids

Reference : Narendra Dwivedi - Send Email From JavaScript

<script type="text/javascript" src="https://cdn.jsdelivr/npm/[email protected]/dist/email.min.js">
</script>
<script type="text/javascript">
  (function() {
    emailjs.init("service_ud48moz"); //please encrypted user id for malicious attacks
  })();
//set the parameter as per you template parameter[https://dashboard.emailjs./templates]
  var templateParams = {
    to_name: 'xyz',
    from_name: 'abc',
    message_html: 'Please Find out the attached file'
  };

  emailjs.send('service_ud48moz', 'template_njhhxon', templateParams)
    .then(function(response) {
      console.log('SUCCESS!', response.status, response.text);
    }, function(error) {
      console.log('FAILED...', error);
    });
</script>

Set a constant in the EmailJS dashboard, go to your template https://dashboard.emailjs./admin/templates, select a template, On your right where there is "To Email" add {{to_email}}

Node code

emailjs
.send(SERVICE_ID, TEMPLATE_ID, {
    to_email : "[email protected]",
    name: "Nania"
 }, {
  publicKey: PUBLIC_KEY,
  privateKey: PRIVATE_KEY,
})
.then(
  (response) => {
    console.log("Email SUCCESS!", response.status, response.text);
  },
  (err) => {
    console.log("Email FAILED...", err);
  }
);
发布评论

评论列表(0)

  1. 暂无评论