通过Android应用程序从Android手机访问数据库

时间:2017-05-23 12:31:14

标签: android database android-studio database-connection wamp

我正在为我的第三年项目开发一个应用程序,它是一个Android应用程序(我使用android工作室),它将访问我在我的wamp服务器上创建的数据库,该连接可以完美地从应用程序运行时我在我的Android手机上调试它(我在我的代码中使用" HttpURLConnection" url是我从我的pc ip地址(cmd / ipconfig))。
问题是,一旦我从手机上断开手机并尝试从手机上运行应用程序,与数据库的连接就无法正常工作,如果我将我的电脑连接到另一个调制解调器,我的电脑ip也会改变,这是非常正常的,但我不认为每次我连接的调制解调器都要改变ip(虽然我不确定,服务器连接显然不是我的专家在),所以我试图在互联网上使用我的电脑的IP,我来自" ipaddress.com"但它不会工作,即使我直接从android studio调试应用程序, 我没有多少时间来提交申请,所以我需要快速回答,谢谢你提前 PS:我想我必须提到我需要访问数据库以便从手机上读取和写入,因为它是一个允许登录/注册的应用程序,并将获取用户将输入并存储的数据数据库。

3 个答案:

答案 0 :(得分:0)

尝试在同一网络中连接手机和手机。

您的连接Url会像192.10.20.2这样是您的IP或计算机。当你使用ipconfig命令从cmd获取它时。

但是每当您的网络发生变化时,您都必须进行反编译才能更改IP。或通过textview提供ip。

采取Editview采取IP。并将其连接到您的网址。这会奏效。因为它对我有用。

答案 1 :(得分:0)

我不知道是什么时候,当你断开手机与电脑的连接时,应用程序已经死了?或者简单地说它不与db连接。注意路由器,你需要一个帐户" no-ip"并在端口80上配置forguard的路由器以重定向计算机的静态IP。我需要更多细节和信息来帮助您。此致

答案 2 :(得分:0)

     i'm working on an external server 
The php code (for the connection to the db)
  <?php
$db_name="pfe";
$mysql_username="root";
$mysql_password="";
$server_name="localhost";
$conn = mysqli_connect($server_name,$mysql_username,$mysql_password,$db_name);
?>
then i got another php file which handles the login part
 <?php
require "connexion.php";
$user_email =$_POST["user-email"];
$user_pass =$_POST["password"];
$mysql_qry = "select id from donateur where email like '$user_email' and                 
password like '$user_pass'";
$result = mysqli_query($conn , $mysql_qry);
if(($row=mysqli_fetch_assoc($result))!=null){
$a = array('myarray' => array("donateur", $row["id"]));
echo json_encode($a);}
else {
    $mysql_qry2 = "select id, username from association where email like     
'$user_email' and password like '$user_pass'";
$result2 = mysqli_query($conn , $mysql_qry2);
if(($row=mysqli_fetch_assoc($result2))!=null) { $a = array('myarray' => 
array("association", $row["id"]));
echo json_encode($a);
}
 else { echo "rien";}}
$conn->close();

    the java code : 

package applis.pfe;
import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
import android.annotation.TargetApi;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.SharedPreferences;
import android.content.pm.PackageManager;
import android.support.annotation.NonNull;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.app.LoaderManager.LoaderCallbacks;

import android.content.CursorLoader;
import android.content.Loader;
import android.database.Cursor;
import android.net.Uri;
import android.os.AsyncTask;

import android.os.Build;
import android.os.Bundle;
import android.provider.ContactsContract;
import android.text.TextUtils;
import android.view.KeyEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.inputmethod.EditorInfo;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.TextView;
import android.widget.Toast;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import static android.Manifest.permission.READ_CONTACTS;


