У меня возникла проблема в 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,
Вот мой код
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)
Спасибо, если кто-то может помочь мне решить эту проблему. Благодарю.
Попробуй это.
В 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();
}
}
Вы запрашиваете JsonObject?
Похоже, вы хорошо разбираетесь в StringRequest, так что плохо держите его простым. Измени свой StringRequest
к JsonObjectRequest
,
Проблема:
Как вы можете видеть в своем 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);
....