c# - 无法使用ajax调用将值插入数据库

标签 c# jquery ajax web-services soap

我不知道为什么我在调用 ajax 方法时出错。 Web 服务工作正常。我在我的本地机器上托管并检查了 .非常感谢任何帮助。

网络服务代码:

public class Contacts : System.Web.Services.WebService
{

    [WebMethod]
    public void InsertIntoContacts(string name,string email,string message)
    {

        string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["KarthikDBConnString"].ConnectionString;
        MySqlConnection connection = new MySqlConnection(connectionString);
        MySqlCommand cmd = new MySqlCommand("Insert into contacts values(@name , @email , @message)");
        cmd.Connection = connection;
        cmd.CommandType = System.Data.CommandType.Text;
        cmd.Parameters.AddWithValue("@name", name);
        cmd.Parameters.AddWithValue("@email", email);
        cmd.Parameters.AddWithValue("@message", message);
        connection.Open();
        cmd.ExecuteNonQuery();
        connection.Close();
    }
}

表单的 html 标记是:

<form role="form" id="contactForm">
<div class="form-group">
    <label for="name">Name :</label>
    <input type="text" class="form-control" placeholder="Enter your Name" id="name" />
</div>
<div class="form-group">
    <label for="email">Email :</label>
    <input type="email" class="form-control" placeholder="Enter your Email here (optional)" id="email" />
</div>
<div class="form-group">
    <label for="message">Message :</label>
    <textarea class="form-control" rows="3" placeholder="Enter your message here" id="message"></textarea>
</div>
<div class="form-group">
    <button type="button" class="btn btn-primary" id="sendMsgBtn" onclick="javascript:SendMsg()">Send Message</button>
</div>
</form>

ajax 调用是:

    function SendMsg() {
    var soapRequset = '<?xml version="1.0" encoding="utf-8"?>\
<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">\
  <soap:Body>\
    <InsertIntoContacts xmlns="http://tempuri.org/">\
      <name>'+$("#name").val()+'</name>\
      <email>'+$("#email").val()+'</email>\
      <message>'+$("#message").val()+'</message>\
    </InsertIntoContacts>\
  </soap:Body>\
</soap:Envelope>';

    $.ajax({
        url: "host/contacts.asmx",
        type: "POST",
        data: soapRequset,
        contentType: "text/xml; charset=utf-8",
        dataType: "xml",
        processData: false,
        success: function (xData, status) { alert(status) },
        error: function (xData, status, req) {
              alert(xData.status);
              alert(status);
              alert(req);
    }
    });
}

最佳答案

关于c# - 无法使用ajax调用将值插入数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33063597/

相关文章:

javascript - 如何使用 jQuery ajax post 传递多个复选框

javascript - 如何在所有元素上仅触发一次toggle()?

c# - 单独刷新 ASP.NET MVC 中表中的每一行

php - Ajax鼠标悬停显示功能对齐

C# "label.text"字符串转整数

c# - 透明窗口上的wpf webbrowser

c# - O(1) 在使用替代比较器时保持在哈希集查找中?

c# - 如何实现双向多对多关系的关联类?

jquery - 滚动后定位元素在屏幕中间

PHP Laravel 同时执行多个 ajax 请求会出现 'encryption key' 服务器错误