public class LoginActivity extends AppCompatActivity implements             
LoaderCallbacks<Cursor> {

/**
 * Id to identity READ_CONTACTS permission request.
 */
private static final int REQUEST_READ_CONTACTS = 0;

DonateurDAO donateurdao= new DonateurDAO(this);
AssociationDAO associationdao=new AssociationDAO(this);
/**
 * Keep track of the login task to ensure we can cancel it if requested.
 */
String ip="http://105.101.179.155/";
private UserLoginTask mAuthTask = null;

// UI references.
private AutoCompleteTextView mEmailView;
private EditText mPasswordView;
private View mProgressView;
private View mLoginFormView;
public static String qui;
public static int id;
public static String username;
SessionManager session;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_login);
    ///////////////////// POUR AFFICHER LE MESSAGE DIINSCRIPTION REUSSIE /////////////////////////////////////
if(getIntent().getStringExtra("inscription")!=null &&         
getIntent().getStringExtra("inscription").equals("oui"))
{ AlertDialog a= new AlertDialog.Builder(LoginActivity.this).create();
    a.setTitle("Inscription réussie !");
    a.setMessage("Votre inscription a été validé, veuillez vous connecter     
pour pouvoir continuer");
    a.show();}
    session = new SessionManager(this);
    // Set up the login form.
    mEmailView = (AutoCompleteTextView) findViewById(R.id.email);
  //  populateAutoComplete();
    mPasswordView = (EditText) findViewById(R.id.password);
    mPasswordView.setOnEditorActionListener(new 
 TextView.OnEditorActionListener() {
        @Override
        public boolean onEditorAction(TextView textView, int id, KeyEvent         
keyEvent) {
                if (id == R.id.login || id == EditorInfo.IME_NULL) {
                    attemptLogin();
                    return true;
            }
            return false;
        }
    });

    Button mEmailSignInButton = (Button) findViewById(R.id.email_sign_in_button);
    mEmailSignInButton.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View view) {attemptLogin();

        }
    });

    mLoginFormView = findViewById(R.id.login_form);
    mProgressView = findViewById(R.id.login_progress);

ImageButton btn;
    btn =(ImageButton)findViewById(R.id.InscriptionDonateurButton);
    btn.setOnClickListener(new View.OnClickListener(){
        @Override
        public void onClick(View view) {Intent in= new     
Intent(LoginActivity.this,InscriptionDonateurActivity.class);
            startActivity(in);
        }
    });

   ImageButton btn1;
  btn1 =(ImageButton)findViewById(R.id.InscriptionAssociationButton);
    btn1.setOnClickListener(new View.OnClickListener(){
        @Override
        public void onClick(View view) {Intent in= new     
Intent(LoginActivity.this,InscriptionAssociationActivity.class);
        startActivity(in);
        }
    });
}


    private void attemptLogin() {
        if (mAuthTask != null) {
            return;
        }

        // Reset errors.
        mEmailView.setError(null);
        mPasswordView.setError(null);

    // Store values at the time of the login attempt.
    String email = mEmailView.getText().toString();
    String password = mPasswordView.getText().toString();

    boolean cancel = false;
    View focusView = null;

    // Check for a valid password, if the user entered one.
    if (!TextUtils.isEmpty(password) && !isPasswordValid(password)) {
        mPasswordView.setError(getString(R.string.error_invalid_password));
        focusView = mPasswordView;
        cancel = true;
    }

    // Check for a valid email address.
    if (TextUtils.isEmpty(email)) {
        mEmailView.setError(getString(R.string.error_field_required));
        focusView = mEmailView;
        cancel = true;
    } else if (!isEmailValid(email)) {
        mEmailView.setError(getString(R.string.error_invalid_email));
        focusView = mEmailView;
        cancel = true;
    }

    if (cancel) {
        // There was an error; don't attempt login and focus the first
        // form field with an error.
        focusView.requestFocus();
    } else {
        // Show a progress spinner, and kick off a background task to
        // perform the user login attempt.
        showProgress(true);
        mAuthTask = new UserLoginTask(email, password);
        mAuthTask.execute((Void) null);
    }
}

