Android Http登录帖子


Android Http Login Post

我正试图通过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

我将感谢的任何帮助

谢谢,

张贴JSON对象,但试图解析REQUEST变量(即$_GET/$_POST/$_COKIE变量)。

对Java不太确定,但我怀疑它将序列化的JSON对象分配给了一个名为jsonString的后变量。(通过编写一个简单的PHP脚本来转储所有$_POST、$_GET和$HTTP_RAW_POST_DATA,您可以很容易地进行检查)

在哪种情况下获取php:中的值

$jsonString=json_decode($_POST['jsonString']);
$myusername = $jsonString['username']; 
$mypassword = $jsonString['password'];

从android代码中删除所有JSON。在PHP端,您没有将其作为JSON接收,因此这可能是根本原因。NameValuePairs应该可以正常工作。