我无法使用ajax通过Web服务在我的数据库中删除或插入数据

时间:2013-01-02 13:15:34

标签: java ajax postgresql

这是我的test_database.html页面

<html>
<head> 
<title> <h1> Database Test </h1> </title>
<script>

    var xmlhttp;
    if (window.XMLHttpRequest) 
    {
        xmlhttp = new XMLHttpRequest();
    } else 
    {
        xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    }
    function loadXMLDoc()
    {
        xmlhttp.onreadystatechange = function() 
        {
            if (xmlhttp.readyState==4 && xmlhttp.status==200) 
            {
                var xmlObj = xmlhttp.responseXML;

                var textXML = xmlObj.documentElement.firstChild.firstChild.nodeValue;


                if (window.DOMParser)
                {
                    parser=new DOMParser();
                    var xmlDoc=parser.parseFromString(textXML,"text/xml");
                }
                else // Internet Explorer
                {
                    var xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
                    xmlDoc.async=false;
                    xmlDoc.loadXML(textXML);
                }   
                var rows = xmlDoc.getElementsByTagName("row");
                mybody=document.getElementsByTagName("body")[0];
                mytable=document.createElement("table");
                mytablebody=document.createElement("tbody");
                //alert(cols.length);
                for(var i=0; i<rows.length; i++)
                {   mycurrent_row=document.createElement("tr"); 
                    var cols=rows[i].getElementsByTagName("colunm");

                   for(var j=0; j<cols.length; j++) 
                    {     mycurrentcell=document.createElement("td");  
                          currenttext=document.createTextNode(cols[j].getAttribute("colvalue"))
                          mycurrentcell.appendChild(currenttext);
                          mycurrent_row.appendChild(mycurrentcell);  
                     }  
                                     mycurrent_row.id=cols[0].getAttribute("colvalue");
                         mybutoncell = document.createElement("td");
                         but=document.createElement("input");
                         but.type="button";
                         mybutoncell.appendChild(but);                                      
                         mycurrent_row.appendChild(mybutoncell); 
                         mytablebody.appendChild(mycurrent_row);
                         but.onclick=ajaxDBDelete;
                }
                mytable.appendChild(mytablebody);
                mybody.appendChild(mytable);
                 mytable.setAttribute("border","2");    
            }
        }
        xmlhttp.open("GET","http://127.0.0.1:8080/axis2/services/database_tmm_man/SelectFromDB?",true);
        xmlhttp.send();

    }       
    function ajaxDBInsert ()
    { 
     var textvalue= document.getElementById('txbegn').value
       var xml="<university><student>";
       xml+="<egn>" +textvalue+ "</egn>";
       xml+="<fname>" + document.getElementById('txbfname').value + "</fname>";
       xml+="<mname>" + document.getElementById('txbmidname').value + "</mname>" ;
       xml+="<lname>" + document.getElementById('txblname').value + "</lname>";
       xml+="<telnum>" + document.getElementById ('txbtelnum').value + "</telnum>";
       xml+="</student></university>";

    alert(xml);
    var tranXml = escape(xml); 
    alert(tranXml);

        var url = "localhost/services/database_tmm_man/InsertInto?";
        var params = "data=" + tranXml;
        xmlhttp.open("POST", url, true);
        xmlhttp.send(params);   


    }

    function ajaxDBDelete()
    {
          var par=this.parentNode;
          while(par.nodeName.toLowerCase()!='tr')
          {
              par=par.parentNode;
          }
          alert (par.id);
         var delid="<university><student>";
         delid+= "<egn>" + par.id + "</egn>";
         delid+= "</student></university>";
         alert(delid);
         var tranDelid = escape(delid);
         alert (tranDelid);

        var url = "http://127.0.0.1:8080/axis2/services/database_tmm_man/DeleteFromDB?";
        var params = "deleteID=" + tranDelid;
        xmlhttp.open("POST", url, true);
        xmlhttp.send(params);   
    }
    </script>
</head>

<body onload="loadXMLDoc();">

EGN:                  <input type="text" id="txbegn"/><br>
FIRST NAME:           <input type="text" id="txbfname"/><br>
MIDDLE NAME:          <input type="text" id="txbmidname"/><br>
LAST NAME:            <input type="text" id="txblname"/><br>
Telephone Number:     <input type="text" id="txbtelnum"/><br>
<br>
<br>
<button type="button" name="btnInsert" onClick="ajaaclxDBInsert();">INSERT</button>
<br>
<br>
</body>
</html>

这是我服务的代码

package gismo;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.net.URLDecoder;
import java.sql.*;

import javax.xml.parsers.*; 

import org.w3c.dom.*;
import org.xml.sax.InputSource;


public class database_tmm_man 

{

