网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.详细介绍什么是实时JAVA.
.如何使用AOP编程减少升级的风险(.
.Tuxedo配置管理简要说明.
.Singleton 模式在 Java 中的应用.
.什么是Java EE 5.
.java编程:关于对Vector的一点理.
.了解Struts1.1介绍.
.抽象PACKAGES增加系统灵活性.
.虚拟机概论(六)——JAVA虚拟机.
.JAgileSearch 1.0 alpha Done.
.细说prototype.js的事件注册.
.Sun电信行业解决方案.
.《Java编程思想》(第二版)第4章:.
.java获得鼠标所在位置的图像的rg.
.java网络蚂蚁的制作流程.
.驯服Tiger之深入研究枚举类型.
.《J2EE核心模式》(DAO模式).
.[JAVA]Panel 嵌入ScrollPane.
.写了一个简单的程序(ArrayList).
.setUTCSeconds 方法.

实用技巧分析——JXPATH实用讲解

发表日期:2008-1-5



  使用JXPATH
  
  APACHE的东西有个好处,就是简单,符合KISS原则。究竟是给数万程序员用的,太晦涩了这些大忙人们可没功夫去慢慢琢磨。
  
  JXPathContext ctx = JXPathContext.newContext(对象实例);Object value = ctx.getValue(数据的XPATH路径);
  
  就这么简单。稍微说明的一点是,假如查询的是Java对象的话,XML里的属性和子节点在这里都被看作对象的属性取值
  
  扩展JXPATH
  
  目前JXPath里默认支持的只有XML、MAP和标准JavaBean。这几个常用么也就差不多够了。但它也可以扩展,以备不时之需。
  
  常用的数据类算是ResulSet,下面就用这个当我们的小白鼠实作一下吧~
  
  方式1:注册自定义的属性取值接口
  
  DynamicPropertyHandler handler= new DynamicPropertyHandler({ Object getProperty(java.lang.Object object, java.lang.String propertyName) {ResultSet rs = (ResultSet)object;return rs.getObject(propertyName); } String[] getPropertyNames(java.lang.Object object) {ResultSet rs = (ResultSet)object;ResultSetMetaData meta = rs.getMetaData();String[] ret = new String[meta.getColumnCount()];for(int i=0; i  
  这样当JXPATH在取值的过程中碰到了ResultSet对象,那么就会调用我们注册的处理器去取值和设值了。
  
  方式2:投机取巧是程序员的职业病。既然JXPath只支持标准JavaBean对象,那就把ResultSet包装成JavaBean对象就好了。什么?包装起来也麻烦?……没说要你自己包啊。首先想到的自然是BeanUtils了:
  
  DynaBean newBean = new BasicDynaBean(new ResultSetDynaClass(rs));
  
  这样一行代码就就可以了。
  
  这样简单的原因是因为ResultSet的数据只有一层,假如需要处理的非凡数据结构是多层的,那么也可以依葫芦画瓢。
  
  但是在设XML节点的值时,该XPATH所指的节点必须存在,否则会报一个节点不存在的Exception。可假如真的要在这个XPATH位置上设值,又懒得自己一个个创建节点,可不可以自动让XPATH按需要自动把对应的树创建起来?JXPATH当然也考虑到了
  
  Document doc = ....;JXPathContext ctx = JXPathContext.newContext(doc);AbstractFactory factory = new AbstractFactory({  boolean createObject(JXPathContext context, Pointer pointer, Object parent, String name, int index) {if (parent instanceof org.w3c.Node){ try{  Node node = (Node) parent;  Document doc = node.getOwnerDocument();  Element e = doc.createElement();  node.appendChild(e);  return true; }catch(Exception e){  return false; }}else return false;  }  boolean declareVariable(JXPathContext context, String name) {return false; //一般用不着  }});ctx.setFactory(factory);
  
  很偷懒~是不是?
  
  JXPATH是个设计的很周到的工具,为了充分让人们感受统一的XPATH的便利性,它提供了很多扩展以满足各种数据的要求。大家可以看它API DOC继续挖掘,我在这就不赘述了。
  
  性能测试
  
  XML最为人诟病的就是它的性能。那么采用JavaBean的XPATH的导航方式是否?本来JavaBean的引用操作比XML操作快不止一个数量级,但别忘了JXPATH在JavaBean间的导航有可能使用了类反射,这将使得性能大打折扣。
  
  一个简单的性能测试就可以说明:构造同一数据结构的两组数据,一组用XML表示,一组用JavaBean 表示。分别用JXPATH进行定位。
  
  测试的结果并不是很乐观,当使用“[@属性='属性值']”这类操作的时候,直接用XML比要用JXPATH要快近一个数量级。
  
  但还有个好消息,似乎JXPATH会对反射出来的信息进行缓存,所以当重复对几个对象进行取值的话,所花费的时间不会线性增长。而CRIMSON的XML实现的时间花费则会线性增长,所以数据量比较大时,两者优劣立见。
上一篇:增强ebXML的安全性2——内容攻击(图) 人气:754
下一篇:通过 XQuery/XPath 支持松散耦合 人气:579
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