0

我开发了一个小型 android 应用程序,它使用 json objects 通过 Http 协议与服务器通信。

它在我的本地机器上一切正常,但是当我决定(仅出于学习目的)将我的 php 脚本上传到一些免费的托管网络服务时,我得到了 406 错误。

我做了一些研究,发现一定是我的HttpPost请求中没有设置Content-type。但是设置 Content-type 并没有帮助。

这是安卓代码:

            ArrayList<NameValuePair> userData = new ArrayList<NameValuePair>();
            userData.add(new BasicNameValuePair("email", userData_email));
            userData.add(new BasicNameValuePair("pass", userData_pass));

            HttpParams httpParameters = new BasicHttpParams();
            HttpConnectionParams.setConnectionTimeout(httpParameters, 10000);
            HttpConnectionParams.setSoTimeout(httpParameters, 10000);

            HttpClient client = new DefaultHttpClient(httpParameters);

            HttpPost postRequest = new HttpPost(uri);

            // I tried this too
            // postRequest.setHeader("Content-Type", "application/json");

            UrlEncodedFormEntity ent = new UrlEncodedFormEntity(userData);

            ent.setContentType(new BasicHeader(HTTP.CONTENT_TYPE, "application/json"));

            postRequest.setEntity(ent);

            HttpResponse response = client.execute(postRequest);

            HttpEntity entity = response.getEntity();

            String result = EntityUtils.toString(entity);

            Log.e("SERVER: ", result);

            JSONObject json = new JSONObject(result); 

            userData_fname = json.getString("fname");
            userData_lname = json.getString("lname");
            userData_age = json.getInt("age");
            userData_gender = json.getString("gender");

这是来自服务器的代码(真的没什么花哨的):

$mysql_host = 'xxxx';
$mysql_user = 'xxxx';
$mysql_pass = 'xxxx';
$mysql_db = 'xxxx';

if (isset($_POST["email"]) && isset($_POST["pass"])) {
$email = $_POST["email"];
$pass = $_POST["pass"];

if(!mysql_connect($mysql_host, $mysql_user, $mysql_pass) || !mysql_select_db($mysql_db)) {
    echo '-1';
}

$query = "SELECT * FROM `users` WHERE `email`='".$email."' AND `password`='".$pass."'";
if($query_run = mysql_query($query)){

    $firstname = mysql_result($query_run, 0, 'firstname');
    $lastname = mysql_result($query_run, 0, 'lastname');
    $age = mysql_result($query_run, 0, 'age');
    $gender = mysql_result($query_run, 0, 'gender');

    $return_data = array (
        'fname' => $firstname,
        'lname' => $lastname,
        'age' => $age,
        'gender' => $gender
    );

    echo json_encode($return_data);

} else {
    echo 'not found';
    exit();
   }
}

现在,它可能与我的 php 代码有关(可能缺少某些东西),但由于我只知道 php 的基础知识,所以我向您寻求帮助。

先感谢您。

4

2 回答 2

1

你改变:

HttpParams httpParameters = new BasicHttpParams();
HttpConnectionParams.setConnectionTimeout(httpParameters, 10000);
HttpConnectionParams.setSoTimeout(httpParameters, 10000);`
HttpClient client = new DefaultHttpClient(httpParameters);

至:

HttpClient httpclient = new DefaultHttpClient();
HttpConnectionParams.setConnectionTimeout(httpclient.getParams(),
            timeOut);
HttpConnectionParams.setSoTimeout(httpclient.getParams(), timeOut);`

当然,它有效。

于 2013-11-19T19:14:15.173 回答
0

如果您想确定您的 php 代码,您必须从浏览器打开该页面,如果您会看到 JSON 格式的数据,那么服务器工作正常!否则您的服务器不会检索json_encode()功能。

于 2013-10-24T20:10:18.720 回答