我在iOS中构建了另一个应用程序,当用户登录到应用程序时,服务器会将其登录到该会话中。在iOS应用程序中,只要正常会话和来自应用程序的所有请求都看到仍然登录的人,会话就会保持活动状态。
我认为这与Android应用程序相同,但登录后我切换到下一个活动,然后向服务器发送请求以填充页面。我得到的结果是说用户没有登录。
这里有没有区别,我不明白是不是让我的服务器上的会话还活着?
我有一个基类,我的所有活动都扩展了,在基类中我有这个受保护的类。我用它来发送所有请求。
protected class API extends AsyncTask <Void, Void, String>
{
public String RequestName;
public String RequestType;
public String RequestUrl;
public List<NameValuePair> RequestParameters;
public API(String Name, String Type, String Url, List<NameValuePair> params)
{
RequestName = Name;
RequestType = Type;
RequestUrl = Url;
RequestParameters = params;
}
protected String getASCIIContentFromEntity(HttpEntity entity) throws IllegalStateException, IOException
{
InputStream in = entity.getContent();
StringBuffer out = new StringBuffer();
int n = 1;
while (n>0)
{
byte[] b = new byte[4096];
n = in.read(b);
if (n>0)
out.append(new String(b, 0, n));
}
return out.toString();
}
@Override
protected String doInBackground(Void... params)
{
HttpClient httpClient = new DefaultHttpClient();
HttpContext localContext = new BasicHttpContext();
String text = null;
if(RequestType == "post")
{
HttpPost p = new HttpPost("http://www.ehrx.com/api/" + RequestUrl);
try
{
p.setEntity(new UrlEncodedFormEntity(RequestParameters));
HttpResponse response = httpClient.execute(p, localContext);
HttpEntity entity = response.getEntity();
text = getASCIIContentFromEntity(entity);
}
catch (Exception e)
{
return e.getLocalizedMessage();
}
}
else
{
HttpGet httpGet = new HttpGet("http://www.ehrx.com/api/" + RequestUrl);
try
{
HttpResponse response = httpClient.execute(httpGet, localContext);
HttpEntity entity = response.getEntity();
text = getASCIIContentFromEntity(entity);
}
catch (Exception e)
{
return e.getLocalizedMessage();
}
}
return text;
}
protected void onPostExecute(String results)
{
HandleResult(results, RequestName);
}
}
答案 0 :(得分:5)
我猜服务器上的会话仍然存在,但你在android应用程序中丢失了会话cookie。看起来您正在为每个请求创建新客户端和新上下文。您将需要为上下文设置cookie存储,以便它可以使用您已经过身份验证的先前请求中的会话cookie。 How do I manage cookies with HttpClient in Android and/or Java?的答案应该会为您提供更多信息。
答案 1 :(得分:0)
这可以使用单例类轻松修复(您应该在所有http请求中使用相同的HTTP客户端)。