Android を学習し、PHP スクリプトと WAMP サーバーを使用してユーザー名とパスワードを確認するコードを作成しようとしています。PHP スクリプトから未定義のインデックス エラーが発生し続けます。私が確認できる限り、これは私の PHP スクリプトが URL からのデータにアクセスできないことを意味します。関連するコードは次のとおりです。どんな助けでも大歓迎です。
//build url data to be sent to server
ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
nameValuePairs.add(new BasicNameValuePair("username",username));
nameValuePairs.add(new BasicNameValuePair("password",password));
String result = "";
InputStream is = null;
//http post
try{
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://10.0.2.2/PasswordCheck.php");
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
HttpResponse response = httpclient.execute(httppost);
HttpEntity entity = response.getEntity();
is = entity.getContent();
}catch(Exception e){
Log.e("Connection", "Error in http connection "+e.toString());
}
ここに私のPHPスクリプトがあります
<?php
mysql_connect("localhost", "root", "") or die("could not connect to mysql");
mysql_select_db("drop-in") or die("database not found");
$username = $_POST["username"];
$suppliedPassword = $_POST["password"];
$databasePassword = "";
$output = "false";
$query = mysql_query("SELECT Password FROM users WHERE Username = '$username'") or die("query failed");
if(mysql_num_rows($query) > 0){
$row = mysql_fetch_assoc($query);
$databasePassword = $row['password'];
if($databasePassword == $suppliedPassword)
{
$output = "true";
}
}
print($output);
mysql_close();
?>
そして、ここにサーバーの応答の写真があります
編集: PHP スクリプトがこれらのエラーを出していても、$username 変数と $password 変数には、Android アプリが渡そうとした値が含まれていることがわかりました。ただし、これらのエラーの存在は、エラー テーブルの HTML が応答で Android アプリに送り返されるため、コードをいじっています。