Developpez.com - Rubrique Android

Le Club des Développeurs et IT Pro

Accéder aux services Web via Android

Par acesyde

Le 2012-11-29 11:23:46, par Feanorin, Expert éminent
Bonjour,

acesyde vous présente un nouveau tutoriel intitulé:

Accéder aux services Web via Android
http://Acesyde.developpez.com/tutoriels/android/web-services-android/


Ce tutoriel a pour but de vous présenter l'utilisation des services Web sous Android.
Bonne lecture.
  Discussion forum
8 commentaires
  • nicroman
    Expert éminent
    Envoyé par DrSnake
    Salut, une petite remarque : sauf modification récente, il me semblait que sous Android et ce depuis la version 3.x, il était impossible de faire une requête vers l'extérieur (réseau) sans threader
    Non c'était déjà interdit dans Android 1.x, mais comme certains développeurs ne comprenaient pas comment fonctionnent une UI (ou s'en foutaient royalement), à partir de 3.0 le système a commencé à émettre des exceptions... (un peu comme sur Windows, ou les programmes écrivaient leurs données dans program files).
    Le StrictMode est une catastrophe de programmation et permet juste de remplacer le "application closed" par un éventuel "ANR" (à mon avis pire encore que le forced-closed, il n'y a rien de plus gavant qu'un téléphone qui ne réponde pas).
  • nicroman
    Expert éminent
    Salut !
    Voila un tutoriel qui manquait...

    Juste quelques remarques en vrac:
    • Non gestion de l'encoding de la réponse (en particulier le charset). Quid de UTF-8 ?
    • Disparition complète de la dernière exception après un Log.e, il faudrait passer l'exception en paramètre. A ce sujet, le return null pour signifier à l'appelant de getPoints() qu'une erreur est survenue est un peu trop léger... mais bon pourquoi pas.
    • L'InputStream n'est pas correctement géré (c'est une ressource, donc avoir son try { } finally { } en attendant Java7 et le try-with).
    • Dans certains cas (réponse en 401 par exemple), InputStream est null, il n' y a aucune raison du pourquoi ou du comment. Aucune exception n'est levée. sendRequest() et getPoints() retournent simplement null.
    • Seule une réponse 200 est acceptée... quid des réponses 201, 202, ... ?
    • La fonction sendRequest() envoie des "Exception", n'est-ce pas un peu "large" ? IOException serait plus approprié non ?
  • DrSnake
    Membre du Club
    Salut, une petite remarque : sauf modification récente, il me semblait que sous Android et ce depuis la version 3.x, il était impossible de faire une requête vers l'extérieur (réseau) sans threader la procédure ou sans utiliser le StrictMode (à destination des développeurs), ce qui est compréhensible en terme de séparation du rendu écran et des process en arrière plan qui, dans le cas de l'accès à un webservice, peuvent prendre du temps. Si c'est toujours le cas, il me semble que ce serait une bonne chose d'y faire référence, si ce n'est de modifier les sources présentées, qui correspondent à du code Java, n'ayant implicitement rien à voir avec Android (à part les Log.x). On peut en effet utiliser le code présenté directement si son utilisation est threadée, mais je pense que cela peut perdre les gens de ne pas en parler du tout (c'est du vécu, passage 2.x à 3.x douloureux en terme d'utilisation de webservice ).
  • acesyde
    Membre éclairé
    @nicroman
    Merci pour tes remarques.
    J'ai voulu faire au plus simple pour éviter de perdre le lecteur, "UTF-8", gestion des erreurs etc... on a vite fait de noyer un paragraphe avec
    Mais c'est vrai que c'est une partie importante que j'aurais du traiter pour forcer les bonnes habitudes.

    @DrSnake
    Je n'ai pas mis la partie Frontale de l'application, juste le traitement de la connexion et de la réponse, bien entendu dans le CS il y a une AsyncTask.

    A l'avenir je rajouterais des compléments dans les tutoriaux suite à vos remarques.

    Merci
  • Klyrdee
    Futur Membre du Club
    bonjour, votre tutoriel: http://acesyde.developpez.com/tutori...vices-android/ est probablement ce rapprochant le plus de ce que je souhaiterai faire:

    Placer les images dans le dossier /assets de ton projet, puis attaques la partie code :
    1) Récupères via HttpClient le code HTML de ton serveur comme une grosse chaîne de caractère
    2) Appliques un traitement sur cette chaîne pour remplacer tout les chemins du serveur par leur équivalent local. Exemple : <img src="logo.png"/> devient <img src="file:///android_asset/logo.png"/>
    3) Procède au rendu graphique de cette chaîne via une WebView : webView.loadDataWithBaseURL(null, la_grosse_chaine_html, "text/html", "utf-8",null);

    mais je suis débutant, et je ne connais pas le langage enfin depuis une semaine je m'y suis mis mais bon je galère
    hors dans votre tuto vous proposer une annexe ou il y a ce que vous avez fait dans le tuto mais le lien n'est plus accessible.
    pourriez-vous le remttre d'actualité pour me l'envoyer: qdavenne@gmail.com

    PS: dans l'eventualité pour vous avec un peu de temp a m'accorder et que cela ne vous pose ni difficulté ni une perte de temp considerable pourriez-vous rajouter les lignes de code qui manque pour que l'appli puisse etre opérationel .
    merci d'avance cordialement
  • Feanorin
    Expert éminent
    Salut,

    ¨Pour cela il faut que tu vois directement avec l'auteur tu peux le contacter par Message Privé.
  • Hephaistos007
    Expert confirmé
    Le tutoriel a 3 ans. Tu peux consulter un équivalent ici (avec code source téléchargeable) : http://olegoaer.developpez.com/tutos...e/android/rpc/

    Mais je ne t'ai pas donné le lien car tu n'es pas dans le cas d'un appel de webservice (ou alors dans une forme extrêmement simpliste). Tu as juste à récupérer le source de la page web distante avec HttpURLConnection.

    Personne ne le fera à ta place car cela nécessite du temps. Je t'ai déjà bien guidé avec ces 3 étapes clés. Si tu bloques encore, c'est que tu n'es pas assez formé. Entraînes-toi d'abord sur des choses plus simple et continues ton projet ensuite.
  • Klyrdee
    Futur Membre du Club
    oui merci je vais apprendre le langage depuis le debut je pense ^^ quand meme