热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android本地化存储Cookie(针对HttpClient)

因为最近有人问我怎么保存HttpClient的Cookie,所以这里写下,顺便记录总结吧.当然,有Android网络编程经历的童鞋一看就懂喇~就不多说了,直接上代码:

因为最近有人问我怎么保存HttpClient的COOKIE, 所以这里写下, 顺便记录总结吧. 当然, 有Android网络编程经历的童鞋一看就懂喇~ 


就不多说了, 直接上代码:

/**
* 本地存储COOKIE
* @param response
*/
private void saveCOOKIEs(HttpResponse response) {
SharedPreferences preferences = getSharedPreferences("COOKIEs", MODE_PRIVATE);
List theCOOKIEs = client.getCOOKIEStore().getCOOKIEs();

StringBuffer sb = new StringBuffer();

for(int k=0; k {
Log.e("循环获取COOKIE信息", "name = " + theCOOKIEs.get(k).getName());
Log.e("循环获取COOKIE信息", "value = " + theCOOKIEs.get(k).getValue());
sb.append(theCOOKIEs.get(k).getName() + "=" + theCOOKIEs.get(k).getValue() + ";");
}
Date date = theCOOKIEs.get(0).getExpiryDate();
Log.e("COOKIE的有效时间是",format.format(date));

preferences.edit().putString("COOKIEs",sb.toString()).commit();
}

设置COOKIE:

String url = "http://www.host.com/test";
HttpGet get = new HttpGet(url);
SharedPreferences sharedPreferences = getSharedPreferences("COOKIEs", MODE_PRIVATE);
get.setHeader("COOKIE", sharedPreferences.getString("COOKIEs", ""));

try
{
HttpResponse respOnse= client.execute(get);
HttpEntity entity = response.getEntity();

if(response.getStatusLine().getStatusCode() != HttpStatus.SC_OK)
{
Log.e(TAG, "保存失败");
//...
}
else
{
Log.e(TAG, "保存成功");
//...

}
}
catch (Exception e)
{
e.printStackTrace();
}

这样即使退出应用后, 下次重新使用COOKIE, 也可以避免一些重复的HTTp请求, 比如重复登录什么的. 但是要注意一个地方, COOKIE是有效期的, 如果超过有效期再去使用就会无效, 需要重新登录才能进行其他的操作. 如上面的代码, 测试的COOKIE有效时间是一个月. 


 所以在使用COOKIE, 可以同时保存COOKIE的有效期, 当然不保存也可以, 携带无效COOKIE去访问是服务器自然也会返回相应的提示, 根据提示响应即可. 另外唠嗑唠嗑, COOKIE是一种很简单的文本数据, 记录了服务器和客户端之间的访问信息, 因此读取和存储, 管理的效率很高, 但不好的是不够安全, 本地化存储最好注意安全. 当然如果不是什么很重要的数据, 并且有良好的使用习惯, 也没什么.



上面是针对Android开发环境中原生的HttpClient, 如果是使用其他Apache的HttpClient jar包, 比如commons-httpclient-3.1.jar. 可能会发现上面的方法使用起来并不方便, 那么我们还可以模仿浏览器处理COOKIE的策略, 使用该jar包中特有的httpPost.setRequestHeader()方法添加访问信息, 比如

httpPost.setRequestHeader("Host", "host地址");

httpPost.setRequestHeader("Connection","Keep-Alive");

httpPost.setRequestHeader("COOKIE", COOKIE);

httpPost.setRequestHeader("User-Agent", userAgent);


然后, 我们利用抓包工具, 随便查看电脑浏览器的某个请求, 能看到Headers中有类似格式的COOKIE数据(下图是访问有道网站的请求):


可见, 这种处理方式跟浏览器的策略是类似的.



推荐阅读
  • Cookie学习小结
    Cookie学习小结 ... [详细]
  • 9102年了,汇总下HttpClient问题,封印一个
    如果找的是core的HttpClientFactory出门右转。官方写法,高并发下,TCP连接不能快速释放,导致端口占完,无法连接Dispose不是马上关闭t ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • SDWebImage第三方库学习
    1、基本使用方法异步下载并缓存-(void)sd_setImageWithURL:(nullableNSURL*)urlNS_REFINED_FOR_SWIFT;使用占位图片& ... [详细]
  • 本指南介绍了 `requests` 库的基本使用方法,详细解释了其七个主要函数。其中,`requests.request()` 是构建请求的基础方法,支持其他高级功能的实现。此外,我们还重点介绍了如何使用 `requests.get()` 方法来获取 HTML 网页内容,这是进行网页数据抓取和解析的重要步骤。通过这些基础方法,读者可以轻松上手并掌握网页数据抓取的核心技巧。 ... [详细]
  • 深入浅出解析HTTP协议的核心功能与应用
    前言——协议是指预先设定的通信规则,确保双方能够按照既定标准进行有效沟通,从而实现准确的信息交换。例如,驯兽师通过拍手使动物坐下,这实际上是一种预设的协议。本文将详细探讨HTTP协议的核心功能及其广泛应用,解析其在现代网络通信中的重要作用。 ... [详细]
  • 本文通过一个具体的案例,展示了如何使用 Python 爬虫技术从京东网站爬取手机的价格和参数。最近发布的 iPhone X 虽然价格昂贵,但不妨碍我们探索其他高性价比的国产手机。 ... [详细]
  • 在对WordPress Duplicator插件0.4.4版本的安全评估中,发现其存在跨站脚本(XSS)攻击漏洞。此漏洞可能被利用进行恶意操作,建议用户及时更新至最新版本以确保系统安全。测试方法仅限于安全研究和教学目的,使用时需自行承担风险。漏洞编号:HTB23162。 ... [详细]
  • 贪心策略在算法设计中的应用与优化
    贪心算法在算法设计中具有广泛的应用,特别是在解决优化问题时表现出色。本文通过分析经典问题“买卖股票的最佳时机II”,探讨了贪心策略的基本原理及其在实际问题中的应用。通过实例分析,展示了贪心算法如何通过局部最优选择逐步达到全局最优解,并讨论了其在时间和空间复杂度上的优势。此外,还提出了一些优化方法,以提高算法的效率和适用性。 ... [详细]
  • 深入解析HTTP网络请求API:从基础到进阶的全面指南
    本文全面解析了HTTP网络请求API,从基础到进阶,详细介绍了Android平台上的两种原生API——HttpUrlConnection和HttpClient。这两种API通过对底层Socket的封装,提供了高效、灵活的网络通信功能。文章不仅涵盖了基本的使用方法,还深入探讨了性能优化、错误处理和安全性等方面的高级主题,帮助开发者更好地理解和应用这些工具。 ... [详细]
  • HTML5 Web存储技术是许多开发者青睐本地应用程序的重要原因之一,因为它能够实现在客户端本地存储数据。HTML5通过引入Web Storage API,使得Web应用程序能够在浏览器中高效地存储数据,从而提升了应用的性能和用户体验。相较于传统的Cookie机制,Web Storage不仅提供了更大的存储容量,还简化了数据管理和访问的方式。本文将从基础概念、关键技术到实际应用,全面解析HTML5 Web存储技术,帮助读者深入了解其工作原理和应用场景。 ... [详细]
  • 本文将详细介绍如何利用JMeter高效执行API接口测试,涵盖JMeter的基础介绍、安装方法、中文环境配置、主要元件及其作用域和执行顺序等内容,并分享一系列实用的测试技巧,帮助读者全面掌握JMeter接口测试的全过程。 ... [详细]
  • Iwishtousestreamsasrecommendedbythejson.netperformancetipsdocumentation,howeverImuna ... [详细]
  • 超文本传输协议HTTP也许是当今互联网上使用的最重要的协议了。尽管java.net包提供了基本通过HTTP访问资源的功能,但它没有提供全面的灵活性和其它很多应用程序需要的功能。HttpClient就 ... [详细]
  • 用httpclient做搜狐邮箱的模拟登录,但是请求结果一直都400,因为是https请求,wireshark也抓不到包
    登录结果{body:,message:BadRequest,status:400}感觉是请求缺少了校验,但是不知道怎么完整的请求过程之前http请求的 ... [详细]
author-avatar
mobiledu2502852643
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有