Android Studio HTTPUrlConnection POST到MYSQL - E / Response Null

时间:2018-05-15 15:52:04

标签: java android mysql spring-boot httpurlconnection

我一直在尝试使用eboot中的springboot和java代码在Android应用程序和MySql数据库之间建立连接。我能够获取用户数据并在应用程序上查看它,但当我尝试发布帖子时,我得到一个空响应。我一直在使用邮递员来查看问题是否在服务器内,但它似乎正常工作。这是代码,感谢您的帮助:

public class MainActivity extends AppCompatActivity {

    Button btnGET;
    Button btnPOST;
    TextView txtJson;
    ProgressDialog pd;

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

        btnGET = (Button) findViewById(R.id.btnGET);
        btnPOST= (Button)findViewById(R.id.btnPST);
        txtJson = (TextView)findViewById(R.id.tvJsonItem);


        btnGET.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                new JsonTaskGET().execute("http://myipaddress/users");
            }
        });

        btnPOST.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                new JsonTaskPOST().execute("http://myipaddress/users");
            }
        });
    }


    private class JsonTaskGET extends AsyncTask<String, String, String> {

        protected void onPreExecute() {
            super.onPreExecute();

            pd = new ProgressDialog(MainActivity.this);
            pd.setMessage("Please wait");
            pd.setCancelable(false);
            pd.show();
        }

        protected String doInBackground(String... params) {


            HttpURLConnection connection = null;
            BufferedReader reader = null;

            try {
                URL url = new URL(params[0]);
                connection = (HttpURLConnection) url.openConnection();
                connection.connect();


                InputStream stream = connection.getInputStream();

                reader = new BufferedReader(new InputStreamReader(stream));

                StringBuffer buffer = new StringBuffer();
                String line = "";

                while ((line = reader.readLine()) != null) {
                    buffer.append(line+"\n");
                    Log.d("Response: ", "> " + line);   //here u ll get whole response...... :-)

                }

                return buffer.toString();


            } catch (MalformedURLException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            } finally {
                if (connection != null) {
                    connection.disconnect();
                }
                try {
                    if (reader != null) {
                        reader.close();
                    }
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
            return null;
        }

        @Override
        protected void onPostExecute(String result) {
            super.onPostExecute(result);
            if (pd.isShowing()){
                pd.dismiss();
            }
            txtJson.setText(result);
        }
    }

    private class JsonTaskPOST extends AsyncTask<String, String, String> {
        String server_response;

        protected void onPreExecute() {
            super.onPreExecute();

            pd = new ProgressDialog(MainActivity.this);
            pd.setMessage("Creating User...");
            pd.setCancelable(true);
            pd.show();
        }

        protected String doInBackground(String... params) {


            HttpURLConnection urlConnection = null;
            BufferedReader reader = null;

            try {
                URL url = new URL(params[0]);
                urlConnection = (HttpURLConnection) url.openConnection();
                urlConnection.setDoOutput(true);
                urlConnection.setDoInput(true);
                urlConnection.setRequestMethod("POST");
                urlConnection.connect();

                DataOutputStream outputStream = new DataOutputStream(urlConnection.getOutputStream ());

                try {
                    JSONObject obj = new JSONObject();
                    obj.put("username" , "value1");
                    obj.put("password" , "value2");
                    obj.put("name" , "value1");
                    obj.put("email" , "value1");

                    outputStream.writeBytes(obj.toString());
                    Log.e("JSON Input", obj.toString());
                    outputStream.flush();
                    outputStream.close();
                } catch (JSONException ex) {
                    ex.printStackTrace();
                }


                int responseCode = urlConnection.getResponseCode();

                if(responseCode == HttpURLConnection.HTTP_OK){
                    server_response = readStream(urlConnection.getInputStream());
                }

            } catch (MalformedURLException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            return null;
        }

        @Override
        protected void onPostExecute(String s) {
            super.onPostExecute(s);

            if (pd.isShowing()){
                pd.dismiss();
            }

            Log.e("Response", "" + server_response);
        }
    }

    public static String readStream(InputStream in) {
        BufferedReader reader = null;
        StringBuffer response = new StringBuffer();
        try {
            reader = new BufferedReader(new InputStreamReader(in));
            String line = "";
            while ((line = reader.readLine()) != null) {
                response.append(line);
            }
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (reader != null) {
                try {
                    reader.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        return response.toString();
    }
}

LOG:

05-15 11:22:03.044 22325-22385/com.example.isccg.jsonmyqlrestful E/JSON Input!!!: {"username":"value1","password":"value2","name":"value1","email":"value1"}
05-15 11:22:03.045 22325-22385/com.example.isccg.jsonmyqlrestful I/System.out: [OkHttp] sendRequest>>
05-15 11:22:03.046 22325-22385/com.example.isccg.jsonmyqlrestful I/System.out: [OkHttp] sendRequest<<
05-15 11:22:03.553 22325-22341/com.example.isccg.jsonmyqlrestful D/Surface: Surface::disconnect(this=0x9b103700,api=1)
05-15 11:22:03.555 22325-22341/com.example.isccg.jsonmyqlrestful D/GraphicBuffer: unregister, handle(0x9945c180) (w:552 h:270 s:560 f:0x1 u:0x000b00)
05-15 11:22:03.556 22325-22341/com.example.isccg.jsonmyqlrestful D/GraphicBuffer: unregister, handle(0x9945c240) (w:552 h:270 s:560 f:0x1 u:0x000b00)
    unregister, handle(0x9945c300) (w:552 h:270 s:560 f:0x1 u:0x000b00)
05-15 11:22:03.556 22325-22341/com.example.isccg.jsonmyqlrestful D/Surface: Surface::disconnect(this=0x9b103700,api=1)
05-15 11:22:03.581 22325-22325/com.example.isccg.jsonmyqlrestful D/WindowClient: Remove from mViews: DecorView@4410e7[], this = android.view.WindowManagerGlobal@8938432
05-15 11:22:03.581 22325-22325/com.example.isccg.jsonmyqlrestful E/Response: null
05-15 11:22:03.583 22325-22325/com.example.isccg.jsonmyqlrestful V/InputMethodManager: onWindowFocus: null softInputMode=32 first=false flags=#81810100

这是我得到空响应的地方:

 @Override
    protected void onPostExecute(String s) {
        super.onPostExecute(s);

        if (pd.isShowing()){
            pd.dismiss();
        }

        Log.e("Response", "" + server_response);
    }
}

这是我得到的服务器端错误:

.RepositoryRestExceptionHandler : No suitable HttpMessageConverter found to read request body into object of type class com.iscc.restservice.entity.User from request with content type of application/x-www-form-urlencoded;charset=UTF-8!

0 个答案:

没有答案