我正在尝试通过Android应用程序登录我的网站。 由于某种原因,它总是无法登录。
以下是该应用的登录方式:
private void login() {
//this method returns false
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://mysite.com/mobileauth.php");
JSONObject jsonObject = new JSONObject();
try {
List nameValuePairs = new ArrayList(2);
jsonObject.put("username", "user1");
jsonObject.put("password", "12345");
nameValuePairs.add(new BasicNameValuePair("jsonString", jsonObject.toString()));
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
HttpResponse response = httpclient.execute(httppost);
String responseStr = org.apache.http.util.EntityUtils.toString(response.getEntity());
statusText.setText(responseStr);
} catch (ClientProtocolException e) {
statusText.setText(e.toString());
} catch (IOException e) {
statusText.setText(e.toString());
} catch (JSONException e) {
statusText.setText(e.toString());
}
}
我为移动设备登录创建了一个特定文件,例如Android。
这是我在服务器上的身份验证文件:
$host="*"; // Host name
$username="*"; // Mysql username
$password="*"; // Mysql password
$tbl_name="users"; // Table name
$db_name="database";
$link = mysql_connect($host, $username, $password) or die("Connection Error");
$db = mysql_select_db("$db_name")or die("Connection Error");
$myusername = $_REQUEST['username'];
$mypassword = $_REQUEST['password'];
$sql="SELECT * FROM $tbl_name WHERE username='$myusername' AND paswd='$mypassword'";
$result = mysql_query($sql);
$count = mysql_num_rows($result);
if ($count == 1) {
$timeUpdateQuesry="UPDATE users SET lastLogin=Now() WHERE username='$myusername' AND paswd='$mypassword'";
mysql_query($timeUpdateQuesry);
echo("true");
} else {
//happend without leaving page
echo ("false");
}
出于某种原因,我总是在我的状态TextView中获得false
。
我会感激任何帮助
谢谢,
答案 0 :(得分:1)
您发布JSON对象但尝试解析REQUEST变量(即$ _GET / $ _ POST / $ _ COKIE变量)。
对Java不太确定,但我怀疑它将序列化的JSON对象分配给名为jsonString的post变量。 (您可以通过编写一个简单的PHP脚本来轻松检查以转储所有$ _POST,$ _GET和$ HTTP_RAW_POST_DATA)
在哪种情况下获取php中的值:
$jsonString=json_decode($_POST['jsonString']);
$myusername = $jsonString['username'];
$mypassword = $jsonString['password'];
答案 1 :(得分:0)
从您的Android代码中删除所有JSON。你没有在PHP端接收它作为JSON,所以这可能是一个根本原因。 NameValuePairs应该可以正常工作。