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 :

login php mysql


Sujet :

Android

  1. #1
    Nouveau membre du Club
    Inscrit en
    Avril 2012
    Messages
    79
    Détails du profil
    Informations forums :
    Inscription : Avril 2012
    Messages : 79
    Points : 32
    Points
    32
    Par défaut login php mysql
    Bonsoir je veux ajouter un code d'authentification à mon application mais je n'ai pas réussi à faire ça.
    login.php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    <?php 
     
    		$log1= $_POST['et_login'];
    		$lpass= $_POST['et_password'];
     
     
    		require "dbConnect.php";
     
    		$sql = "SELECT * FROM member WHERE Login = '$log1' and Password='$pass'  ";
     
    		$r = mysqli_query($con,$sql);
     
    	mysqli_close($con);
    MainActivity.php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
     
    import android.app.ProgressDialog;
    import android.content.Intent;
    import android.os.AsyncTask;
    import android.os.Bundle;
    import android.support.design.widget.FloatingActionButton;
    import android.support.design.widget.Snackbar;
    import android.support.v7.app.AppCompatActivity;
    import android.support.v7.widget.Toolbar;
    import android.util.Config;
    import android.view.View;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.TextView;
    import android.widget.Toast;
     
    import org.json.JSONArray;
    import org.json.JSONException;
    import org.json.JSONObject;
     
    import java.util.HashMap;
     
    public class MainActivity extends AppCompatActivity {
        public static final String URL_LOG= "http://10.0.3.2/PHP/login.php";
        public static final String TAG_JSON_ARRAY ="result";
        EditText etLogin,etPassword;
        Button btnValider;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
            setSupportActionBar(toolbar);
     
            FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
            fab.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                            .setAction("Action", null).show();
                }
            });
            etLogin=(EditText) findViewById(R.id.et_login);
            etPassword=(EditText) findViewById(R.id.et_password);
            btnValider=(Button) findViewById(R.id.btn_valider);
            txt=(TextView) findViewById(R.id.link_signup);
            btnValider.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    Login();
                }
     
        }
     
        private void Login() {
     
            final String login = etLogin.getText().toString().trim();
            final String mdp = etPassword.getText().toString().trim();
     
            class LoginEmployee extends AsyncTask<Void,Void,String> {
     
                ProgressDialog loading;
     
                @Override
                protected void onPreExecute() {
                    super.onPreExecute();
                    loading = ProgressDialog.show(MainActivity.this, "Login...", "Wait...", false, false);
                }
     
                @Override
                protected void onPostExecute(String s) {
                    super.onPostExecute(s);
                    loading.dismiss();
                    showEmployee(s);
                }
     
                @Override
                protected String doInBackground(Void... v) {
     
                    HashMap<String,String> params = new HashMap<>();
                    params.put("log",login);
                    //  params.put(Config.KEY_EMP_SAL,salary);
                    RequestHandler rh = new RequestHandler();
                    String res= rh.sendPostRequest(URL_LOG, params);
                    return res;
                }
            }
     
            LoginEmployee le = new LoginEmployee();
            le.execute();
        }
        private void showEmployee(String json){
            try {
                JSONObject jsonObject = new JSONObject(json);
                JSONArray result = jsonObject.getJSONArray(TAG_JSON_ARRAY);
                JSONObject c = result.getJSONObject(0);
                String mdp = c.getString("mdp");
     
     
                //editTextName.setText(name);
                String d = mdp;
                Toast.makeText(MainActivity.this, d, Toast.LENGTH_LONG).show();
     
     
            } catch (JSONException e) {
                e.printStackTrace();
            }
     
        }
        @Override
        public boolean onCreateOptionsMenu(Menu menu) {
            // Inflate the menu; this adds items to the action bar if it is present.
            getMenuInflater().inflate(R.menu.menu_main, menu);
            return true;
        }
     
        @Override
        public boolean onOptionsItemSelected(MenuItem item) {
            // Handle action bar item clicks here. The action bar will
            // automatically handle clicks on the Home/Up button, so long
            // as you specify a parent activity in AndroidManifest.xml.
            int id = item.getItemId();
     
            //noinspection SimplifiableIfStatement
            if (id == R.id.action_settings) {
                return true;
            }
     
            return super.onOptionsItemSelected(item);
        }
    }
    Avec les codes ci dessus je n'ai pas obtenu aucun erreur. Alors je dois ajouter la partie de vérification suivante mais je n'ai pas arrivé à bien déterminer la partie qui est entre les parenthèse rouges
    Merci de m'aider à compléter mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    if (*********************) {
                        Intent intent = new Intent(MainActivity.this,CompteActivity.class);
                        startActivity(intent);
                    } else {
                        Toast.makeText(MainActivity.this, "Erreur", Toast.LENGTH_SHORT).show();
                    }

  2. #2
    Membre régulier
    Homme Profil pro
    Développeur Java
    Inscrit en
    Octobre 2012
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Congo-Kinshasa

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2012
    Messages : 100
    Points : 91
    Points
    91
    Par défaut
    Bonjour,

    En regardant l'adresse IP que vous avez placé dans votre code ne vous permettra pas de tester avec un emulateur si je ne me trompe pas.
    Lorsqu'on travail avec emulateur pour tester l'application l'adresse IP doit être 10.0.2.2ort par défaut le port de phpAdmin est 80. donc il fallait écrire 10.0.2.2:80

    Dans la méthode InBackground, vous avez uniquement envoyé le login et non le password et pour envoyer les données:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
       HashMap<String,String> params = new HashMap<>();
                    params.put("log",login);
    il faut nécessairement envoyer ces deux paramètres en respectant le même nom du paramètre de la méthode Post de votre code php qui n'est pas aussi identique(et_login, et_password).

    Pour terminer, la valeur du résultat dans la méthode onPostExécuter qui provient de json, tu doit le comparé soit avec le login et le mot de passe. Si c'est identifique alors l'accès.
    Par exempe,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    if(login==login2 && mdp==mdp2){
    -----
    }else{
    ----
    }
     
    avec login et mdp sont ceux qui sont saisis par l'utilisateur et login2 et mdp2 sont ceux que tu récupère grâce à json. 
     
    if (*********************) {
                        Intent intent = new Intent(MainActivity.this,CompteActivity.class);
                        startActivity(intent);
                    } else {
                        Toast.makeText(MainActivity.this, "Erreur", Toast.LENGTH_SHORT).show();
                    }
    Bon ce site peut aidé avec ses exemples: http://www.androidhive.info/2012/05/...ith-php-mysql/

  3. #3
    Membre habitué
    Inscrit en
    Décembre 2007
    Messages
    94
    Détails du profil
    Informations personnelles :
    Âge : 36

    Informations forums :
    Inscription : Décembre 2007
    Messages : 94
    Points : 134
    Points
    134
    Par défaut
    Dans ton code login.php à quel moment tu renvoies un résultat au client ? (a ton application Android en l'occurence)
    Essaie d'afficher dans le log le contenu de ta variable s de onPostExecute et dis nous ce que tu as.

Discussions similaires

  1. [MySQL] Inserer une page de login (en php/mysql) sur site deja existant
    Par ludovic787 dans le forum PHP & Base de données
    Réponses: 14
    Dernier message: 03/02/2016, 13h36
  2. [MySQL] Création d'un login et mot de passe securisé avec PHP/MySQL
    Par NicoMontreal91 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 28/09/2008, 22h01
  3. Réponses: 1
    Dernier message: 19/01/2008, 14h15
  4. Recherche Login Script PHP & MySQL
    Par whbh dans le forum SQL Procédural
    Réponses: 9
    Dernier message: 01/12/2005, 16h45

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