Android org.json.JSONException:输入字符XYZ处结束

Android org.json.JSONException:输入字符XYZ处结束,android,json,android-volley,Android,Json,Android Volley,我知道这个问题众所周知,但到目前为止我还无法解决。 最后,我有一个项目,数据完美地存储在DB(localhost)中。我正在使用www.000webhost.com。问题不在PHP文件或我的应用程序的连接中。来源。 问题发生在 JSONObject jsonResponse=新的JSONObject(响应) 在这篇文章中,有人写道解决方案是: 改变 JSONObject jsonObject = new JSONObject(result); 到 result=getJSONUrl(url)/

我知道这个问题众所周知,但到目前为止我还无法解决。
最后,我有一个项目,数据完美地存储在DB(localhost)中。我正在使用www.000webhost.com。问题不在PHP文件或我的应用程序的连接中。来源。
问题发生在

JSONObject jsonResponse=新的JSONObject(响应)

在这篇文章中,有人写道解决方案是:

改变

JSONObject jsonObject = new JSONObject(result);

result=getJSONUrl(url)//
在这个stackover问题org.json.JSONException:字符输入的结尾有人写道解决方案是这样的

(一些代码)

嗯,那个问题不是用截击。所以,
response=getJSONUrl(response)不适合您的情况

所以问题不在于php文件或我的应用程序的连接

你是怎么测试的?您是否正在向Android应用程序外部的PHP文件发出POST请求

你链接到的同一个问题也说

请检查浏览器中的PHP文件URL,如果获取数据意味着您在android端遇到问题,如果浏览器未显示数据,则表示PHP文件存在问题

如果您正在检查PHP脚本,是否返回了任何JSON数据

您的错误表示返回了一个空页面

字符0处输入结束

空页面不是JSON对象,因此问题实际上源自PHP

您也可以像这样在Android中进行测试

    Response.Listener<String> responseListener = new Response.Listener<String>() {
        @Override
        public void onResponse(String response) {
            try {
                Log.d("response", "Size: "+response.length());
Response.Listener responseListener=newresponse.Listener(){
@凌驾
公共void onResponse(字符串响应){
试一试{
Log.d(“响应”,“大小:”+response.length());
如果在日志中看到
Size:0
,则会得到一个空字符串


顺便说一句,Volley还提供了一个
JSONObject请求
类,使得
新建JSONObject(响应)
不是必需的。

您的JSONObject不在其中。我尝试了这个响应=getJSONUrl(响应);JSONObject JSONObject=new JSONObject(响应);但是getJSONUrl方法基本上不存在。你能告诉我这一行是什么吗:
RegisterActivity.java:43
在这一行中,我有一个JSONObject jsonResponse=new JSONObject(response);但是我尝试了我上面解释的方法。但没有成功:(响应是什么。您是否尝试记录它?我的朋友,数据完全存储在数据库中。数据已保存!我可以在我的表(localhost)中查看信息).所以我认为连接很好。不是吗?数据库可能很好,但是POST请求需要将一些JSON回显到page@AlienJava尝试在logcat中打印输出,您得到的肯定是空字符串。@cricket\u 007非常感谢!几分钟前我删除了php文件中的echo,因为在另一个堆栈问题中,我读到了没有“echo”的内容工作正常!但是解决方案是在json_encode($response)之前再次写入“echo”;非常感谢!!!!欢迎。只是提醒一下:运行本地web服务器和数据库不需要WebHost
package com.tonikamitv.loginregister;

import android.app.AlertDialog;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;

import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.toolbox.Volley;

import org.json.JSONException;
import org.json.JSONObject;

public class RegisterActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_register);

        final EditText etAge = (EditText) findViewById(R.id.etAge);
        final EditText etName = (EditText) findViewById(R.id.etName);
        final EditText etUsername = (EditText) findViewById(R.id.etUsername);
        final EditText etPassword = (EditText) findViewById(R.id.etPassword);
        final Button bRegister = (Button) findViewById(R.id.bRegister);

        bRegister.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                final String name = etName.getText().toString();
                final String username = etUsername.getText().toString();
                final int age = Integer.parseInt(etAge.getText().toString());
                final String password = etPassword.getText().toString();

                Response.Listener<String> responseListener = new Response.Listener<String>() {
                    @Override
                    public void onResponse(String response) {
                        try {
                            response=getJSONUrl(response);  
                            JSONObject jsonResponse = new JSONObject(response);
                            boolean success = jsonResponse.getBoolean("success");
                            if (success) {
                                Intent intent = new Intent(RegisterActivity.this, LoginActivity.class);
                                RegisterActivity.this.startActivity(intent);
                            } else {
                                AlertDialog.Builder builder = new AlertDialog.Builder(RegisterActivity.this);
                                builder.setMessage("Register Failed")
                                        .setNegativeButton("Retry", null)
                                        .create()
                                        .show();
                            }
                        } catch (JSONException e) {
                            e.printStackTrace();
                        }
                    }
                };

                RegisterRequest registerRequest = new RegisterRequest(name, username, age, password, responseListener);
                RequestQueue queue = Volley.newRequestQueue(RegisterActivity.this);
                queue.add(registerRequest);
            }
        });
    }
}
package com.tonikamitv.loginregister;

import com.android.volley.Response;
import com.android.volley.toolbox.StringRequest;

import java.util.HashMap;
import java.util.Map;

public class RegisterRequest extends StringRequest {
    private static final String REGISTER_REQUEST_URL = "https://yourURL/Register.php";
    private Map<String, String> params;

    public RegisterRequest(String name, String username, int age, String password, Response.Listener<String> listener) {
        super(Method.POST, REGISTER_REQUEST_URL, listener, null);
        params = new HashMap<>();
        params.put("name", name);
        params.put("age", age + "");
        params.put("username", username);
        params.put("password", password);
    }

    @Override
    public Map<String, String> getParams() {
        return params;
    }
}
5-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err: org.json.JSONException: End of input at character 0 of 
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at org.json.JSONTokener.syntaxError(JSONTokener.java:450)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at org.json.JSONTokener.nextValue(JSONTokener.java:97)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at org.json.JSONObject.<init>(JSONObject.java:156)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at org.json.JSONObject.<init>(JSONObject.java:173)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at com.tonikamitv.loginregister.RegisterActivity$1$1.onResponse(RegisterActivity.java:43)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at com.tonikamitv.loginregister.RegisterActivity$1$1.onResponse(RegisterActivity.java:39)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at com.android.volley.toolbox.StringRequest.deliverResponse(StringRequest.java:60)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at com.android.volley.toolbox.StringRequest.deliverResponse(StringRequest.java:30)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:99)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at android.os.Handler.handleCallback(Handler.java:739)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at android.os.Handler.dispatchMessage(Handler.java:95)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at android.os.Looper.loop(Looper.java:135)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at android.app.ActivityThread.main(ActivityThread.java:5910)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at java.lang.reflect.Method.invoke(Native Method)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at java.lang.reflect.Method.invoke(Method.java:372)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1405)
    05-02 22:17:35.391 1041-1041/com.tonikamitv.loginregister W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1200)
    05-02 22:24:07.721 1041-1041/com.tonikamitv.loginregister D/ViewRootImpl: ViewPostImeInputStage ACTION_DOWN
    05-02 22:25:31.951 1041-1041/com.tonikamitv.loginregister W/IInputConnectionWrapper: showStatusIcon on inactive InputConnection
    Response.Listener<String> responseListener = new Response.Listener<String>() {
        @Override
        public void onResponse(String response) {
            try {
                Log.d("response", "Size: "+response.length());