#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');