ANDROID — Как отобразить значение базы данных mysql php в textview в Android studio

#java #php #mysql #json #android-studio

#java #php #mysql #json #android-studio

Вопрос:

Я искал некоторые ссылки для отображения моей базы данных значений в Android с помощью JSON, но у меня возникли проблемы с ключевым словом, чтобы найти его, вот весь мой код, чтобы попробовать, пожалуйста, CMIIW, я поместил свой код и БД в hostinger, чтобы здесь было проще

php код

dbconfig.php

 $servername = "localhost";
$username = "root";
$password = "";
$dbname = "data_kuesioner";
  

send_data.php

 <?php
include 'dbconfig.php';
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
} 

$sql = "SELECT * FROM pertanyaan";
$result = $conn->query($sql);

if ($result->num_rows > 0) {
    while($row[] = $result->fetch_assoc()) {

       $json = json_encode($row);
    }
} else {
    echo "0 results";
}
echo $json;
$conn->close();
?>
  

код Android

MainActivity.java

 package flix.yudi.okhttp;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;

import java.io.IOException;
import java.util.concurrent.ExecutionException;

import okhttp3.MediaType;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.RequestBody;
import okhttp3.Response;

public class MainActivity extends AppCompatActivity {
    private EditText edtText;
    private TextView outputText;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        edtText = (EditText) findViewById(R.id.editText1);
        outputText = (TextView) findViewById(R.id.textView1);
    }

    public void downloadUrl(View view) {

        String url = "http://"   edtText.getText().toString();
        OkHttpHandler handler = new OkHttpHandler();
        String result = null;
        try {
            result = handler.execute(url).get();
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (ExecutionException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        outputText.append(result   "n");
    }
}
  

OkHttpHandler.java

 package flix.yudi.okhttp;
import android.os.AsyncTask;

import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;


public class OkHttpHandler extends AsyncTask<String, Void, String> {

    OkHttpClient client = new OkHttpClient();
    @Override
    protected String doInBackground(String... params) {
        Request.Builder builder = new Request.Builder();
        builder.url(params[0]);
        Request request = builder.build();
        try {
            Response response = client.newCall(request).execute();
            return response.body().string();
        } catch (Exception e) {
        }
        return null;
    }
}
  

но когда я запускаю программу, приложение отображает другой интерфейс ниже

Рис

Комментарии:

1. ваш URL возвращает HTML, а не json. и ваш скрипт также будет выводить не json, если запрос не находит данных.

2. я нашел некоторый код для получения json здесь , но я не знаю, куда мне поместить код » public static final MediaType JSON = MediaType.parse («application / json; charset = utf-8»); «, у вас есть простой код для получения json, сэр?

Ответ №1:

Ваш URL возвращает «текст / html», вы можете попробовать поместить этот заголовок в свой send_data.php чтобы изменить возврат к json.

 header('Content-Type: application/json; charset=utf-8');