2012-05-02 12 views
6

Mam usługę internetową, która powinna zwrócić 5 najlepszych e-maili w mojej skrzynce odbiorczej i wyświetlić je w siatce danych. Najpierw umieszczam moje dane w numerze DataTable. Ale ciągle dostaję błędyJak zwrócić datatable przez [WebMethod]

Oto mój kod, Czy brakuje mi czegoś lub oświadczam, że coś jest nie tak?

[WebMethod] 
    public DataTable DisplayMailList(String inMailServer, String inPort, bool inSSlCheck, String inUsername, String inPassword) 
    { 
     objClient.Connect(inMailServer, int.Parse(inPort), inSSlCheck); 
     objClient.Authenticate(inUsername, inPassword); 

     int count = objClient.GetMessageCount(); 

     DataTable dtMessages = new DataTable(); // Creating datatable. 
     dtMessages.Columns.Add("MessageNumber"); 
     dtMessages.Columns.Add("From"); 
     dtMessages.Columns.Add("Subject"); 
     dtMessages.Columns.Add("DateSent"); 
     dtMessages.TableName = "dtMessages"; 

     int counter = 0; 
     for (int i = count; i >= 1; i--) 
     { 
      OpenPop.Mime.Message msg = objClient.GetMessage(i); 

      dtMessages.Rows.Add(); 
      dtMessages.Rows[dtMessages.Rows.Count - 1]["MessageNumber"] = i; //Populateing Datatable 
      dtMessages.Rows[dtMessages.Rows.Count - 1]["Subject"] = msg.Headers.Subject; 
      dtMessages.Rows[dtMessages.Rows.Count - 1]["DateSent"] = msg.Headers.DateSent; 

      counter++; 
      if (counter > 5) 
      { 
       break; 
      } 
     } 
     return dtMessages; 
    } 

że problem jest publiczna DataTable miałem to uznane jako przedmiot, ale to nie działa eter .... ech, co należy zadeklarować ją jako?
jest to błąd ....

System.InvalidOperationException: Wystąpił błąd podczas generowania dokumentu XML. ---> System.InvalidOperationException: Nie można przekształcić do postaci szeregowej DataTable. Nazwa DataTable nie jest ustawiona.

+1

[WebMethod] musi być statyczny, twój błąd mówi, że nie ma przypisanej nazwy ... spróbuj przypisać nazwę (np. DataTable.TableName = "MyTable") również. – Zachary

+1

Na dłuższą metę będzie ci lepiej, jeśli przestaniesz używać datatables i będziesz używał obiektów silnie typowanych. –

Odpowiedz

12

Przypisanie wartości dtMessages.DataTable nazwa zatrzyma błąd serializacji, jak sugeruje komunikat o błędzie.

[WebMethod] 
    public DataTable GetDataTable() 
    { 
     DataTable dt = new DataTable(); 
     dt.Columns.Add("Col1", typeof(string)); 
     dt.Rows.Add("testing"); 
     dt.TableName = "Blah"; // <--- 
     return dt; 
    } 

Ale zgadzam się z Bobem Hornem, że lepiej jest zdefiniować klasę dla swojej wartości zwrotnej niż przy użyciu DataTable.

+1

To przy założeniu, że jest to Web.Method ASP.NET AJAX. Jeśli jest w klasycznej usłudze internetowej ASP.NET, to nie może być statyczne ... –

+0

Właściwie to czy jest to statyczne czy nie, klasyczna ASP czy nie, nie ma znaczenia dla tej odpowiedzi. Chodziło tylko o powiedzenie "Dodaj' dt.TableName = 'Blah'; '". Myślę, że twój komentarz jest rozpraszający. – vapcguy

+0

Mój komentarz był odpowiedzią na wcześniejszy komentarz, który został usunięty. Wcześniejsza uwaga dotyczyła faktu, że nie uwzględniłem słowa kluczowego "static" w metodzie signature. –

0

Ten pracował dla mnie:

w aplikacji

 public void app() 
     { 
     try 
     { 
      DataTable dtInput = new DataTable(); 
      DataRow drRow; 
      dtInput.Columns.Add("ID"); 
      dtInput.Columns.Add("Name"); 
      drRow = dtInput.NewRow(); 
      drRow["ID"] = 1; 
      drRow["Name"] = "Star"; 
      dtInput.Rows.Add(drRow); 
      dtInput.TableName = "Input";//Table name is mandatory to avoid serialization exception 
      DataTable dtOutput = new DataTable(); 
      dtOutput.TableName = "Output";//Table name is mandatory to avoid serialization exception 
      service.TestService(dtInput ,ref dtOutput); 
     } 
     catch (Exception ex) 
     { 
     } 
     } 

w usłudze

 DataTable dtOutput= new DataTable(); 
     [WebMethod] 
     public void TestService(DataTable dtInput , ref DataTable dtOutput) 
     { 
     DataRow drRow; 
     drRow= dtInput.NewRow(); 
     drRow["ID"] = 2; 
     drRow["Name"] = "Success"; 
     dtInput.Rows.Add(drRow); 
     dtOutput= dtInput; 
     } 
5

Wystarczy podać nazwę tabeli kiedy utworzyć DataTable obiektu

DataTable dt = new DataTable("tablename");