java - 为什么函数不从android中的php获取数据?

标签 java php android android-activity

我想在发布数据后得到响应,但失败了。我想创建一个登录系统,我已成功将数据提交到 php 文件,现在一切正常我想从相同的功能获得响应,但我无法知道问题出在哪里。

Here is the Java function:

public class PostDataGetRes extends AsyncTask<String, String, String> {

        protected void onPreExecute() {
            super.onPreExecute();
        }

        @Override
        protected String doInBackground(String... strings) {
            try {


                postRData();


            } catch (NullPointerException e) {
                e.printStackTrace();
            } catch (Exception e) {
                e.printStackTrace();
            }
            return null;
        }

        @Override
        protected void onPostExecute(String lenghtOfFile) {
            // do stuff after posting data
        }
    }

    public void postRData() {
        String result = "";
        InputStream isr = null;
        final String email = editEmail.getText().toString();
        final String pass = editPass.getText().toString();
        // Create a new HttpClient and Post Header
        HttpClient httpclient = new DefaultHttpClient();
        HttpPost httppost = new HttpPost("http://website.com/appservice.php");

        try {
            // Add your data
            List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(2);
            nameValuePairs.add(new BasicNameValuePair("id", email));
            nameValuePairs.add(new BasicNameValuePair("stringdata", pass));
            httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));

            // Execute HTTP Post Request
            HttpResponse response = httpclient.execute(httppost);
            resultView.setText("Inserted");
            HttpEntity entity = response.getEntity();
            isr = entity.getContent();

            //convert response to string
            try{
                BufferedReader reader = new BufferedReader(new InputStreamReader(isr,"iso-8859-1"),8);
                StringBuilder sb = new StringBuilder();
                String line = null;
                while ((line = reader.readLine()) != null) {
                    sb.append(line + "\n");
                }
                isr.close();

                result=sb.toString();
            }
            catch(Exception e){
                Log.e("log_tag", "Error  converting result "+e.toString());
            }

            //parse json data
            try {
                String s = "";
                JSONArray jArray = new JSONArray(result);

                for(int i=0; i<jArray.length();i++){
                    JSONObject json = jArray.getJSONObject(i);
                    s = s +
                            "Name : "+json.getString("first_name")+"\n\n";

                    //"User ID : "+json.getInt("user_id")+"\n"+
                    //"Name : "+json.getString("first_name")+"\n"+
                    //"Email : "+json.getString("email")+"\n\n";
                }

                resultView.setText(s);

            } catch (Exception e) {
                // TODO: handle exception
                Log.e("log_tag", "Error Parsing Data "+e.toString());
            }


        } catch (ClientProtocolException e) {
            // TODO Auto-generated catch block
        } catch (IOException e) {
            // TODO Auto-generated catch block
        }
        resultView.setText("Done");
    }

And here is php code:

if($id){
        $query =  mysql_query("SELECT first_name FROM users where email = '$id' ");
        while($row=mysql_fetch_assoc($query)){
            $selectedData[]=$row;
        }
        print(json_encode($selectedData));
    }

请帮助我,到目前为止我已经尝试过但无法取得任何结果。请帮助我如何在执行查询后从 php 文件获得响应。

最佳答案

首先确保您从您的网站获得正确的 JSON 对象 - 尝试将其打印为 Toast.makeText()。就 Web 浏览器保留 html 注释而言,android 会获取它作为响应。

AsyncTask 对象和类不是按照您提供的方式设计的,而且您不能在 doInBackground() 中进行任何 UI 操作。 AsyncTask 的制作方式不会阻止 GUI。 这是一个没有太大区别的示例,它如何使用 AsyncTask 类中的方法:

class Logging extends AsyncTask<String,String,Void>{
    JSONObject json=null;
    String output="";
    String log=StringCheck.buildSpaces(login.getText().toString());
    String pas=StringCheck.buildSpaces(password.getText().toString());
    String url="http://www.mastah.esy.es/webservice/login.php?login="+log+"&pass="+pas;

    protected void onPreExecute() {
        Toast.makeText(getApplicationContext(), "Operation pending, please wait", Toast.LENGTH_SHORT).show();
     }

