IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Android Discussion :

Perte d'Internet lorsque le téléphone est en veille


Sujet :

Android

  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2013
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2013
    Messages : 22
    Points : 22
    Points
    22
    Par défaut Perte d'Internet lorsque le téléphone est en veille
    Bonjour,

    Je développe une application pour Android qui utilise les sockets pour communiquer régulièrement avec un serveur. Le socket est stocké dans une variable static.

    L'application fonctionne correctement tant que le téléphone est utilisé mais lorsque le téléphone est en veille, l'application perd la connexion après quelques minutes (environ 5).
    Il faut alors rallumer l'écran pour que l'application se reconnecte.

    Le problème se produit aussi bien avec le wifi qu'avec les données mobiles mais il ne semble pas se produire lorsque le téléphone est connecté en débogage à l'ordinateur (Android Studio).

    J'ai essayé de mettre en place un WifiLock et un WakeLock :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    PowerManager powerManager = (PowerManager) getSystemService(POWER_SERVICE);
    wakeLock = powerManager.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "MyWakeLock");
    wakeLock.acquire();
    WifiManager wifiManager = (WifiManager) getApplicationContext().getSystemService(WIFI_SERVICE);
    wifiLock = wifiManager.createWifiLock(WifiManager.WIFI_MODE_FULL, "MyWifiLock");
    wifiLock.acquire();
    (sans oublier d'ajouter
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    au fichier AndroidManifest.xml).

    J'ai également essayé d'exécuter un IntentService qui se charge de la communication avec le serveur.

    Mais le problème persiste et je suis à court d'idées pour y remédier.

    Je précise que l'application continue à fonctionner lorsque le téléphone est en veille, puisqu'elle m'avertit de la perte de connexion grâce à un signal sonore préalablement défini ; le seul ennui est ladite perte de connexion à Internet.

    Sauriez-vous comment éviter que l'application ne se déconnecte lorsque le téléphone est en veille ?

    Cordialement,
    E__Man.

  2. #2
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 691
    Points : 20 222
    Points
    20 222
    Par défaut
    C'est le Doze mode d'android qui coupe toute connexion réseau et ignore les wakelock quand le téléphone est en veille.

    https://developer.android.com/traini...e-standby.html
    Garder une connexion ouverte même avec le téléphone en veille est une mauvaise pratique.

    Il y'a possiblité de contourner cela en whitelistant une application mais c'est la solution de dernier recours qui ne devrait être appliqué que si tout le reste n'est pas possible.
    Il existe un tableau en bas de la doc qui défini les cas acceptable ou non.

    Autant te dire que si c'est une appli que tu souhaites publier , n'envisage même pas de garder une connexion ouverte. Tu vas drainer la batterie et te faire lyncher sur les notes/commentaires.
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre à l'essai
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2013
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2013
    Messages : 22
    Points : 22
    Points
    22
    Par défaut
    J'ai lu l'article que vous m'avez envoyé. Je vais me pencher sur le Firebase Cloud Messaging et je vous tiens au courant de l'avancement de sa mise en place.

  4. #4
    Membre à l'essai
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2013
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2013
    Messages : 22
    Points : 22
    Points
    22
    Par défaut
    Bonjour,

    Excusez-moi de ne pas avoir répondu plus tôt : l'expérimentation du code a été fastidieuse. En effet, la moindre modification oblige à attendre au moins 5 minutes pour voir le résultat. De plus, il faut débrancher le téléphone ce qui complique l'accès à logcat et donc le diagnostic des problèmes en cas de comportement non désiré.

    J'ai mise en place FCM grâce à la documentation (https://firebase.google.com/docs/android/setup) et à l'assistant intégré à Android Studio.
    Je demande à l'application de rejoindre un "topic" de diffusion des messages au démarrage :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        ...
        FirebaseMessaging.getInstance().subscribeToTopic("mon_topic");
    }
    Je ne poste pas le code du FirebaseMessagingService ni celui du FirebaseInstanceIdService car ils sont disponibles à l'identique dans la susdite documentation.

    Le programme avec lequel l'application Android doit communiquer est en Python sur Raspberry Pi. J'ai installé pyfcm grâce à pip install pyfcm puis j'ai ajouté le code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    import pyfcm
    ...
    push_service = FCMNotification(api_key="clé")
    ...
    data = dict()
    data["param1"] = "value1"
    data["param2"] = "value2"
    ...
    try:
        push_service.notify_topic_subscribers(topic_name="mon_topic", data_message=data)
    except pyfcm.errors.AuthenticationError:
        #clé incorrecte
    except:
        #envoi du message impossible
    Il est très important d'envoyer un message "data" plutôt qu'un message texte. Comme indiqué dans la documentation, les messages sous forme de texte ne sont pas envoyés à l'application lorsque le téléphone est en veille mais sont affichés en tant que notifications.
    Je n'ai cependant pas trouvé comment envoyer les messages du téléphone en veille vers le Raspberry mais, heureusement, cela m'est pour le moment inutile.

    Le problème est donc résolu. Merci de votre aide.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 4
    Dernier message: 02/11/2013, 00h55
  2. Réponses: 7
    Dernier message: 25/12/2005, 01h07
  3. Calcul Stock Actuel mm lorsqu'une valeur est null
    Par priest69 dans le forum Access
    Réponses: 3
    Dernier message: 12/09/2005, 18h58
  4. Calque en pied de page (même lorsque le scroll est en haut)
    Par AlphaYoDa dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 18/03/2005, 20h00
  5. Réponses: 6
    Dernier message: 11/01/2005, 12h49

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo