千家信息网

J2ME平台中Cookie技术怎么用

发表于:2025-11-21 作者:千家信息网编辑
千家信息网最后更新 2025年11月21日,这篇文章给大家分享的是有关J2ME平台中Cookie技术怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Cookie技术在J2ME平台的应用与实现Cookie在Web应
千家信息网最后更新 2025年11月21日J2ME平台中Cookie技术怎么用

这篇文章给大家分享的是有关J2ME平台中Cookie技术怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

Cookie技术在J2ME平台的应用与实现

Cookie在Web应用程序中被广泛采用,维护浏览器和服务器之间的状态。遗憾的是这一特性在JavaME平台中并没有得到支持。因此,要想维持客户端和服务器端的状态则必须使用URL重写的方式。URL重写操作起来比较麻烦,所以研究一下cookie的原理并在JavaME平台上实现cookie是不错的尝试。

首先,我们来看一下cookie的原理。当服务器需要和浏览器维持某一状态的时候,例如需要记录用户的购物车中已经购买的商品。这时候服务器可以新建一个Cookie并把它写入到响应中,浏览器从响应中接收到cookie并保存起来。当浏览器再次向服务器发送请求的时候,浏览器会根据域(domain)和路径(path)检查是否有匹配的cookie,如果有则把cookie以"名称=值"的形式发送给服务器,服务器从请求中解析出cookie就知道用户的状态了。

那么,浏览器根据什么规则来决定向服务器发送cookie呢,首先要匹配domain,如果cookie的域属性是.google.com,那么请求指向j2medev.com的时候,cookie就不会被发送。如果域匹配的条件满足,则判断path是否匹配,如果cookie的path属性是请求的uri的父目录的话,那么cookie就会被发送给服务器。Cookie是有存活周期的,到期的cookie会被浏览器自动清除。如果服务器创建cookie的时候不设置生命周期,那么在会话结束后浏览器就会删除cookie。如果不为cookie指定path属性,那么默认就是这次请求的路径。

cookie在很多web应用程序中都有应用,比如记住密码,购物车等。在开发MIDlet的时候,你也可以让你的应用程序支持cookie,这样维持客户端与服务器端的状态将变得简单,为你集中精力解决其他业务方法奠定了基础。既然已经知道了cookie的工作原理,那么就应该考虑一下在JavaME平台如何实现cookie,这个想法是否可行。我将从下面三个方面进行分析。

***:获得cookie

当服务器端的响应到来的时候,我们应该能够读取cookie。如果服务器向客户端写入Cookie的时候,响应中的HTTP头"Set-Cookie"中会包含一个字符串,代表了cookie的信息。幸运的是我们是用HttpConnection.getHeaderFiled("Set-Cookie")方法即可获得cookie,但是需要注意这里只是读取了一个cookie,如果响应中包含了多个cookie,那么你需要循环读取。类似于下面的代码

StringsCookie=null;  Stringkey=null;  inti=0;  //如果key存在,则查询header的key,如果key等于SET_COOKIE,则存储  while((key=connection.getHeaderFieldKey(i))!=null){  if(key.equals(SET_COOKIE)||key.equals(SESSIONID)){  sCookie=connection.getHeaderField(i);  saveCookie(sCookie,url);  }  i++;  }

上面的代码把header是Set-Cookie和SesssionID的cookie内容读取下来。

第二:保存cookie

已经获得了cookie之后,就需要把cookie存储下来,存储分为两个部分,首先需要解析cookie,我们定义一个JavaBean来代表cookie.