    Connection conn= null;
    String strEgnin;
    String strFname;
    String strMname;
    String strLname;
    String strNumtel;
    String strEgndel;

public String SelectFromDB()
{

    String strXml = "<response>";


        try {
            Class.forName("org.postgresql.Driver");
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        try 
        {
            conn= DriverManager.getConnection("jdbc:postgresql://127.0.0.1:5432/plovdivbizlocator", "postgres", "********");
        } 

        catch (SQLException ex) 
        {

            ex.printStackTrace();
        }

        Statement mystmt = null;
        String selectQuery = "SELECT egn, firstname, middlename, lastname,telnumber FROM tanya_students";
        try 
        {
            mystmt = conn.createStatement();
            ResultSet mysr = mystmt.executeQuery(selectQuery);  

            ResultSetMetaData rsmd = mysr.getMetaData(); 
            int colCount = rsmd.getColumnCount();
                int numberrow=0;

            strXml += "<rows>";
            while (mysr.next())
            {  
                strXml += "<row id= '"+numberrow +"'>";
                for (int i=1;i<=colCount;i++) 
                {
                    String elementname = rsmd.getColumnName(i);
                    String elementValue=mysr.getString(i);
                    strXml += "<colunm colname='"+elementname+"' colvalue='"+elementValue+"'/>";
                }                   
                numberrow++;
                strXml +="</row>";
            }
            strXml += "</rows>";                

        }
        catch(Exception ex)
        {}
        strXml+="</response>";

        return strXml;


}


public String InsertIntoDB (String data) throws ClassNotFoundException
{

    try
        {   String strDecodedData = URLDecoder.decode(data);
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
            Document doc = dbBuilder.parse(new InputSource(new ByteArrayInputStream(strDecodedData.getBytes("utf-8"))));
            doc.getDocumentElement().normalize();

            NodeList nList = doc.getElementsByTagName("student");
            int num=nList.getLength();
            for (int i=0;i<num;i++)
                        {       
                            Element section=(Element)nList.item(i);                     
                            strEgnin = section.getElementsByTagName("egn").item(0).getChildNodes().item(0).getNodeValue();              
                            strFname = section.getElementsByTagName("fname").item(0).getChildNodes().item(0).getNodeValue();             
                            strMname = section.getElementsByTagName("mname").item(0).getChildNodes().item(0).getNodeValue();            
                            strLname = section.getElementsByTagName("lname").item(0).getChildNodes().item(0).getNodeValue();                
                            strNumtel =section.getElementsByTagName("telnum").item(0).getChildNodes().item(0).getNodeValue();

                        }
        }

    catch (Exception ex1)
         {

         }

    Connection conn= null;

    Class.forName("org.postgresql.Driver");
    try 
    {
        conn= DriverManager.getConnection("jdbc:postgresql:/127.0.0.1:5432/plovdivbizlocator", "postgres", "********");
    } 

    catch (SQLException ex) 
        {

            ex.printStackTrace();
        }

    PreparedStatement pstmt = null;
    String insertQuery= "insert into tanya_students (egn, firstname, middlename, lastname, telnumber)";
    insertQuery +="values (?, ?, ?, ?, ?)";
    try
        {
            pstmt=conn.prepareStatement(insertQuery);
            pstmt.setString(1,strEgnin);
            pstmt.setString(2,strFname);
            pstmt.setString(3,strMname);
            pstmt.setString(4,strLname);
            pstmt.setString(5,strNumtel);
            pstmt.executeUpdate();
        }

    catch (Exception ex)
        {

        }

    return "" ;
}
public String DeleteFromDB(String deleteID) 
{
    try
    {   String strDecodeddelID = URLDecoder.decode(deleteID);
        DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
        DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
        Document doc = dbBuilder.parse(new InputSource(new ByteArrayInputStream(strDecodeddelID.getBytes("utf-8"))));
        doc.getDocumentElement().normalize();

        NodeList nList = doc.getElementsByTagName("student");
        int num=nList.getLength();
        for (int i=0;i<num;i++)
                    {       
                        Element section=(Element)nList.item(i);                     
                        strEgndel = section.getElementsByTagName("egn").item(0).getChildNodes().item(0).getNodeValue();                 


                    }
    }

catch (Exception ex1)
     {

     }






  Connection conn= null;

    try 
    {
        Class.forName("org.postgresql.Driver");
    } 

    catch (ClassNotFoundException e) 
    {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

    try 
    {
        conn= DriverManager.getConnection("jdbc:postgresql:/127.0.0.1:5432/plovdivbizlocator", "postgres", "********");
    } 

    catch (SQLException ex) 
        {

            ex.printStackTrace();
        }

    PreparedStatement delstmt = null;
    String delQuery= "DELETE FROM tanya_students WHERE egn= ?";
    try
        {
            delstmt=conn.prepareStatement(delQuery);
            delstmt.setString(1,strEgndel);
            delstmt.executeUpdate();
        }

    catch (Exception ex)
        {

        }

    return "" ;

}




}

当我尝试删除记录时,当我点击每行末尾的按钮时,没有任何反应。提及我选择我的row.id可能是有用的。我的数据库的第一列 - egn是唯一的(没有人有相同的egn)。这就是我将这个egn发送到服务器和我的web服务的原因 在无效的主程序中,everythins的工作非常完美@ \所以我认为不知何故我没有正确地将数据发送到我的服务器

与插入相同 - 当我在文本框中键入一些我要插入数据库的数据时,当我单击插入按钮时没有任何反应 感谢您的帮助

1 个答案:

答案 0 :(得分:0)

您确定您的Ajax通话是正确的还是根本没有?既然您正在使用原始Javascript构建调用,您是否已在多个浏览器中对其进行了测试?有一些很好的Chrome扩展允许您手动构建REST调用,以测试Web服务是否在浏览器文档上下文之外正常工作。 (我使用的是名为Graphic HHTP客户端的程序,但我认为它只适用于Mac)。

这样做至少可以帮助您确定问题是服务器端还是客户端。