我正在创建一个简单的Android应用程序,根据用户的奖励积分发放奖励。 每个人都应该有自己的用户名,密码,奖励积分和愿望清单等。
我打算在Heroku上使用PostgreSQL数据库,并在Heroku上编写REST API。
现在我不确定我的ANDROID APPLICATION本身需要什么? (除了代码)
1)我需要另一个REST API吗?
2)我需要另一个数据库吗?
3)我的Android应用程序如何与REST API(与Heroku上的PostgreSQL通信)进行通信? - >我需要为此编写什么java代码?
非常感谢。 总的初学者很难找到合适的资源。 :(
答案 0 :(得分:0)
1)我需要另一个REST API吗?
您只需要一个API作为数据的前门。
2)我需要另一个数据库吗?
不,你不需要另一个数据库。如果您发现需要使用本地存储,那么您可以开始考虑使用SQLite实例或在适用的情况下存储到SD卡,也可以选择首选项。
3)我的Android应用程序如何与REST API通信 (它与Heroku上的PostgreSQL通信)? - >什么java代码 我需要写这个吗?
您可以使用HttpClient
在创建服务后调用该服务。网上有很多例子,可以找到一个这样的例子here。一旦您与API交互,它将随后通过DAL或其他抽象层调用数据库并返回所请求的数据。
public class RestClient {
private ArrayList <NameValuePair> params;
private ArrayList <NameValuePair> headers;
private String url;
private int responseCode;
private String message;
private String response;
public String getResponse() {
return response;
}
public String getErrorMessage() {
return message;
}
public int getResponseCode() {
return responseCode;
}
public RestClient(String url)
{
this.url = url;
params = new ArrayList<NameValuePair>();
headers = new ArrayList<NameValuePair>();
}
public void AddParam(String name, String value)
{
params.add(new BasicNameValuePair(name, value));
}
public void AddHeader(String name, String value)
{
headers.add(new BasicNameValuePair(name, value));
}
public void Execute(RequestMethod method) throws Exception
{
switch(method) {
case GET:
{
//add parameters
String combinedParams = "";
if(!params.isEmpty()){
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
for(NameValuePair h : headers)
{
request.addHeader(h.getName(), h.getValue());
}
executeRequest(request, url);
break;
}
case POST:
{
HttpPost request = new HttpPost(url);
//add headers
for(NameValuePair h : headers)
{
request.addHeader(h.getName(), h.getValue());
}
if(!params.isEmpty()){
request.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8));
}
executeRequest(request, url);
break;
}
}
}
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);
// Closing the input stream will trigger connection release
instream.close();
}
} catch (ClientProtocolException e) {
client.getConnectionManager().shutdown();
e.printStackTrace();
} catch (IOException e) {
client.getConnectionManager().shutdown();
e.printStackTrace();
}
}
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");
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return sb.toString();
}
}