private boolean isEmailValid(String email) {
    //TODO: Replace this with your own logic
   return android.util.Patterns.EMAIL_ADDRESS.matcher(email).matches();

}

private boolean isPasswordValid(String password) {
    //TODO: Replace this with your own logic
    return password.length() > 4;
}

/**
 * Shows the progress UI and hides the login form.
 */
@TargetApi(Build.VERSION_CODES.HONEYCOMB_MR2)
private void showProgress(final boolean show) {
    // On Honeycomb MR2 we have the ViewPropertyAnimator APIs, which allow
    // for very easy animations. If available, use these APIs to fade-in
    // the progress spinner.
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB_MR2) {
        int shortAnimTime = getResources().getInteger(android.R.integer.config_shortAnimTime);

        mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE);
        mLoginFormView.animate().setDuration(shortAnimTime).alpha(
                show ? 0 : 1).setListener(new AnimatorListenerAdapter() {
            @Override
            public void onAnimationEnd(Animator animation) {
                mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE);
            }
        });

        mProgressView.setVisibility(show ? View.VISIBLE : View.GONE);
        mProgressView.animate().setDuration(shortAnimTime).alpha(
                show ? 1 : 0).setListener(new AnimatorListenerAdapter() {
            @Override
            public void onAnimationEnd(Animator animation) {
                mProgressView.setVisibility(show ? View.VISIBLE : View.GONE);
            }
        });
    } else {
        // The ViewPropertyAnimator APIs are not available, so simply show
        // and hide the relevant UI components.
        mProgressView.setVisibility(show ? View.VISIBLE : View.GONE);
        mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE);
    }
}

@Override
public Loader<Cursor> onCreateLoader(int i, Bundle bundle) {
    return new CursorLoader(this,
            // Retrieve data rows for the device user's 'profile' contact.
            Uri.withAppendedPath(ContactsContract.Profile.CONTENT_URI,
                    ContactsContract.Contacts.Data.CONTENT_DIRECTORY), ProfileQuery.PROJECTION,

            // Select only email addresses.
            ContactsContract.Contacts.Data.MIMETYPE +
                    " = ?", new String[]{ContactsContract.CommonDataKinds.Email
            .CONTENT_ITEM_TYPE},

            // Show primary email addresses first. Note that there won't be
            // a primary email address if the user hasn't specified one.
            ContactsContract.Contacts.Data.IS_PRIMARY + " DESC");
}

@Override
public void onLoadFinished(Loader<Cursor> cursorLoader, Cursor cursor) {
    List<String> emails = new ArrayList<>();
    cursor.moveToFirst();
    while (!cursor.isAfterLast()) {
        emails.add(cursor.getString(ProfileQuery.ADDRESS));
        cursor.moveToNext();
    }

    addEmailsToAutoComplete(emails);
}

@Override
public void onLoaderReset(Loader<Cursor> cursorLoader) {

}

private void addEmailsToAutoComplete(List<String> emailAddressCollection) {
    //Create adapter to tell the AutoCompleteTextView what to show in its dropdown list.
    ArrayAdapter<String> adapter =
            new ArrayAdapter<>(LoginActivity.this,
                    android.R.layout.simple_dropdown_item_1line, emailAddressCollection);

    mEmailView.setAdapter(adapter);
}


private interface ProfileQuery {
    String[] PROJECTION = {
            ContactsContract.CommonDataKinds.Email.ADDRESS,
            ContactsContract.CommonDataKinds.Email.IS_PRIMARY,
    };

    int ADDRESS = 0;
    int IS_PRIMARY = 1;
}

/**
 * Represents an asynchronous login/registration task used to authenticate
 * the user.
 */
public class UserLoginTask extends AsyncTask<Void, Void, String> {

    private final String mEmail;
    private final String mPassword;

    UserLoginTask(String email, String password) {
        mEmail = email;
        mPassword = password;
    }