    @Override
    protected Void doInBackground(String... params) {
        HttpClient client = new DefaultHttpClient();
        HttpGet request = new HttpGet(url);
        request.addHeader("User-Agent", "User-Agent");
        HttpResponse response;
        try {
            response = client.execute(request);
            BufferedReader br = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));
            String line="";
            StringBuilder result = new StringBuilder();
            while ((line = br.readLine()) != null) {
                result.append(line);
            }
            output=result.toString();
        } catch (ClientProtocolException e) {
            Toast.makeText(getApplicationContext(), "Connection problems", Toast.LENGTH_LONG).show();
        } catch (IOException e) {
            Toast.makeText(getApplicationContext(), "Conversion problems", Toast.LENGTH_LONG).show();
        }
        return null;
    }

    @Override
    protected void onPostExecute(Void w) {
        try {
            json = new JSONObject(output);
            if(json.getInt("err")==1){
                Toast.makeText(getApplicationContext(), json.getString("msg"), Toast.LENGTH_LONG).show();
            }else{
                String id_user="-1";
                Toast.makeText(getApplicationContext(), json.getString("msg"), Toast.LENGTH_LONG).show();
                JSONArray arr = json.getJSONArray("data");
                for(int i =0;i<arr.length();i++){
                    JSONObject o = arr.getJSONObject(i);
                    id_user = o.getString("id_user");
                }
                User.getInstance().setName(log);
                User.getInstance().setId(Integer.valueOf(id_user));
                Intent i = new Intent(getApplicationContext(),Discover.class);
                startActivity(i);
            }
        } catch (JSONException e) {
        }
        super.onPostExecute(w);
    }   
}

PHP 文件内容:

$data = array(
    'err' => 0,
    'msg' => "",
    'data' => array(),
);

$mysqli = new MySQLi($dbhost,$dbuser,$dbpass,$dbname);
if($mysqli->connect_errno){
    $data['err'] = 1;
    $data['msg'] = "Brak polaczenia z baza";
    exit(json_encode($data));
}

if(isset($_GET['login']) && isset($_GET['pass'])){
    $mysqli->query("SET CHARACTER SET 'utf8';");
    $query = $mysqli->query("SELECT banned.id_user FROM banned JOIN user ON user.id_user = banned.id_user WHERE user.login ='{$_GET['login']}' LIMIT 1;");
    if($query->num_rows){
        $data['err']=1;
        $data['msg']="User banned";
        exit(json_encode($data));
    }else{
        $query = $mysqli->query("SELECT login FROM user WHERE login='{$_GET['login']}' LIMIT 1;");
        if($query->num_rows){
            $query = $mysqli->query("SELECT pass FROM user WHERE pass ='{$_GET['pass']}' LIMIT 1;");
            if($query->num_rows){
                $data['msg']="Logged IN!";
                $query = $mysqli->query("SELECT id_user FROM user WHERE login='{$_GET['login']}' LIMIT 1;");
                $data['data'][]=$query->fetch_assoc();
                exit(json_encode($data));
            }else{
                $data['err']=1;
                $data['msg']="Wrong login credentials.";
                exit(json_encode($data));
            }
        }else{
            $data['err']=1;
            $data['msg']="This login doesn't exist.";
            exit(json_encode($data));
        }
    }
}else{
    $data['err']=1;
    $data['msg']="Wrong login credentials";
    exit(json_encode($data));
}

我已经为我的应用程序创建了一个小字典 $data。我使用它的 err 键作为标志来知道是否出现任何错误,msg 通知用户操作结果和 data 发送 JSON 对象。

如果 if(response == true) 存在的话,你想用它做的事情类似于我在 onPostExecute(Void w) 方法中使用的构造异步任务:

if(json.getInt("err")==1){
    //something went wrong
}else{
    //everything is okay, get JSON, inform user, start new Activity
}

这也是我使用 $data['data'] 获取 JSON 响应的方式:

if($query->num_rows){
        while($res=$query->fetch_assoc()){
            $data['data'][]=$res;
        }
        exit(json_encode($data));
}

关于java - 为什么函数不从android中的php获取数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32092590/

相关文章:

php - javascript 和 php 中字符串与数组的处理速度,以及数组是否可以在不进行操作的情况下传递给 php?

android - 谷歌播放服务 5.0.77

android - Nexus 6 和三星 Galaxy S6 的存储和网络设备驱动程序源代码

php - 通过 Cron 显示 PHP 脚本运行的次数

java - Android Studio 突然在 Logcat 中显示太多日志

java - 如何使用 Spring Boot 创建列表类型 View 以从数据库中获取所有记录?

java - javafx 8 中的自定义 3D 立方体蒙皮

php - 在数据库更新时重定向用户

android - ViewHolder 不起作用

java - 在每个附加 for 循环的方法调用之前添加类名