Как отобразить / запросить объект JSON с помощью Android Volley?

У меня возникла проблема в Android Studio о том, как запросить JSON Object.

Мой Logcat может печатать только String onResponse, но не значение JSONObject. У меня проблема в строке try {} внутри AccessActivity.java

Мое объяснение кода как ниже.

У меня есть эти выходные данные объекта JSON, которые я получаю из базы данных MySQL.

{
"access":"PA001",
"password":"123",
"fullname":"ARCADE",
"branch":"HQ",
"section":"MPR"}

В моем PHP-коде я получаю данные и кодирую их как объект JSON.

access.php

<?php
$conn = mysqli_connect("","","","");
if(
isset($_POST['access']) &&
isset($_POST['password'])
){
$access     = $_POST['access'];
$password   = $_POST['password'];
$sql = "SELECT * FROM table WHERE access = '$access' AND password = '$password' ";
$result = mysqli_query($conn, $sql);
if($result && mysqli_num_rows($result) > 0){
while($row = mysqli_fetch_array($result)){

$accessdb     = $row['access'];
$passworddb   = $row['password'];
$fullnamedb   = $row['fullname'];
$branchdb     = $row['branch'];
$sectiondb    = $row['section'];

echo "success_access";

$response = array('access' => $accessdb, 'password' => $passworddb, 'fullname' => $fullnamedb, 'branch' => $branchdb, 'section' => $sectiondb);
echo json_encode($response);
}
mysqli_free_result($result);
} else {
echo "access_failed";
}
}
?>

Но моя проблема возникает в Android Studio,

  1. Я даже не могу напечатать Log.e (TAG, «JSON Object =» + jsonObject);
  2. Я не могу использовать значение объекта JSON в следующем упражнении.

Вот мой код

AccessActivity.java

public class AccessActivity extends AppCompatActivity{

final String TAG = this.getClass().getName();
EditText etAccess, etPassword;
Button bLogin;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);

etAccess        = (EditText)findViewById(R.id.etAccess);
etPassword      = (EditText)findViewById(R.id.etPassword);
bLogin          = (Button)findViewById(R.id.bLogin);
bLogin.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String url = "http://localhost/access.php";
StringRequest stringRequest = new StringRequest(Request.Method.POST, url, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.e(TAG, "Response is = " + response);
if(response.equals("success_access")){
try {
JSONObject jsonObject = new JSONObject(response);
Log.e(TAG, "JSON Object is = " + jsonObject);

final String accessdb   = jsonObject.getString("access");
final String passworddb = jsonObject.getString("password");
final String fullnamedb = jsonObject.getString("fullname");
final String branchdb   = jsonObject.getString("branch");
final String sectiondb  = jsonObject.getString("branch");

Intent intent = new Intent(AccessActivity.this, NextActivity.class);
intent.putExtra("access",   accessdb);
intent.putExtra("password", passworddb);
intent.putExtra("fullname", fullnamedb);
intent.putExtra("branch",   branchdb);
intent.putExtra("section",  sectiondb);
AccessActivity.this.startActivity(intent);
} catch (JSONException e) {
e.printStackTrace();
}
} else{
Toast.makeText(getApplicationContext(), "Access Error", Toast.LENGTH_SHORT).show();
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(getApplicationContext(), "Volley Error", Toast.LENGTH_SHORT).show();
}
}){
@Override
protected Map<String, String> getParams() throws AuthFailureError {
Map<String, String> params = new HashMap<>();
params.put("access",   etAccess.getText().toString());
params.put("password", etPassword.getText().toString());
return params;
}
};
MySingleton.getInstance(getApplicationContext()).addToRequestQueue(stringRequest);
}
});
}
}

ОБНОВИТЬ :

мой logcat отобразить это

