Как отправить запрос HttpPost в php скрипт на сервере - PullRequest
0 голосов
/ 06 февраля 2012

Это код php, где я хочу использовать метод HttpPost в Android.Я хочу проверить, что объект json, отправленный вместе с методом post, совпадает с данными, присутствующими в базе данных

if(!isset($_POST['data'])) {
    echo "FAIL1";   
    return 'false';
}

$jsonObject = $_POST['data'];
$data = json_decode($jsonObject, true);

if(!is_array($data)) {
    print_r($data);
    exit;  
    echo "FAIL2";
    return 'false';
}

$UNIQUE_ID = $data['UNIQUE_ID'];
$BAR_CODE = $data['BARCODE'];
$BATCH_CODE = $data['BATCHCODE'];

if(!isset($UNIQUE_ID) || trim($UNIQUE_ID) == '' || !isset($BAR_CODE) || trim($BAR_CODE) == '' || !isset($BATCH_CODE) || trim($BATCH_CODE) == '') {
    echo "FAIL3";
    return 'false';
}

$link = mysql_connect($db_server,$db_username,$db_pasword) or die("Can not connect to server $db_server.");

mysql_select_db("drugverifier",$link);

$query = "SELECT * FROM drugverifier where unique_id = $UNIQUE_ID AND bar_code = $BAR_CODE AND batch_code = $BATCH_CODE";
echo " TEST4";
$result = mysql_query($query,$link) or die("Can not able to run the query ' $query ' on server $db_server.");
echo "TEST5";
if(mysql_num_rows($result) > 0){
    echo "SUCCESS6";
    echo 'true';
}
else {
    echo "FAILURE7";
    echo 'false';
}

мой код Android:

JSONObject j = new JSONObject();
        try {
            j.put("BARCODE", "8904017500190");
            j.put("BATCHCODE", "220");  
            j.put("UNIQUE_ID", "9876"); 

        } catch (JSONException e) {
            Log.v("@@@@@JSONException", e.getMessage());
        }
String url = "http://www.smartcloudinfotech.com/SmartDrugVerifier/verifyBarCode.php";
 HttpClient httpclient = new DefaultHttpClient();
         HttpPost httpPost = new HttpPost(url);

List<NameValuePair> nameValuePair = new ArrayList<NameValuePair>(1);
                nameValuePair.add(new BasicNameValuePair("data",j.toString()));
                httpPost.setEntity(new UrlEncodedFormEntity(nameValuePair));

                 response = httpclient.execute(httpPost);
                 Log.v("RESPONSE",""+response.toString());
                 Toast.makeText(this, "RESPONSE in doPOST()"+response.toString(), Toast.LENGTH_SHORT).show();


            } catch (UnsupportedEncodingException e) {
                Log.v("@@@@@@@@@@@@@@UnsupportedEncodingException", e.getMessage());
            } catch (ClientProtocolException e) {
                Log.v("@@@@@@@@@ClientProtocolException",e.getMessage());
            } catch (IOException e) {
                Log.v("@@@@@@@@@@IOException116", e.getMessage());
            } 

String temp = EntityUtils.toString(response.getEntity());

при запуске этого значенияпеременной temp не содержит никакого значения.Пожалуйста, помогите мне, где я иду не так.

Ответы [ 2 ]

0 голосов
/ 06 февраля 2012

Вы неправильно читаете ответ в Android, это так

HttpResponse response = httpclient.execute(httppost);
String result = EntityUtils.toString(response.getEntity());

Также я не большой программист PHP, но я считаю, что вы неправильно читаете значения в PHP, вы не передаете JSONArray, насколько я могу судить, вы передаете JSONObject. Также удалите

print_r($data);
exit; 
0 голосов
/ 06 февраля 2012

Попробуйте использовать BufferedReader для чтения содержимого HttpEntity следующим образом:

void printResponse(HttpResponse response) throws IOException {
    BufferedReader in = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
    String line = "";
    while ((line = in.readLine()) != null) {
        System.out.println(line);
    }
}

Редактировать
Когда я запускаю POST, используя Curl для вашего сервера, с data=test, я не получаю ответа. Я думаю, что это из-за этого кода:

if(!is_array($data)) {
    print_r($data);
    exit;  
    echo "FAIL2";
    return 'false';
}

Во-первых, если это не массив, вы хотите напечатать массив. Это бессмысленно. Во-вторых, вы выходите и повторяете «FAIL2».

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...