il vous suffit d'importer ceci
import org.json.JSONObject;
constructing the String that you want to send
JSONObject param=new JSONObject();
JSONObject post=new JSONObject();
im utilisant deux objets car vous pouvez avoir un jsonObject dans un autre
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");
puis je mets le post json dans un autre comme ça
param.put("post",post);
c'est la méthode que j'utilise pour faire une demande
makeRequest(param.toString());
public JSONObject makeRequest(String param)
{
try
{
établissement de la connexion
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();
réglage du flux de sortie
dataOutputStream = new DataOutputStream(connection.getOutputStream());
j'utilise ceci pour voir dans le logcat ce que j'envoie
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;
ici la chaîne est construite
while ((line = reader.readLine()) != null)
{
result.append(line);
}
j'utilise ce journal pour voir ce qu'il arrive dans la réponse
Log.d("INPUTSTREAM: ",result.toString());
instanciation d'un json avec la chaîne qui contient la réponse du serveur
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;
}