Android 中Header与Cookie应用场景深入剖析

本文深入探讨了Android平台上Cookie和Header的区别及其应用场景。Cookie适用于保持登录状态和购物车等,而Header适合传递可能频繁更新的信息。在Android中,Cookie的管理由CookieManager负责,可以通过HttpClient获取并设置。同时,文章提到了Ajax请求无法读取Cookie的问题及其解决方案。
摘要由CSDN通过智能技术生成

了解 Cookie和Session

HTTP协议


这里将两者在Android平台上做一个简单的对比:


Header:

                   

客户端向服务器发送请求,在请求头中包含请求方法,协议版本,客户端信息等内容,这些内容以key,value形式组合,我们称这些内容为http header


Cookie:

            

1.这里说的cookie不是传统意义上的cookie,传统来讲cookie是服务器保存在客户端的信息,以便下次请求时能够通过读取cookie识别客户端身份等信息。

2.Cookie发送也是放在header中发送的。

3.android.webkit.CookieManagerandroid cookie的管理类,可以讲客户端信息封装在cookiemanager中,这样系统发送请求时就自动带上这些cookie信息。

4.在Android手机中,Cookie的相关信息保存在/data/data/package_name/database/webview.db中.



Cookie vs Header


                              Cookie                   headers
生存周期           一段时期有效        每次都需要重新传递

读取                   容易读取               Ajax请求不能读取

WebView支持    全支持                   2.2以上才支持


Cookie与Header的对比:


1..Cookie从Android最早的版本已经开始支持. 但Cookie在Android2.2以上才WebView才支持headers(Android2.2才加入了webview.load(url,headers)的API).这方面还好,毕竟现在主流的手机已经普遍安装了Android4.0及以上的版本,2.2以下的手机市场占有率并不多了,受到影响不大.

2.但是Ajax请求不能读取影响就比较严重了,毕竟现在的Web页面大量应用了Ajax跳转,不可能不处理这种情况. 关于这方面我在之前的Android WebView常见问题及解决方案汇总 中已经提到,当时是采取特殊标记,过滤Ajax的url,采取将参数拼接到URL末尾的方式.解决.

3.Cookie无论是获取还是操作都很便捷,无论是

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值