packagecom.j2medev.lomol.model;   importcom.j2medev.lomol.util.StringUtil;  importjava.io.DataInputStream;  importjava.io.DataOutputStream;  importjava.io.IOException;  importjava.util.Date;   /**  *acookiestoredonthemobiledevice,  cookieisusedtomaintainthestatesbetweenclientandserver  *@authormingjava  *@version0.105/06/2006  */  publicclassCookie{   privateStringpath="";  privateStringname="";  privateStringvalue="";  privatelongexpire=SESSION_COOKIE;  publicstaticlongSESSION_COOKIE=0;//sessioncookie,onlyvalidthissession   publicCookie(){  }   publicStringgetPath(){  returnpath;  }   publicvoidsetPath(Stringpath){  this.path=path;  }   publicStringgetName(){  returnname;  }   publicvoidsetName(Stringname){  this.name=name;  }   publicStringgetValue(){  returnvalue;  }   publicvoidsetValue(Stringvalue){  this.value=value;  }   publicvoidserialize(DataOutputStreamdos)throwsIOException{  dos.writeUTF(name);  dos.writeUTF(value);  dos.writeUTF(path);  dos.writeLong(expire);  }   publicstaticCookiedeserialize(DataInputStreamdis)throwsIOException{  Cookiecookie=newCookie();  cookie.name=dis.readUTF();  cookie.value=dis.readUTF();  cookie.path=dis.readUTF();  cookie.expire=dis.readLong();  returncookie;  }   publiclonggetExpire(){  returnexpire;  }   publicvoidsetExpire(longexpire){  this.expire=expire;  }  //fordebug  publicStringtoString(){  returnname+"="+value+";expires="+newDate(expire).toString()+";path="+path;  }   publicbooleanisExpired(longnow){  returnexpire-now<0;  }   publicbooleanisExpired(){  returnexpire-(newDate().getTime())<0;  }   publicstaticCookieparseCookie(Strings,Stringuri){  Cookiecookie=newCookie();  StringUtilsu=newStringUtil(s,";");  while(su.hasMoreTokens()){  Stringstr=su.nextToken().trim();  inti=str.indexOf("=");  if(i==-1){  //securedonothing  continue;  }else{  Stringname=str.substring(0,i);  Stringvalue=str.substring(i+1,str.length());  if("path".equals(name)){  cookie.setPath(value);  }elseif("expires".equals(name)){  cookie.setExpire(StringUtil.getData(value));  }elseif("domain".equals(name)){  //donothing  }else{  cookie.setName(name);  cookie.setValue(value);  }  }  if(cookie.getPath().equals(""))  cookie.setPath(uri);  }  returncookie;  }   publicbooleanequals(Objectobj){  if(objinstanceofCookie){  Cookieo=(Cookie)obj;  if(o.getName().equals(name)&&o.getPath().equals(path))  returntrue;  }  returnfalse;  }   publicinthashCode(){  intresult=17;  resultresult=result*37+path.hashCode();  resultresult=result*37+name.hashCode();  returnresult;  }  }

提供了一个parseCookie方法来解析cookie,具体的原理就不再介绍了。然后需要把这个Cookie对象存储到RMS中。cookie并不大,所以不会占用太多的空间,在RMS中存储非常合适。注意对于会话期间的cookie没有必要存储在rms中,因为会话结束后就失效了,不如在内存中声明一个Map来存储会话类型的cookie。

第三:发送cookie

发送cookie也是需要两个步骤,首先检索rms和内存看是否有满足条件的cookie,如果有读取出来。然后通过下面的方法向服务器端发送

检查是否有cookie需要发送给服务器端

String_cookie=collectCookie(url);  if(_cookie!=null)  connection.setRequestProperty(COOKIE,_cookie);

如果能够顺利解决上面的三个步骤,基本可以实现cookie在javame平台的应用。

感谢各位的阅读!关于"J2ME平台中Cookie技术怎么用"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

服务器 服务 浏览器 浏览 平台 时候 存储 应用 状态 原理 方法 面的 技术 内容 客户 客户端 属性 应用程序 程序 端的 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 怎么回复苹果流量数据库 浙江网络安全硬件设备厂家 物理所网络技术中心电话 事件软件开发公司 互联网平台开发与网络安全 用户与数据库之间的接线 数据库删除修改代码 供电所开展网络安全稿件 老头环pc连不上服务器 单片机串口数据迁移到服务器上 web访问数据库配置文件 戴尔软件开发研究所 哪个行业的软件开发岗位多 10g数据库支持增量导入 添加一个对象到数据库中 公司租入的服务器入什么会计科目 网络安全法27条罚款 无服务器架构有哪些意义 安阳润森网络技术有限公司 江苏电商软件开发哪家实惠 管理类软件开发价格 开发的系统如何上传到服务器 阿里云服务器的配置 10g数据库支持增量导入 blob数据库放几个文字 学生对网络安全的理解 做软件开发必须自信 网络技术有限公司经营范围有哪些 江苏电商软件开发哪家实惠 网络安全 应对国外
0