当前位置: 首页 > 面试题库 >

使用整个活动的Cookie使用时的HttpClient

仲孙才捷
2023-03-14
问题内容

我想一个简单的应用程序在网站的HTML阅读,变换分析它创建于Android的易读的UI(这是学习Android的一个exersize,而不是使可用的应用程序)。我遇到的问题是持续跨越一个活动用户会话,然后在使用会话HttpClient曾经回忆说。

我想这样做“正确”,推荐的方法似乎是使用CookieManager。我已经受够了这个问题,但是-
我似乎无法找到“正确”的方式采取CookieCookieManager并在以后的实例使用它HttpClient在一个单独的活动。

当使用CookieManager我可以保存CookieCookie随后在其他活动范围(见代码段2)。我还没有找到如何请求页面时使用此之后(见代码片断3)。

够说话,这里是一些代码。首先我的登录操作和Cookie的存储:

private OnClickListener loginActionListener = new OnClickListener() 
{
    public void onClick(View v) 
    {
        EditText usernameTextView = (EditText) findViewById(R.id.Username);
        EditText passwordTextView = (EditText) findViewById(R.id.Password);
        String username = usernameTextView.getText().toString();
        String password = passwordTextView.getText().toString();

        try {
            HttpPost postMethod = new HttpPost(URI);                
            HttpParams params   = new BasicHttpParams();

            params.setParameter("mode", "login");
            params.setParameter("autologin", true);
            params.setParameter("username", username);
            params.setParameter("password", password);
            postMethod.setParams(params);

            DefaultHttpClient httpClient = new DefaultHttpClient();
            HttpResponse response        = httpClient.execute(postMethod);
            List<Cookie> cookies = httpClient.getCookieStore().getCookies();

            if(cookies != null)
            {
                for(Cookie cookie : cookies)
                {
                    String cookieString = cookie.getName() + "=" + cookie.getValue() + "; domain=" + cookie.getDomain();                        
                    CookieManager.getInstance().setCookie(cookie.getDomain(), cookieString);  
                }
            }
            CookieSyncManager.getInstance().sync();

            Intent intent = new Intent(v.getContext(), IndexAction.class);
            startActivity(intent);
    } catch (Exception e) {...}
}

下面是决定是否进行用户登录或转到索引的启动活动。您可以从这段代码中的Cookie是在范围和可以读取看到:

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    CookieSyncManager.createInstance(this);

    if(CookieManager.getInstance().getCookie(URI) == null)
    {
        Intent intent = new Intent(this, LoginAction.class);
        startActivity(intent);
    }
    else
    {
        Intent intent = new Intent(this, IndexAction.class);
        startActivity(intent);
    }
}

但是从我的代码读取索引页,我希望你能提出什么我失踪:

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    CookieSyncManager.createInstance(this);

    try
    {
            HttpGet getMethod = new HttpGet(URI_INDEX);

            HttpParams params   = new BasicHttpParams();                        
            HttpConnectionParams.setConnectionTimeout(params, 30000);
            HttpConnectionParams.setSoTimeout(params, 30000);

            // This code results in a ClassCastException, I'm assuming i've found a red herring with this solution.
            // HttpContext localContext = new BasicHttpContext();    
            // localContext.setAttribute(ClientContext.COOKIE_STORE, CookieManager.getInstance().getCookie(URI));

            DefaultHttpClient httpClient = new DefaultHttpClient(params);
            HttpResponse response        = httpClient.execute(getMethod);

            if(response.getStatusLine().getStatusCode() > 299 && response.getStatusLine().getStatusCode() < 400)
            {
                // Not logged in doesn't give a redirect response. Very annoying.
            }

            final char[] buffer = new char[0x10000];
            StringBuilder out = new StringBuilder();
            Reader in = new InputStreamReader(response.getEntity().getContent(), "UTF-8");
            int read = 0;
            while (read>=0)
            {
              read = in.read(buffer, 0, buffer.length);
              if (read>0) {
                out.append(buffer, 0, read);
              }
            }

            String returnString = out.toString();
    } catch (ClientProtocolException e) {...}
}

HttpClientexecute(getMethod)未使用的Cookie(双调试检查这一点)拉回来的页面。这将是巨大的,如果有人可以填补我所知,这洞。

提前致谢。

编辑

当注释的代码中加入在背面(与httpClient.execute(getMethod)方法改变httpClient.execute(getMethod, localContext))这个跟踪STRACK产生-
Assumedly因为即时填充所述属性ClientContext.COOKIE_STORE与一个Cookie
String,而不是一个CookieStore

