Avatar billede repsak Nybegynder
15. december 2005 - 09:43 Der er 7 kommentarer og
1 løsning

Modtage csv format

Hej,

Jeg skal lave en hjemmeside (asp.net 1.1) hvor brugeren kan se noget data fra en tabel i en database - en personoversigt.

Jeg ønsker nu at man kan kalde min side med to forskellige parametre:
default.aspx?output=xml
default.aspx?output=csv

således skal et kald til den første KUN returnere data på xmlform (ingen GUI) og et kald til den anden = KUN csv form - ingen HTML.

Hvilken løsningsmodel kan jeg med fordel benytte? Det er meningen at andre hjemmesider skal kunne kalde fx default.aspx?output=csv og kunne læse og parse data så de kan vises i modtagerens GUI.
Min første tanke var at løse xml som en webservice, men den går jo ikke til min csv-model, da jeg på ingen måde vil modtage andet end ren CSV her
Avatar billede arne_v Ekspert
15. december 2005 - 15:22 #1
en web service metode som returnerer en string kunne da godt returnere CSV

set fra en web service client på app level ville man kun se CSV'en

at den CSV var pakket ind i XML under transport gør vel ikke noget
Avatar billede arne_v Ekspert
15. december 2005 - 15:23 #2
du kan prøve om du kan outputte CSV direkte i ASP.NET - jeg har aldrig prøvet,
men jeg ved fra andre af den slags at det er svært at undgå blanke linier og mellemrum
Avatar billede Slettet bruger
17. december 2005 - 08:15 #3
Med hensyn til csv har jeg være på nogle løsninger med denne model. Det vi har gjort er helt simpelt efter den Britiske hærs slogan Keep It Simple Stupid ;)

Sæt ContentType på til text/plain, skriv til så de enkelte lininer til Response.OutputStream

finished ;)

Det samme kan du jo gøre med XML sæt text/xml og skriv text svarende til det XMl dokument du ønsker at afleverer.

Hvis du vil en Web service, hvilket IMHO ikke er nødvendigt til den slags her så skal du ikke blande dem på samme URL.
Avatar billede repsak Nybegynder
19. december 2005 - 09:42 #4
Tak for input. Jeg vil lige eksperimentere med det :)
Avatar billede repsak Nybegynder
19. december 2005 - 12:56 #5
Response.ContentType = "text/plain";
byte[] b = Encoding.Default.GetBytes(sb.ToString());
Response.OutputStream.Write(b, 0, b.Length);

virker fint.

Hvordan 'samler' jeg det op fra en anden aspx side i .NET?
noget ala
HttpRequest r = new HttpRequest("WebForm2.aspx", ".", "output=csv");
måske? Eller hvordan?
Avatar billede Slettet bruger
19. december 2005 - 12:59 #6
Check WebRequest.Create("url");
Avatar billede repsak Nybegynder
19. december 2005 - 13:37 #7
Supér. Læg et svar kryptos :)
Avatar billede Slettet bruger
19. december 2005 - 13:39 #8
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester