Ошибка сценария PHP при вызове из Android HttpClient

У меня проблема со скриптом, который не возвращает то, что должен, при вызове из моего приложения для Android.

Сторона Android

int pur_user = 3;
URL url = new URL("http://www.example.com/conf/includes/purchase.php");
String result = "";
HttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost(url.toString());
ArrayList<NameValuePair> pairs = new ArrayList<NameValuePair>();
JSONObject jsonObject = new JSONObject();
jsonObject.put("PUR_sku", SKU);
jsonObject.put("PUR_user", pur_user);
pairs.add(new BasicNameValuePair("data", jsonObject.toString()));
httpPost.setEntity(new UrlEncodedFormEntity(pairs,HTTP.UTF_8));
HttpResponse response = httpClient.execute(httpPost);           
InputStream is = response.getEntity().getContent();        
result = convertInputStreamToString(is);
Log.d("SEND", "Response of Send Result : " + result);

Я попробовал 3 разных способа подключения к моему веб-серверу, и результат всегда в порядке, поэтому я предполагаю, что проблема связана с PHP-скриптом.

Сторона PHP

<? 
$auth=0;
include('./connexion.php');
//$data = file_get_contents('php://input');
//$json = json_decode($data,true);
$json = json_decode($this->input->post('data'), true);
if (strip_tags($json['PUR_sku'])=="singleconf" || strip_tags($json['PUR_sku'])=="fiveconf" || strip_tags($json['PUR_sku'])=="tenconf"){
$addcredits = 0;
if (strip_tags($json['PUR_sku'])=="singleconf"){$addcredits = 1;}
if (strip_tags($json['PUR_sku'])=="fiveconf"){$addcredits = 5;}
if (strip_tags($json['PUR_sku'])=="tenconf"){$addcredits = 10;}
if ($addcredits>0){
    $S_user = mysqli_query($C,"SELECT USE_id, USE_maxcredits FROM CONF_users WHERE USE_id = '".strip_tags($json['PUR_user'])."' LIMIT 1");  
    if (mysqli_num_rows($S_user)==1){
        $DT_user = mysqli_fetch_assoc($S_user);
        $newcredits = $DT_user['USE_maxcredits'] + $addcredits;
        $U_user = mysqli_query($C,"UPDATE CONF_users SET USE_maxcredits = '".$newcredits."' WHERE USE_id = '".$DT_user['USE_id']."' LIMIT 1"); 
        $_SESSION['CO_maxcredits'] = $newcredits;
        }
    }
}
echo "Retour ".print_r($json)." et ".$json['PUR_sku']." et ".$json['PUR_user'];
?>

В logcat я получаю «Ответ отправки результата:» и пустую строку... Я пытался отлаживать, удаляя все строки, кроме последней (эхо), и получаю правильный ответ в logcat. Кажется, проблема связана со строкой "include('./connexion.php')", но я знаю, что строковое имя файла в порядке, потому что я использую то же самое в другом скрипте.

Любая идея о том, что я делаю неправильно ??


person Matthieu Marcé    schedule 08.07.2015    source источник
comment
Что вы подразумеваете под тем, что у вас есть 3 способа подключения к серверу?   -  person B001ᛦ    schedule 08.07.2015
comment
Один с HttpUrlConnection, другой с HttpClient и другим способом отправки JsonObject, а этот   -  person Matthieu Marcé    schedule 08.07.2015
comment
Используйте HttpUrlConnection, так как HttpClient устарел   -  person B001ᛦ    schedule 08.07.2015
comment
@Bub, я также пробовал с HttpUrlConnection, но проблема не здесь   -  person Matthieu Marcé    schedule 08.07.2015


Ответы (1)


Проблема в вашем заявлении echo "Retour ".print_r($json)." et ".$json['PUR_sku']." et ".$json['PUR_user'];. Здесь print_r возвращает логическое значение ( true ), и ваш код означает преобразование его в строку.

Вот решение.

$auth=0;
include('./connexion.php');
//$data = file_get_contents('php://input');
//$json = json_decode($data,true);
$json = json_decode($this->input->post('data'));
if (strip_tags($json['PUR_sku'])=="singleconf" || strip_tags($json['PUR_sku'])=="fiveconf" || strip_tags($json['PUR_sku'])=="tenconf"){
$addcredits = 0;
if (strip_tags($json['PUR_sku'])=="singleconf"){$addcredits = 1;}
if (strip_tags($json['PUR_sku'])=="fiveconf"){$addcredits = 5;}
if (strip_tags($json['PUR_sku'])=="tenconf"){$addcredits = 10;}
if ($addcredits>0){
    $S_user = mysqli_query($C,"SELECT USE_id, USE_maxcredits FROM CONF_users WHERE USE_id = '".strip_tags($json['PUR_user'])."' LIMIT 1");  
    if (mysqli_num_rows($S_user)==1){
        $DT_user = mysqli_fetch_assoc($S_user);
        $newcredits = $DT_user['USE_maxcredits'] + $addcredits;
        $U_user = mysqli_query($C,"UPDATE CONF_users SET USE_maxcredits = '".$newcredits."' WHERE USE_id = '".$DT_user['USE_id']."' LIMIT 1"); 
        $_SESSION['CO_maxcredits'] = $newcredits;
        }
    }
}
echo "Retour ".json_encode($json)." et ".$json['PUR_sku']." et ".$json['PUR_user'];
person Pratik Soni    schedule 08.07.2015
comment
Я попробовал ваше решение, но безрезультатно... похоже, это не основная проблема скрипта! - person Matthieu Marcé; 08.07.2015