*org.apache.http.client.protocol.RequestAddCookies.process(RequestAddCookies.java:88), org.apache.http.protocol.BasicHttpProcessor.process(BasicHttpProcessor.java:290), org.apache.http.protocol.HttpRequestExecutor.preProcess(HttpRequestExecutor.java:160), org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:401)
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555), org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487), 
com.testapp.site.name.IndexAction.onCreate(IndexAction.java:47), 
android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047), 
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611), 
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663), 
android.app.ActivityThread.access$1500(ActivityThread.java:117), 
android.app.ActivityThread$H.handleMessage(ActivityThread.java:931), 
android.os.Handler.dispatchMessage(Handler.java:99), 
android.os.Looper.loop(Looper.java:123), 
android.app.ActivityThread.main(ActivityThread.java:3683), 
java.lang.reflect.Method.invokeNative(Native Method), 
java.lang.reflect.Method.invoke(Method.java:507), 
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839), 
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597), 
dalvik.system.NativeStart.main(Native Method)*

问题答案:

(如所承诺的解决了这一点。我还是不喜欢它,感觉我错过了这样做的“正确”的方式,但是,它的工作原理。)

您可以使用CookieManager注册您的cookies(并因此使应用程序之间提供这些cookie),用下面的代码:

将Cookie保存到中CookieManager

List<Cookie> cookies = httpClient.getCookieStore().getCookies();

if(cookies != null)
{
    for(Cookie cookie : cookies)
    {
        String cookieString = cookie.getName() + "=" + cookie.getValue() + "; domain=" + cookie.getDomain();                        
        CookieManager.getInstance().setCookie(cookie.getDomain(), cookieString);  
    }
}
CookieSyncManager.getInstance().sync();

检查指定域的Cookie: if(CookieManager.getInstance().getCookie(URI_FOR_DOMAIN)

要为HttpClient的重建值:

DefaultHttpClient httpClient = new DefaultHttpClient(params);
String[] keyValueSets = CookieManager.getInstance().getCookie(URI_FOR_DOMAIN).split(";");
for(String cookie : keyValueSets)
{
    String[] keyValue = cookie.split("=");
    String key = keyValue[0];
    String value = "";
    if(keyValue.length>1) value = keyValue[1];
    httpClient.getCookieStore().addCookie(new BasicClientCookie(key, value));
}


 类似资料:
  • 问题内容: 我正在使用同时打开的三个活动。所有活动都是来自sqlite的追溯数据。从活动a-> b或从b-> c进入时,我不会关闭或重新打开连接。我只是在活动销毁时处理我的数据库。 活动A 当我从活动b-> c开始时,正在运行相同的代码。在同一活动中,我经常使用sqlite。 这是一个好习惯吗?使用后我应该立即处置连接吗?还是应该在暂停时关闭连接并在恢复时重新打开?还是可以将相同的打开的连接传递给

  • 框架中session/cookie的使用 session session的作用主要在保存会话信息,在访问者浏览网站的期间,对访问者相关的信息进行记录,当浏览器关闭后,会话结束,session数据也就消失了。 PHP框架中session是一个数组,可以通过$_SESSION['key'] = $value的方式对session赋值。如: $_SESSION['myname'] = 'Helllo';

  • 我的应用程序(最小API14)使用带有3个选项卡的ActionBar。选项卡是:i。输入数据(约10个片段)ii。管理数据(15个片段)三.查看数据(8个片段)。每个选项卡都有一个默认片段,但根据用户的选择会有多个片段。 我希望用户能够在3个选项卡之间滑动(通过滑动内容),因此我需要使用ViewPager和兼容性库V4。 我得到的建议(经过大量研究)是使用一个MainActivity,它承载Act

  • 我正在通过Android培训学习Android开发:http://developer.android.com/training/basics/firstapp/index.html 在第一部分的末尾(http://developer.android.com/training/basics/firstapp/starting-activity.html)当我单击按钮时,什么也没有发生,我甚至没有在日

  • 问题内容: 我正在使用ThreadPoolExecutor在Java应用程序中执行任务。我有一个要求,我想在任何时间获取执行者队列中队列中活动任务的数量。我查看了ThreadPoolExecutor 的javadoc,发现了两个相关方法:和。 根据文档,我可以分别通过上述两种方法获得计划任务和完成任务的数量。但是我找不到能够在任何时间获取队列中活动任务数量的解决方案。我可以做类似的事情: 但是失败

  • 我现在真的很困惑,因为每当我创建一个新的带有空白活动的Android应用程序时,它总是fragment_main.xml.我只是想创建一个没有片段的空白活动。 在第一幅图中,空白活动带有片段布局: 第二个图像显示了创建的fragment_main 现在我真的很困惑…这只发生在将ADT更新到最新版本之后。我提到了这个线程:Adt不创建默认的hello world,但命令行创建_ 我只是想制作一个An