вам просто потрібно імпортувати це
import org.json.JSONObject;
constructing the String that you want to send
JSONObject param=new JSONObject();
JSONObject post=new JSONObject();
я використовую два об'єкти, оскільки ви можете мати jsonObject в іншому
post.put("username(here i write the key)","someusername"(here i put the value);
post.put("message","this is a sweet message");
post.put("image","http://localhost/someimage.jpg");
post.put("time": "present time");
то я помістив пост json в інший подібний
param.put("post",post);
це метод, який я використовую для подання запиту
makeRequest(param.toString());
public JSONObject makeRequest(String param)
{
try
{
встановлення з'єднання
urlConnection = new URL("your url");
connection = (HttpURLConnection) urlConnection.openConnection();
connection.setDoOutput(true);
connection.setRequestMethod("POST");
connection.setRequestProperty("Content-type", "application/json;charset=UTF-8");
connection.setReadTimeout(60000);
connection.setConnectTimeout(60000);
connection.connect();
встановлення вихідного потоку
dataOutputStream = new DataOutputStream(connection.getOutputStream());
Я використовую це, щоб побачити в логкатах, що я надсилаю
Log.d("OUTPUT STREAM " ,param);
dataOutputStream.writeBytes(param);
dataOutputStream.flush();
dataOutputStream.close();
InputStream in = new BufferedInputStream(connection.getInputStream());
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
result = new StringBuilder();
String line;
тут будується рядок
while ((line = reader.readLine()) != null)
{
result.append(line);
}
Я використовую цей журнал, щоб побачити, що відбувається у відповіді
Log.d("INPUTSTREAM: ",result.toString());
інстанціювання json з рядком, який містить відповідь сервера
jResponse=new JSONObject(result.toString());
}
catch (IOException e) {
e.printStackTrace();
return jResponse=null;
} catch (JSONException e)
{
e.printStackTrace();
return jResponse=null;
}
connection.disconnect();
return jResponse;
}