Подтвердить что ты не робот

Как отправить запрос POST в JSON с помощью HTTPClient в Android?

Я пытаюсь выяснить, как использовать POST JSON с Android с помощью HTTPClient. Я пытался понять это на некоторое время, я нашел множество примеров в Интернете, но я не могу заставить их работать. Я считаю, что это из-за моего отсутствия знаний JSON/сетей в целом. Я знаю, что есть много примеров, но кто-то может указать мне на реальный учебник? Я ищу шаг за шагом процесс с кодом и объяснение того, почему вы делаете каждый шаг, или того, что делает этот шаг. Это не должно быть сложным, простым будет достаточно.

Опять же, я знаю, что есть масса примеров, я просто действительно ищу пример с объяснением того, что именно происходит и почему он так поступает.

Если кто-то знает о хорошей книге Android об этом, то, пожалуйста, дайте мне знать.

Еще раз спасибо за помощь @terrance, вот код, описанный ниже

public void shNameVerParams() throws Exception{
     String path = //removed
     HashMap  params = new HashMap();

     params.put(new String("Name"), "Value"); 
     params.put(new String("Name"), "Value");

     try {
        HttpClient.SendHttpPost(path, params);
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
 }
4b9b3361

Ответ 1

В этом ответе я использую пример, опубликованный Джастином Грамменсом.

О JSON

JSON обозначает обозначение объекта JavaScript. В свойствах JavaScript можно ссылаться как на object1.name, так и на object['name'];. В примере из статьи используется этот бит JSON.

Детали
Объект-фанат с электронной почтой в качестве ключа и [email protected] в качестве значения

{
  fan:
    {
      email : '[email protected]'
    }
}

Таким образом, эквивалент объекта будет fan.email; или fan['email'];. Оба значения будут одинаковыми '[email protected]'.

О запросе HttpClient

Следующим является то, что наш автор использовал Запрос HttpClient. Я не претендую на то, чтобы быть экспертом во всем этом, поэтому, если у кого-то есть лучший способ выразить некоторые термины, не стесняйтесь.

public static HttpResponse makeRequest(String path, Map params) throws Exception 
{
    //instantiates httpclient to make request
    DefaultHttpClient httpclient = new DefaultHttpClient();

    //url with the post data
    HttpPost httpost = new HttpPost(path);

    //convert parameters into JSON object
    JSONObject holder = getJsonObjectFromMap(params);

    //passes the results to a string builder/entity
    StringEntity se = new StringEntity(holder.toString());

    //sets the post request as the resulting string
    httpost.setEntity(se);
    //sets a request header so the page receving the request
    //will know what to do with it
    httpost.setHeader("Accept", "application/json");
    httpost.setHeader("Content-type", "application/json");

    //Handles what is returned from the page 
    ResponseHandler responseHandler = new BasicResponseHandler();
    return httpclient.execute(httpost, responseHandler);
}

Карта

Если вы не знакомы с структурой данных Map, ознакомьтесь с ссылкой на Java Map. Короче говоря, карта похожа на словарь или хэш.

private static JSONObject getJsonObjectFromMap(Map params) throws JSONException {

    //all the passed parameters from the post request
    //iterator used to loop through all the parameters
    //passed in the post request
    Iterator iter = params.entrySet().iterator();

    //Stores JSON
    JSONObject holder = new JSONObject();

    //using the earlier example your first entry would get email
    //and the inner while would get the value which would be '[email protected]' 
    //{ fan: { email : '[email protected]' } }

    //While there is another entry
    while (iter.hasNext()) 
    {
        //gets an entry in the params
        Map.Entry pairs = (Map.Entry)iter.next();

        //creates a key for Map
        String key = (String)pairs.getKey();

        //Create a new map
        Map m = (Map)pairs.getValue();   

        //object for storing Json
        JSONObject data = new JSONObject();

        //gets the value
        Iterator iter2 = m.entrySet().iterator();
        while (iter2.hasNext()) 
        {
            Map.Entry pairs2 = (Map.Entry)iter2.next();
            data.put((String)pairs2.getKey(), (String)pairs2.getValue());
        }

        //puts email and '[email protected]'  together in map
        holder.put(key, data);
    }
    return holder;
}

<я >

Пожалуйста, не стесняйтесь комментировать любые вопросы, возникающие в связи с этим сообщением, или если я не сделал что-то ясно или не затронул то, о чем вы все еще путаете... и т.д., Что бы ни звучало в вашей голове.

(Я сниму, если Джастин Грэммен не одобрит. Но если нет, то благодарим Джастина за то, что он о нем прочен.)

Обновление

Я просто хочу получить комментарий о том, как использовать код, и понял, что была ошибка в возвращаемом типе. Подпись метода была настроена на возврат строки, но в этом случае она ничего не возвращала. Я изменил подпись к HttpResponse и направит вас по этой ссылке на Получение ответа на HttpResponse переменная path - это url, и я обновляюсь, чтобы исправить ошибку в коде.

Ответ 2

Вот альтернативное решение для ответа @Terrance. Вы можете легко передать на аутсорсинг конверсию. Библиотека Gson делает замечательную работу по преобразованию различных структур данных в JSON и наоборот.

public static void execute() {
    Map<String, String> comment = new HashMap<String, String>();
    comment.put("subject", "Using the GSON library");
    comment.put("message", "Using libraries is convenient.");
    String json = new GsonBuilder().create().toJson(comment, Map.class);
    makeRequest("http://192.168.0.1:3000/post/77/comments", json);
}

public static HttpResponse makeRequest(String uri, String json) {
    try {
        HttpPost httpPost = new HttpPost(uri);
        httpPost.setEntity(new StringEntity(json));
        httpPost.setHeader("Accept", "application/json");
        httpPost.setHeader("Content-type", "application/json");
        return new DefaultHttpClient().execute(httpPost);
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    } catch (ClientProtocolException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
    return null;
}

Аналогично можно использовать Jackson вместо Gson. Я также рекомендую взглянуть на Retrofit, который скрывает для вас весь этот шаблонный код. Для более опытных разработчиков я рекомендую попробовать RxAndroid.

Ответ 3

Я рекомендую использовать HttpURLConnection вместо HttpGet. Поскольку HttpGet уже устарел в Android API уровне 22.

HttpURLConnection httpcon;  
String url = null;
String data = null;
String result = null;
try {
  //Connect
  httpcon = (HttpURLConnection) ((new URL (url).openConnection()));
  httpcon.setDoOutput(true);
  httpcon.setRequestProperty("Content-Type", "application/json");
  httpcon.setRequestProperty("Accept", "application/json");
  httpcon.setRequestMethod("POST");
  httpcon.connect();

  //Write       
  OutputStream os = httpcon.getOutputStream();
  BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(os, "UTF-8"));
  writer.write(data);
  writer.close();
  os.close();

  //Read        
  BufferedReader br = new BufferedReader(new InputStreamReader(httpcon.getInputStream(),"UTF-8"));

  String line = null; 
  StringBuilder sb = new StringBuilder();         

  while ((line = br.readLine()) != null) {  
    sb.append(line); 
  }         

  br.close();  
  result = sb.toString();

} catch (UnsupportedEncodingException e) {
    e.printStackTrace();
} catch (IOException e) {
    e.printStackTrace();
} 

Ответ 4

Слишком много кода для этой задачи, проверьте эту библиотеку https://github.com/kodart/Httpzoid Использует GSON внутри и предоставляет API, который работает с объектами. Все детали JSON скрыты.

Http http = HttpFactory.create(context);
http.get("http://example.com/users")
    .handler(new ResponseHandler<User[]>() {
        @Override
        public void success(User[] users, HttpResponse response) {
        }
    }).execute();

Ответ 5

Существует несколько способов установления соединения HHTP и получения данных из веб-службы RESTFULL. Самый последний из них - GSON. Но прежде чем перейти к GSON, вы должны иметь представление о самом традиционном способе создания HTTP-клиента и выполнить обмен данными с удаленным сервером. Я упомянул оба метода отправки запросов POST и GET с помощью HTTPClient.

/**
 * This method is used to process GET requests to the server.
 * 
 * @param url 
 * @return String
 * @throws IOException
 */
public static String connect(String url) throws IOException {

    HttpGet httpget = new HttpGet(url);
    HttpResponse response;
    HttpParams httpParameters = new BasicHttpParams();
    // Set the timeout in milliseconds until a connection is established.
    // The default value is zero, that means the timeout is not used. 
    int timeoutConnection = 60*1000;
    HttpConnectionParams.setConnectionTimeout(httpParameters, timeoutConnection);
    // Set the default socket timeout (SO_TIMEOUT) 
    // in milliseconds which is the timeout for waiting for data.
    int timeoutSocket = 60*1000;

    HttpConnectionParams.setSoTimeout(httpParameters, timeoutSocket);
    HttpClient httpclient = new DefaultHttpClient(httpParameters);
    try {

        response = httpclient.execute(httpget);

        HttpEntity entity = response.getEntity();
        if (entity != null) {
            InputStream instream = entity.getContent();
            result = convertStreamToString(instream);
            //instream.close();
        }
    } 
    catch (ClientProtocolException e) {
        Utilities.showDLog("connect","ClientProtocolException:-"+e);
    } catch (IOException e) {
        Utilities.showDLog("connect","IOException:-"+e); 
    }
    return result;
}


 /**
 * This method is used to send POST requests to the server.
 * 
 * @param URL
 * @param paramenter
 * @return result of server response
 */
static public String postHTPPRequest(String URL, String paramenter) {       

    HttpParams httpParameters = new BasicHttpParams();
    // Set the timeout in milliseconds until a connection is established.
    // The default value is zero, that means the timeout is not used. 
    int timeoutConnection = 60*1000;
    HttpConnectionParams.setConnectionTimeout(httpParameters, timeoutConnection);
    // Set the default socket timeout (SO_TIMEOUT) 
    // in milliseconds which is the timeout for waiting for data.
    int timeoutSocket = 60*1000;

    HttpConnectionParams.setSoTimeout(httpParameters, timeoutSocket);
    HttpClient httpclient = new DefaultHttpClient(httpParameters);
    HttpPost httppost = new HttpPost(URL);
    httppost.setHeader("Content-Type", "application/json");
    try {
        if (paramenter != null) {
            StringEntity tmp = null;
            tmp = new StringEntity(paramenter, "UTF-8");
            httppost.setEntity(tmp);
        }
        HttpResponse httpResponse = null;
        httpResponse = httpclient.execute(httppost);
        HttpEntity entity = httpResponse.getEntity();
        if (entity != null) {
            InputStream input = null;
            input = entity.getContent();
            String res = convertStreamToString(input);
            return res;
        }
    } 
     catch (Exception e) {
        System.out.print(e.toString());
    }
    return null;
}