Как вызвать веб-службу RESTful с Android?
Я написал веб-службу REST в NetSE IDE, используя фреймворк Jersey и Java.
Для каждого запроса пользователю необходимо указать имя пользователя и пароль, я знаю, что эта проверка подлинности не является лучшей практикой (с использованием команды curl, например: curl -u username:password -X PUT http://localhsot:8080/user
).
Теперь я хочу вызвать веб-службу REST из класса Android.
Как мне это сделать?
У меня есть класс Android, который использует DefaultHttpClient
и CredentialUsernameAndPassword
, но когда я запускаю его в Eclipse, иногда я получаю исключение во время выполнения или исключение SDK.
Ответы
Ответ 1
Это пример класса restclient
public class RestClient
{
public enum RequestMethod
{
GET,
POST
}
public int responseCode=0;
public String message;
public String response;
public void Execute(RequestMethod method,String url,ArrayList<NameValuePair> headers,ArrayList<NameValuePair> params) throws Exception
{
switch (method)
{
case GET:
{
// add parameters
String combinedParams = "";
if (params!=null)
{
combinedParams += "?";
for (NameValuePair p : params)
{
String paramString = p.getName() + "=" + URLEncoder.encode(p.getValue(),"UTF-8");
if (combinedParams.length() > 1)
combinedParams += "&" + paramString;
else
combinedParams += paramString;
}
}
HttpGet request = new HttpGet(url + combinedParams);
// add headers
if (headers!=null)
{
headers=addCommonHeaderField(headers);
for (NameValuePair h : headers)
request.addHeader(h.getName(), h.getValue());
}
executeRequest(request, url);
break;
}
case POST:
{
HttpPost request = new HttpPost(url);
// add headers
if (headers!=null)
{
headers=addCommonHeaderField(headers);
for (NameValuePair h : headers)
request.addHeader(h.getName(), h.getValue());
}
if (params!=null)
request.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8));
executeRequest(request, url);
break;
}
}
}
private ArrayList<NameValuePair> addCommonHeaderField(ArrayList<NameValuePair> _header)
{
_header.add(new BasicNameValuePair("Content-Type","application/x-www-form-urlencoded"));
return _header;
}
private void executeRequest(HttpUriRequest request, String url)
{
HttpClient client = new DefaultHttpClient();
HttpResponse httpResponse;
try
{
httpResponse = client.execute(request);
responseCode = httpResponse.getStatusLine().getStatusCode();
message = httpResponse.getStatusLine().getReasonPhrase();
HttpEntity entity = httpResponse.getEntity();
if (entity != null)
{
InputStream instream = entity.getContent();
response = convertStreamToString(instream);
instream.close();
}
}
catch (Exception e)
{ }
}
private static String convertStreamToString(InputStream is)
{
BufferedReader reader = new BufferedReader(new InputStreamReader(is));
StringBuilder sb = new StringBuilder();
String line = null;
try
{
while ((line = reader.readLine()) != null)
{
sb.append(line + "\n");
}
is.close();
}
catch (IOException e)
{ }
return sb.toString();
}
}
Ответ 2
Недавно было обнаружено, что сторонняя библиотека - Square Retrofit может сделать работу очень хорошо.
Определение конечной точки REST
public interface GitHubService {
@GET("/users/{user}/repos")
List<Repo> listRepos(@Path("user") String user,Callback<List<User>> cb);
}
Получение конкретной услуги
RestAdapter restAdapter = new RestAdapter.Builder()
.setEndpoint("https://api.github.com")
.build();
GitHubService service = restAdapter.create(GitHubService.class);
Вызов конечной точки REST
List<Repo> repos = service.listRepos("octocat",new Callback<List<User>>() {
@Override
public void failure(final RetrofitError error) {
android.util.Log.i("example", "Error, body: " + error.getBody().toString());
}
@Override
public void success(List<User> users, Response response) {
// Do something with the List of Users object returned
// you may populate your adapter here
}
});
Библиотека обрабатывает сериализацию json и deserailization для вас. Вы также можете настроить сериализацию и десериализацию.
Gson gson = new GsonBuilder()
.setFieldNamingPolicy(FieldNamingPolicy.LOWER_CASE_WITH_UNDERSCORES)
.registerTypeAdapter(Date.class, new DateTypeAdapter())
.create();
RestAdapter restAdapter = new RestAdapter.Builder()
.setEndpoint("https://api.github.com")
.setConverter(new GsonConverter(gson))
.build();
Ответ 3
Я использую этот REST Client для моего Android. Это выглядит здорово. Хорошая работа Люка.
http://lukencode.com/2010/04/27/calling-web-services-in-android-using-httpclient/
Ответ 4
Прекратите все, что вы делаете!:)
Внедрите RESTful client как SERVICE и делегируйте интенсивный сетевой материал независящему от активности компоненту: SERVICE.
Смотрите это проницательное видео
http://www.youtube.com/watch?v=xHXn3Kg2IQE, где Вергилий Добжански объясняет свой подход к этой проблеме...
Ответ 5
Я использовал OkHttpClient
для вызова спокойной веб-службы. Это очень просто.
OkHttpClient httpClient = new OkHttpClient();
Request request = new Request.Builder()
.url(url)
.build();
Response response = httpClient.newCall(request).execute();
String body = response.body().string()
Ответ 6
Использование Spring для Android с помощью RestTemplate
https://spring.io/guides/gs/consuming-rest-android/
// The connection URL
String url = "https://ajax.googleapis.com/ajax/" +
"services/search/web?v=1.0&q={query}";
// Create a new RestTemplate instance
RestTemplate restTemplate = new RestTemplate();
// Add the String message converter
restTemplate.getMessageConverters().add(new StringHttpMessageConverter());
// Make the HTTP GET request, marshaling the response to a String
String result = restTemplate.getForObject(url, String.class, "Android");
Ответ 7
Какой исходный код? Если JAVA, то вы можете использовать REST с Java (JAX-RS), используя Джерси.
На стороне Android вы можете использовать этот простой RestClient для работы с этой службой REST.
Для JSON ↔ Сопоставление объектов с обеих сторон (Android, Java back-end) вы можете использовать GSON.
Ответ 8
Возможно, поздно или, возможно, вы уже использовали его раньше, но есть еще один, называемый ksoap, и это довольно удивительно.. Это также включает тайм-ауты и может эффективно анализировать любой веб-сервис на основе SOAP. Я также внес несколько изменений в соответствии с моим анализом. Посмотрите его
Ответ 9
Следуйте приведенным ниже инструкциям, чтобы использовать RestFul в android.
Step1
Создайте пустой проект андроида.
Step2
Требуется разрешение на доступ в Интернет. напишите приведенный ниже код в файле AndroidManifest.xml.
<uses-permission android:name="android.permission.INTERNET">
</uses-permission>
Step3
Требуется URL-адрес RestFul, который запущен на другом сервере или на той же машине.
Step4
Сделайте клиент RestFul, который расширяет AsyncTask. См. RestFulPost.java.
Step5
Создайте класс DTO для запроса и ответа RestFull.
RestFulPost.java
package javaant.com.consuming_restful.restclient;
import android.app.ProgressDialog;
import android.content.Context;
import android.os.AsyncTask;
import android.util.Log;
import com.google.gson.Gson;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import java.util.Map;
import javaant.com.consuming_restful.util.Util;
/**
* Created by Nirmal Dhara on 29-10-2015.
*/
public class RestFulPost extends AsyncTask<map, void,="" string=""> {
RestFulResult restFulResult = null;
ProgressDialog Asycdialog;
String msg;
String task;
public RestFulPost(RestFulResult restFulResult, Context context, String msg,String task) {
this.restFulResult = restFulResult;
this.task=task;
this.msg = msg;
Asycdialog = new ProgressDialog(context);
}
@Override
protected String doInBackground(Map... params) {
String responseStr = null;
Object dataMap = null;
HttpPost httpost = new HttpPost(params[0].get("url").toString());
try {
dataMap = (Object) params[0].get("data");
Gson gson = new Gson();
Log.d("data map", "data map------" + gson.toJson(dataMap));
httpost.setEntity(new StringEntity(gson.toJson(dataMap)));
httpost.setHeader("Accept", "application/json");
httpost.setHeader("Content-type", "application/json");
DefaultHttpClient httpclient= Util.getClient();
HttpResponse response = httpclient.execute(httpost);
int statusCode = response.getStatusLine().getStatusCode();
Log.d("resonse code", "----------------" + statusCode);
if (statusCode == 200)
responseStr = EntityUtils.toString(response.getEntity());
if (statusCode == 404) {
responseStr = "{\n" +
"\"status\":\"fail\",\n" +
" \"data\":{\n" +
"\"ValidUser\":\"Service not available\",\n" +
"\"code\":\"404\"\n" +
"}\n" +
"}";
}
} catch (Exception e) {
e.printStackTrace();
}
return responseStr;
}
@Override
protected void onPreExecute() {
Asycdialog.setMessage(msg);
//show dialog
Asycdialog.show();
super.onPreExecute();
}
@Override
protected void onPostExecute(String s) {
Asycdialog.dismiss();
restFulResult.onResfulResponse(s,task);
}
}
Для получения более подробной информации и полного кода посетите http://javaant.com/consume-a-restful-webservice-in-android/#.VwzbipN96Hs
Ответ 10
Вот моя библиотека, которую я создал для простого вызова Webservice,
Вы можете использовать это, добавив одну строку gradle dependency -
compile 'com.scantity.ScHttpLibrary:ScHttpLibrary:1.0.0'
Вот демонстрация использования.
https://github.com/vishalchhodwani1992/httpLibrary