Вопрос

Я искал везде, но не мог найти свой ответ, есть ли способ сделать простой HTTP -запрос? Я хочу запросить PHP -страницу / скрипт на одном из моих веб -сайтов, но я не хочу показывать веб -страницу.

Если возможно, я даже хочу сделать это в фоновом режиме (в Broadcastreceiver)

Это было полезно?

Решение

ОБНОВИТЬ

Это очень старый ответ. Я определенно не буду рекомендовать клиенту Apache больше. Вместо этого используйте:

Оригинальный ответ

Прежде всего, запросите разрешение на доступ к сети, добавьте следующее к своему манифесту:

<uses-permission android:name="android.permission.INTERNET" />

Тогда самый простой способ - использовать Apache HTTP -клиент, связанный с Android:

    HttpClient httpclient = new DefaultHttpClient();
    HttpResponse response = httpclient.execute(new HttpGet(URL));
    StatusLine statusLine = response.getStatusLine();
    if(statusLine.getStatusCode() == HttpStatus.SC_OK){
        ByteArrayOutputStream out = new ByteArrayOutputStream();
        response.getEntity().writeTo(out);
        String responseString = out.toString();
        out.close();
        //..more logic
    } else{
        //Closes the connection.
        response.getEntity().getContent().close();
        throw new IOException(statusLine.getReasonPhrase());
    }

Если вы хотите, чтобы он работал в отдельном потоке, я бы порекомендовал расширить Asynctask:

class RequestTask extends AsyncTask<String, String, String>{

    @Override
    protected String doInBackground(String... uri) {
        HttpClient httpclient = new DefaultHttpClient();
        HttpResponse response;
        String responseString = null;
        try {
            response = httpclient.execute(new HttpGet(uri[0]));
            StatusLine statusLine = response.getStatusLine();
            if(statusLine.getStatusCode() == HttpStatus.SC_OK){
                ByteArrayOutputStream out = new ByteArrayOutputStream();
                response.getEntity().writeTo(out);
                responseString = out.toString();
                out.close();
            } else{
                //Closes the connection.
                response.getEntity().getContent().close();
                throw new IOException(statusLine.getReasonPhrase());
            }
        } catch (ClientProtocolException e) {
            //TODO Handle problems..
        } catch (IOException e) {
            //TODO Handle problems..
        }
        return responseString;
    }

    @Override
    protected void onPostExecute(String result) {
        super.onPostExecute(result);
        //Do anything with response..
    }
}

Затем вы можете сделать запрос:

   new RequestTask().execute("http://stackoverflow.com");

Другие советы

Если у вас нет явной причины выбрать Apache HttpClient, вы должны предпочевать Java.net.urlconnection. Вы можете найти множество примеров того, как использовать его в Интернете.

Мы также улучшили документацию Android, так как ваш оригинальный пост: http://developer.android.com/reference/java/net/httpurlconnection.html

И мы говорили о компромистах на официальном блоге: http://android-developers.blogspot.com/2011/09/androids-http-clients.html

Примечание. Клиент Apache HTTP, в комплекте с Android теперь устарел в пользу Httpurlconnection. Отказ Пожалуйста, смотрите разработчики Android Блог Больше подробностей.

Добавлять <uses-permission android:name="android.permission.INTERNET" /> к вашему проявлению.

Затем вы потратите веб-страницу так:

URL url = new URL("http://www.android.com/");
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
try {
     InputStream in = new BufferedInputStream(urlConnection.getInputStream());
     readStream(in);
}
finally {
     urlConnection.disconnect();
}

Я также предлагаю проводить его на отдельной резьбе:

class RequestTask extends AsyncTask<String, String, String>{

@Override
protected String doInBackground(String... uri) {
    String responseString = null;
    try {
        URL url = new URL(myurl);
        HttpURLConnection conn = (HttpURLConnection) url.openConnection();
        if(conn.getResponseCode() == HttpsURLConnection.HTTP_OK){
            // Do normal input or output stream reading
        }
        else {
            response = "FAILED"; // See documentation for more info on response handling
        }
    } catch (ClientProtocolException e) {
        //TODO Handle problems..
    } catch (IOException e) {
        //TODO Handle problems..
    }
    return responseString;
}

@Override
protected void onPostExecute(String result) {
    super.onPostExecute(result);
    //Do anything with response..
}
}

Увидеть документация Для получения дополнительной информации о обработке ответов и последующих запросов.

Самый простой способ использует Android lib под названием Залп

Volley предлагает следующие преимущества:

Автоматическое планирование сетевых запросов. Несколько одновременных сетевых подключений. Отказ Прозрачный диск и реагирование на диск и память с стандартным Cache Cache Cache. Поддержка приоритетов запроса. Отмена запроса API. Вы можете отменить один запрос, или вы можете установить блоки или объемы запросов, чтобы отменить. Простота настройки, например, для повторения и отката. Сильный упорядочение, которое позволяет легко наполнить ваш интерфейс UI с данными, выявленными асинхронно из сети. Инструменты отладки и отслеживания.

Вы можете отправить запрос HTTP / HTTPS так же просто, как это:

        // Instantiate the RequestQueue.
        RequestQueue queue = Volley.newRequestQueue(this);
        String url ="http://www.yourapi.com";
        JsonObjectRequest request = new JsonObjectRequest(url, null,
            new Response.Listener<JSONObject>() {
                @Override
                public void onResponse(JSONObject response) {
                    if (null != response) {
                         try {
                             //handle your response
                         } catch (JSONException e) {
                             e.printStackTrace();
                         }
                    }
                }
            }, new Response.ErrorListener() {

            @Override
            public void onErrorResponse(VolleyError error) {

            }
        });
        queue.add(request);

В этом случае вам не нужно учитывать «Бег на заднем плане» или «Использовать кеш», как все это уже сделано залп.

private String getToServer(String service) throws IOException {
    HttpGet httpget = new HttpGet(service);
    ResponseHandler<String> responseHandler = new BasicResponseHandler();
    return new DefaultHttpClient().execute(httpget, responseHandler);

}

С уважением

Посмотрите на эту потрясающую новую библиотеку, которая доступна через Gradle :)

build.gradle: compile 'com.apptakk.http_request:http-request:0.1.2'

Использование:

new HttpRequestTask(
    new HttpRequest("http://httpbin.org/post", HttpRequest.POST, "{ \"some\": \"data\" }"),
    new HttpRequest.Handler() {
      @Override
      public void response(HttpResponse response) {
        if (response.code == 200) {
          Log.d(this.getClass().toString(), "Request successful!");
        } else {
          Log.e(this.getClass().toString(), "Request unsuccessful: " + response);
        }
      }
    }).execute();

https://github.com/erf/http-request

С веткой:

private class LoadingThread extends Thread {
    Handler handler;

    LoadingThread(Handler h) {
        handler = h;
    }
    @Override
    public void run() {
        Message m = handler.obtainMessage();
        try {
            BufferedReader in = 
                new BufferedReader(new InputStreamReader(url.openStream()));
            String page = "";
            String inLine;

            while ((inLine = in.readLine()) != null) {
                page += inLine;
            }

            in.close();
            Bundle b = new Bundle();
            b.putString("result", page);
            m.setData(b);
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

        handler.sendMessage(m);
    }
}

Я сделал это для WebService, чтобы преследовать URL, используя GSON Lib:

Клиент:

public EstabelecimentoList getListaEstabelecimentoPorPromocao(){

        EstabelecimentoList estabelecimentoList  = new EstabelecimentoList();
        try{
            URL url = new URL("http://" +  Conexao.getSERVIDOR()+ "/cardapio.online/rest/recursos/busca_estabelecimento_promocao_android");
            HttpURLConnection con = (HttpURLConnection) url.openConnection();

            if (con.getResponseCode() != 200) {
                    throw new RuntimeException("HTTP error code : "+ con.getResponseCode());
            }

            BufferedReader br = new BufferedReader(new InputStreamReader((con.getInputStream())));
            estabelecimentoList = new Gson().fromJson(br, EstabelecimentoList.class);
            con.disconnect();

        } catch (IOException e) {
            e.printStackTrace();
        }
        return estabelecimentoList;
}

Это новый код для запроса HTTP GET / POST в Android. HTTPClient запрещены и могут быть недоступны, насколько это было в моем случае.

Сначала добавьте две зависимости в Build.Gradle:

compile 'org.apache.httpcomponents:httpcore:4.4.1'
compile 'org.apache.httpcomponents:httpclient:4.5'

Затем напишите этот код в ASyncTask в doBackground метод