    @Override
    protected String doInBackground(Void... params) {
        // TODO: attempt authentication against a network service.
String login_url= ip.concat("login.php");
        try {
            URL url= new URL(login_url);
            HttpURLConnection httpURLConnection=(HttpURLConnection)url.openConnection();
            httpURLConnection.setRequestMethod("POST");
            httpURLConnection.setDoInput(true);
            httpURLConnection.setDoOutput(true);
            OutputStream outputStream= httpURLConnection.getOutputStream();
            BufferedWriter bufferedWriter= new BufferedWriter(new OutputStreamWriter(outputStream,"UTF-8"));
            String Post_data= URLEncoder.encode("user-email","UTF-8")+"="+URLEncoder.encode(mEmail,"UTF-8")+"&"
                    +URLEncoder.encode("password","UTF-8")+"="+URLEncoder.encode(mPassword,"UTF-8");
            bufferedWriter.write(Post_data);
            bufferedWriter.flush();
            bufferedWriter.close();
            outputStream.close();
            InputStream inputStream=httpURLConnection.getInputStream();
            qui=null;
            id=0;
            BufferedReader bufferedReader= new BufferedReader(new InputStreamReader(inputStream,"iso-8859-1"));
            String  resultat="";
           String ligne="";
            while((ligne=bufferedReader.readLine())!=null)
            resultat += ligne;
if (resultat.equals("rien")) return  resultat; else {
            JSONObject jsonObject = new JSONObject(resultat);
           JSONArray json_data = jsonObject.getJSONArray("myarray");
            qui=json_data.getString(0);
            id=json_data.getInt(1);
               username= json_data.getString(2);}
          /*  for(int i=0;i<json_data.length();i++)
            {
                k++;
                qui= json_data.getString(1);
                id= json_data.getInt(2);
                //r.add(json_data.getString("categorie"));

            }*/

            bufferedReader.close();
            inputStream.close();
            httpURLConnection.disconnect();
            return resultat;
        } catch (MalformedURLException e) {
            e.printStackTrace();return e.toString();
        } catch (IOException e) {
            e.printStackTrace();return e.toString();
        } catch (JSONException e) {
            e.printStackTrace(); return  e.toString();
        }
    }
      /*  for (String credential : DUMMY_CREDENTIALS) {
            String[] pieces = credential.split(":");
            if (pieces[0].equals(mEmail)) {
                // Account exists, return true if the password matches.
                return pieces[1].equals(mPassword);
            }
        }*/

        // TODO: register the new account here.



    @Override
    protected void onPostExecute(String resultat) {
        mAuthTask = null;
        showProgress(false);
        /////////////////////////////////////////////////////////////////////////////////
        Intent i;
        AlertDialog a;

        if (resultat.equals("rien")){i= new Intent(LoginActivity.this,LoginActivity.class);
            a= new AlertDialog.Builder(LoginActivity.this).create();
            a.setTitle("Erreur");
            a.setMessage(" Email et/ou mot de passe erroné(s)");
            a.show();} else {

            try {
                session.createLoginSession(mEmail,username,qui,id);
                session.checkLogin();
                if (qui.equals("donateur")) {

                    i = new Intent(LoginActivity.this, Suite_Inscription_Donateur.class);
                    i.putExtra("id", id);
                    startActivity(i);
                } else if (qui.equals("association")) {

                    session.createLoginSession(mEmail,username,qui,id);
                    i = new Intent(LoginActivity.this, Suite_Inscription_Association.class);
                    i.putExtra("id", id);
                    startActivity(i);
                }
            } catch (Exception e) {
                e.printStackTrace();
                a= new AlertDialog.Builder(LoginActivity.this).create();
                a.setTitle("Erreur");
                a.setMessage("Erreur :".concat(e.toString()));
                a.show();
            }
        }


    @Override
    protected void onCancelled() {
        mAuthTask = null;
        showProgress(false);
    }
}

}