Search code examples
javascriptasp.netajaxweb-serviceswebmethod

Call ASP.NET web service method from JavaScript


I have the web service:

[WebMethod]
public void SendMail(string _name, string _email, string _message)
{
    //Create Mail Message Object with content that you want to send with mail.
    MailMessage MyMailMessage = new MailMessage("gglebati@example.com", "gglebati@example.com", "This is the mail subject", "Just wanted to say Hello");

    MyMailMessage.IsBodyHtml = false;

    //Proper Authentication Details need to be passed when sending email from gmail
    NetworkCredential mailAuthentication = new NetworkCredential("myxxxxx@gmail.com", "xxxxxxxxx");

    //Smtp Mail server of Gmail is "smpt.gmail.com" and it uses port no. 587
    //For different server like yahoo this details changes and you can
    //get it from respective server.
   SmtpClient mailClient = new SmtpClient("smtp.gmail.com", 587);

    //Enable SSL
    mailClient.EnableSsl = true;
    mailClient.UseDefaultCredentials = false;
    mailClient.Credentials = mailAuthentication;

    mailClient.Send(MyMailMessage);
}

and i have a html page. How can i call this function from my html page? (This function must send the message to email)


Solution

  • Use jQuery library. It makes ajax calls piece a cake. Then follow these items:

    1. Add an HTML button to your page, so that people can start the ajax process by clicking it
    2. Use jQuery to hook into the click event of that button (or span, or a div, or anything else)
    3. Make sure you have ScriptService attribute on your web service (this attribute means that you can call your service from JavaScript)
    4. Send items to your web service method

       $('#buttonId').click(function(){
           // Validating input
           $.ajax({
              type: 'POST',
              url: '/your-web-service-path.asmx/your-method-name',
              data: {} 
              dataType: 'json',
              contentType: 'application/json; charset=utf-8',
              success: function(r){},
              error: function(e){}
           });
      });
      

    Just note that you have to make a JSON object out of your parameters and the name of the JSON properties should match the name of the web service parameters. Also note that the return value of the web service would be available to you as r.d object passed to success callback of ajax call.