 URL url = new URL("http://localhost:8080/web/get?key=value");
 HttpURLConnection urlConnection = (HttpURLConnection)url.openConnection();
 urlConnection.setRequestMethod("GET");
 int statusCode = urlConnection.getResponseCode();
 if (statusCode ==  200) {
      InputStream it = new BufferedInputStream(urlConnection.getInputStream());
      InputStreamReader read = new InputStreamReader(it);
      BufferedReader buff = new BufferedReader(read);
      StringBuilder dta = new StringBuilder();
      String chunks ;
      while((chunks = buff.readLine()) != null)
      {
         dta.append(chunks);
      }
 }
 else
 {
     //Handle else
 }

Для меня самый простой способ использовать библиотеку под названием Модернизация2.

Нам просто нужно создать интерфейс, содержащий наш метод запроса, параметры, а также мы можем сделать пользовательский заголовок для каждого запроса:

    public interface MyService {

      @GET("users/{user}/repos")
      Call<List<Repo>> listRepos(@Path("user") String user);

      @GET("user")
      Call<UserDetails> getUserDetails(@Header("Authorization") String   credentials);

      @POST("users/new")
      Call<User> createUser(@Body User user);

      @FormUrlEncoded
      @POST("user/edit")
      Call<User> updateUser(@Field("first_name") String first, 
                            @Field("last_name") String last);

      @Multipart
      @PUT("user/photo")
      Call<User> updateUser(@Part("photo") RequestBody photo, 
                            @Part("description") RequestBody description);

      @Headers({
        "Accept: application/vnd.github.v3.full+json",
        "User-Agent: Retrofit-Sample-App"
      })
      @GET("users/{username}")
      Call<User> getUser(@Path("username") String username);    

    }

И лучшее, мы можем сделать это асинхронно легко, используя метод Enqueue

Поскольку никто из ответов не описал способ выполнения запросов с Okhttp., который очень популярен HTTP-клиент в настоящее время для Android и Java в целом, я собираюсь предоставить простой пример:

//get an instance of the client
OkHttpClient client = new OkHttpClient();

//add parameters
HttpUrl.Builder urlBuilder = HttpUrl.parse("https://www.example.com").newBuilder();
urlBuilder.addQueryParameter("query", "stack-overflow");


String url = urlBuilder.build().toString();

//build the request
Request request = new Request.Builder().url(url).build();

//execute
Response response = client.newCall(request).execute();

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

Используйте залп, как указано выше. Добавить следующие в build.gradle (Module: App)

implementation 'com.android.volley:volley:1.1.1'

Добавьте следующее в AndroidManifest.xml:

<uses-permission android:name="android.permission.INTERNET" />

И добавить в соответствие с вами код деятельности:

public void httpCall(String url) {

    RequestQueue queue = Volley.newRequestQueue(this);

    StringRequest stringRequest = new StringRequest(Request.Method.GET, url,
            new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {
                    // enjoy your response
                }
            }, new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {
                    // enjoy your error status
                }
    });

    queue.add(stringRequest);
}

Он заменяет HTTP-клиент, и это очень просто.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top