вам просто нужно импортировать это
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;
}