08-22 10:22:22.059 19801-19908/com.apps.test D/NetworkSecurityConfig: No Network Security Config specified, using platform default
08-22 10:22:22.064 19801-19801/com.apps.test E/my.com.apps.test.Activity: Response is = success_access{"access":"PA001","password":"123","fullname":"ARCADE","branch":"HQ","section":"HQ"}
08-22 10:22:22.112 19801-19825/com.apps.test D/EGL_emulation: eglMakeCurrent: 0xb3305060: ver 2 0 (tinfo 0xb3303200)
08-22 10:22:22.128 19801-19825/com.apps.test D/EGL_emulation: eglMakeCurrent: 0xb3305060: ver 2 0 (tinfo 0xb3303200)
08-22 10:22:22.134 19801-19825/com.apps.test D/EGL_emulation: eglMakeCurrent: 0xb3305060: ver 2 0 (tinfo 0xb3303200)
08-22 10:22:22.140 19801-19825/com.apps.test D/EGL_emulation: eglMakeCurrent: 0xb3305060: ver 2 0 (tinfo 0xb3303200)
08-22 10:22:23.697 19801-19825/com.apps.test D/EGL_emulation: eglMakeCurrent: 0xb3305060: ver 2 0 (tinfo 0xb3303200)
08-22 10:22:25.751 19801-19825/com.apps.test D/EGL_emulation: eglMakeCurrent: 0xb3305060: ver 2 0 (tinfo 0xb3303200)
08-22 10:22:25.780 19801-19825/com.apps.test D/EGL_emulation: eglMakeCurrent: 0xb3305060: ver 2 0 (tinfo 0xb3303200)

Спасибо, если кто-то может помочь мне решить эту проблему. Благодарю.

0

Решение

Попробуй это.

В AccessActivity

 Intent intent = new Intent(AccessActivity.this, NextActivity.class);
intent.putExtra("access",   accessdb);
intent.putExtra("password", passworddb);
intent.putExtra("fullname", fullnamedb);
intent.putExtra("branch",   branchdb);
intent.putExtra("section",  sectiondb);
AccessActivity.this.startActivity(intent);

менять

LoginActivity.this.startActivity(intent);

в

AccessActivity.this.startActivity(intent);

В NextActivity

Intent intent = getIntent();
String access = intent.getStringExtra("access");
String password = intent.getStringExtra("password");
String fullname = intent.getStringExtra("fullname");
String branch = intent.getStringExtra("branch");
String section = intent.getStringExtra("section");

отредактированный

менять

if(response.equals("success_access")){
}

в

if(response.contains("success_access")){
}

И согласно вашему коду.
Вы должны убедиться, что ваша текущая активность com.apps.test.AccessActivity или же com.apps.test.AccessActivity,

отредактированный

изменить на

if (response.contains("success_access")) {
String res = response.substring(response.indexOf("{"));
try {
JSONObject jsonObject = new JSONObject(res);
final String accessdb = jsonObject.getString("access");
final String passworddb = jsonObject.getString("password");
final String fullnamedb = jsonObject.getString("fullname");
final String branchdb = jsonObject.getString("branch");
final String sectiondb = jsonObject.getString("branch");
Log.e("Tag", accessdb);

} catch (JSONException e) {
e.printStackTrace();
}
}
0

Другие решения

Вы запрашиваете JsonObject?
Похоже, вы хорошо разбираетесь в StringRequest, так что плохо держите его простым. Измени свой StringRequest к JsonObjectRequest,

0

Проблема:

Как вы можете видеть в своем logcat, ответ, который вы получаете от сервера: success_access{"access":"PA001","password":"123","fullname":"ARCADE","branch":"HQ","section":"HQ"}

Во-первых, это недействительно JSON,
Кроме того, это значение response переменная.
Теперь ваш response.equals("success_access") никогда не вернет true, и, следовательно, контроль кода никогда не войдет в if блок.

Решение :

В идеале не должно быть лишней строки, такой как success_accessВаш ответ должен быть JSON объект ВСЕГДА, содержащий одно указанное поле ( result фейлд к примеру). Чтобы показать успех, ваш JSON будет выглядеть примерно так:

{
result : "success_access",
/* other parameters down here */
}

И в случае неудачи:

{
result : "access_failed"}

И тогда ваш код должен преобразовать respose строка в JSON (ваш серверный код должен убедиться, что он всегда возвращает действительный JSON), проверьте значение result поле и продолжить.

Быстрая починка :

Измените свой код на:

  ....
Log.e(TAG, "Response is = " + response);
String result = response.replace("{.*}","");
String jsonString = response.replace(result, "");

if(result.equals("success_access")){
try {
JSONObject jsonObject = new JSONObject(jsonString);
....
0
По вопросам рекламы [email protected]