﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-JAVA学习点点滴滴-随笔分类-Java小技术</title><link>http://www.blogjava.net/mkchen/category/18617.html</link><description>用开放的脑子去闯荡;用开阔的视野去拼搏;用平和的身心去磨练;用美好的理想去追求!</description><language>zh-cn</language><lastBuildDate>Wed, 28 Feb 2007 04:10:21 GMT</lastBuildDate><pubDate>Wed, 28 Feb 2007 04:10:21 GMT</pubDate><ttl>60</ttl><item><title>java关于23种设计模式的有趣见解 </title><link>http://www.blogjava.net/mkchen/archive/2007/01/27/96327.html</link><dc:creator>海思</dc:creator><author>海思</author><pubDate>Sat, 27 Jan 2007 15:05:00 GMT</pubDate><guid>http://www.blogjava.net/mkchen/archive/2007/01/27/96327.html</guid><wfw:comment>http://www.blogjava.net/mkchen/comments/96327.html</wfw:comment><comments>http://www.blogjava.net/mkchen/archive/2007/01/27/96327.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/mkchen/comments/commentRss/96327.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/mkchen/services/trackbacks/96327.html</trackback:ping><description><![CDATA[
		<p>创建型模式 </p>
		<p>1、FACTORY—追MM少不了请吃饭了，麦当劳的鸡翅和肯德基的鸡翅都是MM爱吃的东西，虽然口味有所不同，但不管你带MM去麦当劳或肯德基，只管向服务员说“来四个鸡翅”就行了。麦当劳和肯德基就是生产鸡翅的Factory </p>
		<p>工厂模式：客户类和工厂类分开。消费者任何时候需要某种产品，只需向工厂请求即可。消费者无须修改就可以接纳新产品。缺点是当产品修改时，工厂类也要做相应的修改。如：如何创建及如何向客户端提供。 </p>
		<p>2、BUILDER—MM最爱听的就是“我爱你”这句话了，见到不同地方的MM,要能够用她们的方言跟她说这句话哦，我有一个多种语言翻译机，上面每种语言都有一个按键，见到MM我只要按对应的键，它就能够用相应的语言说出“我爱你”这句话了，国外的MM也可以轻松搞掂，这就是我的“我爱你”builder。（这一定比美军在伊拉克用的翻译机好卖） </p>
		<p>建造模式：将产品的内部表象和产品的生成过程分割开来，从而使一个建造过程生成具有不同的内部表象的产品对象。建造模式使得产品内部表象可以独立的变化，客户不必知道产品内部组成的细节。建造模式可以强制实行一种分步骤进行的建造过程。 </p>
		<p>3、FACTORY METHOD—请MM去麦当劳吃汉堡，不同的MM有不同的口味，要每个都记住是一件烦人的事情，我一般采用Factory Method模式，带着MM到服务员那儿，说“要一个汉堡”，具体要什么样的汉堡呢，让MM直接跟服务员说就行了。 </p>
		<p>工厂方法模式：核心工厂类不再负责所有产品的创建，而是将具体创建的工作交给子类去做，成为一个抽象工厂角色，仅负责给出具体工厂类必须实现的接口，而不接触哪一个产品类应当被实例化这种细节。 </p>
		<p>4、PROTOTYPE—跟MM用QQ聊天，一定要说些深情的话语了，我搜集了好多肉麻的情话，需要时只要copy出来放到QQ里面就行了，这就是我的情话prototype了。（100块钱一份，你要不要） </p>
		<p>原始模型模式：通过给出一个原型对象来指明所要创建的对象的类型，然后用复制这个原型对象的方法创建出更多同类型的对象。原始模型模式允许动态的增加或减少产品类，产品类不需要非得有任何事先确定的等级结构，原始模型模式适用于任何的等级结构。缺点是每一个类都必须配备一个克隆方法。 </p>
		<p>5、SINGLETON—俺有6个漂亮的老婆，她们的老公都是我，我就是我们家里的老公Sigleton，她们只要说道“老公”，都是指的同一个人，那就是我(刚才做了个梦啦，哪有这么好的事) </p>
		<p>单例模式：单例模式确保某一个类只有一个实例，而且自行实例化并向整个系统提供这个实例单例模式。单例模式只应在有真正的“单一实例”的需求时才可使用。 </p>
		<p>结构型模式 </p>
		<p>6、ADAPTER—在朋友聚会上碰到了一个美女Sarah，从香港来的，可我不会说粤语，她不会说普通话，只好求助于我的朋友kent了，他作为我和Sarah之间的Adapter，让我和Sarah可以相互交谈了(也不知道他会不会耍我) </p>
		<p>适配器（变压器）模式：把一个类的接口变换成客户端所期待的另一种接口，从而使原本因接口原因不匹配而无法一起工作的两个类能够一起工作。适配类可以根据参数返还一个合适的实例给客户端。 </p>
		<p>7、BRIDGE—早上碰到MM，要说早上好，晚上碰到MM，要说晚上好；碰到MM穿了件新衣服，要说你的衣服好漂亮哦，碰到MM新做的发型，要说你的头发好漂亮哦。不要问我“早上碰到MM新做了个发型怎么说”这种问题，自己用BRIDGE组合一下不就行了 </p>
		<p>桥梁模式：将抽象化与实现化脱耦，使得二者可以独立的变化，也就是说将他们之间的强关联变成弱关联，也就是指在一个软件系统的抽象化和实现化之间使用组合/聚合关系而不是继承关系，从而使两者可以独立的变化。 </p>
		<p>8、COMPOSITE—Mary今天过生日。“我过生日，你要送我一件礼物。”“嗯，好吧，去商店，你自己挑。”“这件T恤挺漂亮，买，这条裙子好看，买，这个包也不错，买。”“喂，买了三件了呀，我只答应送一件礼物的哦。”“什么呀，T恤加裙子加包包，正好配成一套呀，小姐，麻烦你包起来。”“……”，MM都会用Composite模式了，你会了没有？ </p>
		<p>合成模式：合成模式将对象组织到树结构中，可以用来描述整体与部分的关系。合成模式就是一个处理对象的树结构的模式。合成模式把部分与整体的关系用树结构表示出来。合成模式使得客户端把一个个单独的成分对象和由他们复合而成的合成对象同等看待。 </p>
		<p>9、DECORATOR—Mary过完轮到Sarly过生日，还是不要叫她自己挑了，不然这个月伙食费肯定玩完，拿出我去年在华山顶上照的照片，在背面写上“最好的的礼物，就是爱你的Fita”，再到街上礼品店买了个像框（卖礼品的MM也很漂亮哦），再找隔壁搞美术设计的Mike设计了一个漂亮的盒子装起来……，我们都是Decorator，最终都在修饰我这个人呀，怎么样，看懂了吗？ </p>
		<p>装饰模式：装饰模式以对客户端透明的方式扩展对象的功能，是继承关系的一个替代方案，提供比继承更多的灵活性。动态给一个对象增加功能，这些功能可以再动态的撤消。增加由一些基本功能的排列组合而产生的非常大量的功能。</p>
		<p>10、FACADE—我有一个专业的Nikon相机，我就喜欢自己手动调光圈、快门，这样照出来的照片才专业，但MM可不懂这些，教了半天也不会。幸好相机有Facade设计模式，把相机调整到自动档，只要对准目标按快门就行了，一切由相机自动调整，这样MM也可以用这个相机给我拍张照片了。 </p>
		<p>门面模式：外部与一个子系统的通信必须通过一个统一的门面对象进行。门面模式提供一个高层次的接口，使得子系统更易于使用。每一个子系统只有一个门面类，而且此门面类只有一个实例，也就是说它是一个单例模式。但整个系统可以有多个门面类。 </p>
		<p>11、FLYWEIGHT—每天跟MM发短信，手指都累死了，最近买了个新手机，可以把一些常用的句子存在手机里，要用的时候，直接拿出来，在前面加上MM的名字就可以发送了，再不用一个字一个字敲了。共享的句子就是Flyweight，MM的名字就是提取出来的外部特征，根据上下文情况使用。 </p>
		<p>享元模式：FLYWEIGHT在拳击比赛中指最轻量级。享元模式以共享的方式高效的支持大量的细粒度对象。享元模式能做到共享的关键是区分内蕴状态和外蕴状态。内蕴状态存储在享元内部，不会随环境的改变而有所不同。外蕴状态是随环境的改变而改变的。外蕴状态不能影响内蕴状态，它们是相互独立的。将可以共享的状态和不可以共享的状态从常规类中区分开来，将不可以共享的状态从类里剔除出去。客户端不可以直接创建被共享的对象，而应当使用一个工厂对象负责创建被共享的对象。享元模式大幅度的降低内存中对象的数量。 </p>
		<p>12、PROXY—跟MM在网上聊天，一开头总是“hi,你好”,“你从哪儿来呀？”“你多大了？”“身高多少呀？”这些话，真烦人，写个程序做为我的Proxy吧，凡是接收到这些话都设置好了自动的回答，接收到其他的话时再通知我回答，怎么样，酷吧。 </p>
		<p>代理模式：代理模式给某一个对象提供一个代理对象，并由代理对象控制对源对象的引用。代理就是一个人或一个机构代表另一个人或者一个机构采取行动。某些情况下，客户不想或者不能够直接引用一个对象，代理对象可以在客户和目标对象直接起到中介的作用。客户端分辨不出代理主题对象与真实主题对象。代理模式可以并不知道真正的被代理对象，而仅仅持有一个被代理对象的接口，这时候代理对象不能够创建被代理对象，被代理对象必须有系统的其他角色代为创建并传入。 </p>
		<p>行为模式 </p>
		<p>13、CHAIN OF RESPONSIBLEITY—晚上去上英语课，为了好开溜坐到了最后一排，哇，前面坐了好几个漂亮的MM哎，找张纸条，写上“Hi,可以做我的女朋友吗？如果不愿意请向前传”，纸条就一个接一个的传上去了，糟糕，传到第一排的MM把纸条传给老师了，听说是个老处女呀，快跑! </p>
		<p>责任链模式：在责任链模式中，很多对象由每一个对象对其下家的引用而接 </p>
		<p>起来形成一条链。请求在这个链上传递，直到链上的某一个对象决定处理此请求。客户并不知道链上的哪一个对象最终处理这个请求，系统可以在不影响客户端的情况下动态的重新组织链和分配责任。处理者有两个选择：承担责任或者把责任推给下家。一个请求可以最终不被任何接收端对象所接受。 <br />14、COMMAND—俺有一个MM家里管得特别严，没法见面，只好借助于她弟弟在我们俩之间传送信息，她对我有什么指示，就写一张纸条让她弟弟带给我。这不，她弟弟又传送过来一个COMMAND，为了感谢他，我请他吃了碗杂酱面，哪知道他说：“我同时给我姐姐三个男朋友送COMMAND，就数你最小气，才请我吃面。”，:-( </p>
		<p>命令模式：命令模式把一个请求或者操作封装到一个对象中。命令模式把发出命令的责任和执行命令的责任分割开，委派给不同的对象。命令模式允许请求的一方和发送的一方独立开来，使得请求的一方不必知道接收请求的一方的接口，更不必知道请求是怎么被接收，以及操作是否执行，何时被执行以及是怎么被执行的。系统支持命令的撤消。 </p>
		<p>15、INTERPRETER—俺有一个《泡MM真经》，上面有各种泡MM的攻略，比如说去吃西餐的步骤、去看电影的方法等等，跟MM约会时，只要做一个Interpreter，照着上面的脚本执行就可以了。 </p>
		<p>解释器模式：给定一个语言后，解释器模式可以定义出其文法的一种表示，并同时提供一个解释器。客户端可以使用这个解释器来解释这个语言中的句子。解释器模式将描述怎样在有了一个简单的文法后，使用模式设计解释这些语句。在解释器模式里面提到的语言是指任何解释器对象能够解释的任何组合。在解释器模式中需要定义一个代表文法的命令类的等级结构，也就是一系列的组合规则。每一个命令对象都有一个解释方法，代表对命令对象的解释。命令对象的等级结构中的对象的任何排列组合都是一个语言。 </p>
		<p> </p>
		<p>16、ITERATOR—我爱上了Mary，不顾一切的向她求婚。 </p>
		<p>Mary：“想要我跟你结婚，得答应我的条件” </p>
		<p>我：“什么条件我都答应，你说吧” </p>
		<p>Mary：“我看上了那个一克拉的钻石” </p>
		<p>我：“我买，我买，还有吗？” </p>
		<p>Mary：“我看上了湖边的那栋别墅” </p>
		<p>我：“我买，我买，还有吗？” </p>
		<p>Mary：“你的小弟弟必须要有50cm长” </p>
		<p>我脑袋嗡的一声，坐在椅子上，一咬牙：“我剪，我剪，还有吗？” </p>
		<p>…… </p>
		<p>迭代子模式：迭代子模式可以顺序访问一个聚集中的元素而不必暴露聚集的内部表象。多个对象聚在一起形成的总体称之为聚集，聚集对象是能够包容一组对象的容器对象。迭代子模式将迭代逻辑封装到一个独立的子对象中，从而与聚集本身隔开。迭代子模式简化了聚集的界面。每一个聚集对象都可以有一个或一个以上的迭代子对象，每一个迭代子的迭代状态可以是彼此独立的。迭代算法可以独立于聚集角色变化。 </p>
		<p>17、MEDIATOR—四个MM打麻将，相互之间谁应该给谁多少钱算不清楚了，幸亏当时我在旁边，按照各自的筹码数算钱，赚了钱的从我这里拿，赔了钱的也付给我，一切就OK啦，俺得到了四个MM的电话。 </p>
		<p>调停者模式：调停者模式包装了一系列对象相互作用的方式，使得这些对象不必相互明显作用。从而使他们可以松散偶合。当某些对象之间的作用发生改变时，不会立即影响其他的一些对象之间的作用。保证这些作用可以彼此独立的变化。调停者模式将多对多的相互作用转化为一对多的相互作用。调停者模式将对象的行为和协作抽象化，把对象在小尺度的行为上与其他对象的相互作用分开处理。 </p>
		<p>18、MEMENTO—同时跟几个MM聊天时，一定要记清楚刚才跟MM说了些什么话，不然MM发现了会不高兴的哦，幸亏我有个备忘录，刚才与哪个MM说了什么话我都拷贝一份放到备忘录里面保存，这样可以随时察看以前的记录啦。 </p>
		<p>备忘录模式：备忘录对象是一个用来存储另外一个对象内部状态的快照的对象。备忘录模式的用意是在不破坏封装的条件下，将一个对象的状态捉住，并外部化，存储起来，从而可以在将来合适的时候把这个对象还原到存储起来的状态。 </p>
		<p>19、OBSERVER—想知道咱们公司最新MM情报吗？加入公司的MM情报邮件组就行了，tom负责搜集情报，他发现的新情报不用一个一个通知我们，直接发布给邮件组，我们作为订阅者（观察者）就可以及时收到情报啦 </p>
		<p>观察者模式：观察者模式定义了一种一队多的依赖关系，让多个观察者对象同时监听某一个主题对象。这个主题对象在状态上发生变化时，会通知所有观察者对象，使他们能够自动更新自己。 </p>
		<p>20、STATE—跟MM交往时，一定要注意她的状态哦，在不同的状态时她的行为会有不同，比如你约她今天晚上去看电影，对你没兴趣的MM就会说“有事情啦”，对你不讨厌但还没喜欢上的MM就会说“好啊，不过可以带上我同事么？”，已经喜欢上你的MM就会说“几点钟？看完电影再去泡吧怎么样？”，当然你看电影过程中表现良好的话，也可以把MM的状态从不讨厌不喜欢变成喜欢哦。 </p>
		<p>状态模式：状态模式允许一个对象在其内部状态改变的时候改变行为。这个对象看上去象是改变了它的类一样。状态模式把所研究的对象的行为包装在不同的状态对象里，每一个状态对象都属于一个抽象状态类的一个子类。状态模式的意图是让一个对象在其内部状态改变的时候，其行为也随之改变。状态模式需要对每一个系统可能取得的状态创立一个状态类的子类。当系统的状态变化时，系统便改变所选的子类。</p>
		<p>   21、STRATEGY—跟不同类型的MM约会，要用不同的策略，有的请电影比较好，有的则去吃小吃效果不错，有的去海边浪漫最合适，单目的都是为了得到MM的芳心，我的追MM锦囊中有好多Strategy哦。 </p>
		<p>策略模式：策略模式针对一组算法，将每一个算法封装到具有共同接口的独立的类中，从而使得它们可以相互替换。策略模式使得算法可以在不影响到客户端的情况下发生变化。策略模式把行为和环境分开。环境类负责维持和查询行为类，各种算法在具体的策略类中提供。由于算法和环境独立开来，算法的增减，修改都不会影响到环境和客户端。 </p>
		<p>22、TEMPLATE METHOD——看过《如何说服女生上床》这部经典文章吗？女生从认识到上床的不变的步骤分为巧遇、打破僵局、展开追求、接吻、前戏、动手、爱抚、进去八大步骤(Template method)，但每个步骤针对不同的情况，都有不一样的做法，这就要看你随机应变啦(具体实现)； </p>
		<p>模板方法模式：模板方法模式准备一个抽象类，将部分逻辑以具体方法以及具体构造子的形式实现，然后声明一些抽象方法来迫使子类实现剩余的逻辑。不同的子类可以以不同的方式实现这些抽象方法，从而对剩余的逻辑有不同的实现。先制定一个顶级逻辑框架，而将逻辑的细节留给具体的子类去实现。 </p>
		<p>23、VISITOR—情人节到了，要给每个MM送一束鲜花和一张卡片，可是每个MM送的花都要针对她个人的特点，每张卡片也要根据个人的特点来挑，我一个人哪搞得清楚，还是找花店老板和礼品店老板做一下Visitor，让花店老板根据MM的特点选一束花，让礼品店老板也根据每个人特点选一张卡，这样就轻松多了； </p>
		<p>访问者模式：访问者模式的目的是封装一些施加于某种数据结构元素之上的操作。一旦这些操作需要修改的话，接受这个操作的数据结构可以保持不变。访问者模式适用于数据结构相对未定的系统，它把数据结构和作用于结构上的操作之间的耦合解脱开，使得操作集合可以相对自由的演化。访问者模式使得增加新的操作变的很容易，就是增加一个新的访问者类。访问者模式将有关的行为集中到一个访问者对象中，而不是分散到一个个的节点类中。当使用访问者模式时，要将尽可能多的对象浏览逻辑放在访问者类中，而不是放到它的子类中。访问者模式可以跨过几个类的等级结构访问属于不同的等级结构的成员类。</p>
		<p>转<a href="http://java.ccidnet.com/art/3749/20060622/586221_3.html">http://java.ccidnet.com/art/3749/20060622/586221_3.html</a></p>
		<p> </p>
<img src ="http://www.blogjava.net/mkchen/aggbug/96327.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/mkchen/" target="_blank">海思</a> 2007-01-27 23:05 <a href="http://www.blogjava.net/mkchen/archive/2007/01/27/96327.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>[转]Java 5.0多线程编程 </title><link>http://www.blogjava.net/mkchen/archive/2006/12/24/89792.html</link><dc:creator>海思</dc:creator><author>海思</author><pubDate>Sun, 24 Dec 2006 14:37:00 GMT</pubDate><guid>http://www.blogjava.net/mkchen/archive/2006/12/24/89792.html</guid><wfw:comment>http://www.blogjava.net/mkchen/comments/89792.html</wfw:comment><comments>http://www.blogjava.net/mkchen/archive/2006/12/24/89792.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.blogjava.net/mkchen/comments/commentRss/89792.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/mkchen/services/trackbacks/89792.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 李涛，Sun中国工程研究院工程师																																概述																																																												1：三个新加的多线程包																																					...&nbsp;&nbsp;<a href='http://www.blogjava.net/mkchen/archive/2006/12/24/89792.html'>阅读全文</a><img src ="http://www.blogjava.net/mkchen/aggbug/89792.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/mkchen/" target="_blank">海思</a> 2006-12-24 22:37 <a href="http://www.blogjava.net/mkchen/archive/2006/12/24/89792.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>利用XMLBean轻轻松松读写XML</title><link>http://www.blogjava.net/mkchen/archive/2006/12/21/89382.html</link><dc:creator>海思</dc:creator><author>海思</author><pubDate>Thu, 21 Dec 2006 15:10:00 GMT</pubDate><guid>http://www.blogjava.net/mkchen/archive/2006/12/21/89382.html</guid><wfw:comment>http://www.blogjava.net/mkchen/comments/89382.html</wfw:comment><comments>http://www.blogjava.net/mkchen/archive/2006/12/21/89382.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/mkchen/comments/commentRss/89382.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/mkchen/services/trackbacks/89382.html</trackback:ping><description><![CDATA[
		<center>
				<span style="FONT-SIZE: 20px">
						<b>利用XMLBean轻轻松松读写XML</b>
				</span>
		</center>
		<br />
		<center>作者：叶枫</center>
		<br />
		<br />
		<br />
		<br />
		<span style="COLOR: red">版权声明：本文可以自由转载，转载时请务必以超链接形式标明文章原始出处和作者信息及本声明</span>
		<br />作者:叶枫(<a href="http://blog.matrix.org.cn/page/叶枫" target="_new"><font color="#000080">http://blog.matrix.org.cn/page/叶枫</font></a>)<br />原文:[http://www.matrix.org.cn/resource/article/44/44027_XMLBean.html]http://www.matrix.org.cn/resource/article/44/44027_XMLBean.html[/url]<br />关键字:XML XMLBean Parser<br /><br /><b><span style="FONT-SIZE: 16px">一、关于XML解析</span></b><br /><br />  XML在Java应用程序里变得越来越重要, 广泛应用于数据存储和<br />交换. 比如我们常见的配置文件,都是以XML方式存储的. XML还应用<br />于Java Message Service和Web Services等技术作为数据交换.<br />因此,正确读写XML文档是XML应用的基础.<br />  Java提供了SAX和DOM两种方式用于解析XML,但即便如此,要读写一个<br />稍微复杂的XML,也不是一件容易的事.<br /><br /><b><span style="FONT-SIZE: 16px">二、XMLBean简介</span></b><br /><br />    Hibernate已经成为目前流行的面向Java环境的对象/关系数据库映射工具.<br />在Hibernate等对象/关系数据库映射工具出现之前,对数据库的操作是<br />通过JDBC来实现的,对数据库的任何操作,开发人员都要自己写SQL语句<br />来实现. 对象/关系数据库映射工具出现后,对数据库的操作转成对<br />JavaBean的操作,极大方便了数据库开发. 所以如果有一个类似的工具能够<br />实现将对XML的读写转成对JavaBean的操作,将会简化XML的读写,即使对XML<br />不熟悉的开发人员也能方便地读写XML. 这个工具就是XMLBean.<br /><br /><b><span style="FONT-SIZE: 16px">三、准备XMLBean和XML文档</span></b><br /><br />   XMLBean是Apache的一个开源项目,可以从http://www.apache.org下载,<br />最新的版本是2.0. 解压后目录如下:<br /><span style="COLOR: blue">xmlbean2.0.0<br />     +---bin<br />     +---docs<br />     +---lib<br />     +---samples<br />     +---schemas</span><br /><br />另外还要准备一个XML文档(customers.xml),<br />在本文的例子里,我们将对这个文档进行读写操作. 文档源码如下:<br /><pre class="overflow" title="pre code"><br />&lt;?xml version="1.0" encoding="UTF-8"?&gt;<br />&lt;Customers&gt;<br />    &lt;customer&gt;<br />            &lt;id&gt;1&lt;/id&gt;<br />            &lt;gender&gt;female&lt;/gender&gt;<br />            &lt;firstname&gt;Jessica&lt;/firstname&gt;<br />            &lt;lastname&gt;Lim&lt;/lastname&gt;<br />            &lt;phoneNumber&gt;1234567&lt;/phoneNumber&gt;<br />            &lt;address&gt;<br />                &lt;primaryAddress&gt;<br />                        &lt;postalCode&gt;350106&lt;/postalCode&gt;<br />                        &lt;addressLine1&gt;#25-1&lt;/addressLine1&gt;<br />                        &lt;addressLine2&gt;SHINSAYAMA 2-CHOME&lt;/addressLine2&gt;<br />                &lt;/primaryAddress&gt;<br />                &lt;billingAddress&gt;<br />                        &lt;receiver&gt;Ms Danielle&lt;/receiver&gt;<br />                        &lt;postalCode&gt;350107&lt;/postalCode&gt;<br />                        &lt;addressLine1&gt;#167&lt;/addressLine1&gt;<br />                        &lt;addressLine2&gt;NORTH TOWER HARBOUR CITY&lt;/addressLine2&gt;<br />                &lt;/billingAddress&gt;<br />            &lt;/address&gt;<br />    &lt;/customer&gt;<br />    &lt;customer&gt;<br />            &lt;id&gt;2&lt;/id&gt;<br />            &lt;gender&gt;male&lt;/gender&gt;<br />            &lt;firstname&gt;David&lt;/firstname&gt;<br />            &lt;lastname&gt;Bill&lt;/lastname&gt;<br />            &lt;phoneNumber&gt;808182&lt;/phoneNumber&gt;<br />            &lt;address&gt;<br />                &lt;primaryAddress&gt;<br />                        &lt;postalCode&gt;319087&lt;/postalCode&gt;<br />                        &lt;addressLine1&gt;1033 WS St.&lt;/addressLine1&gt;<br />                        &lt;addressLine2&gt;Tima Road&lt;/addressLine2&gt;<br />                &lt;/primaryAddress&gt;<br />                &lt;billingAddress&gt;<br />                        &lt;receiver&gt;Mr William&lt;/receiver&gt;<br />                        &lt;postalCode&gt;672993&lt;/postalCode&gt;<br />                        &lt;addressLine1&gt;1033 WS St.&lt;/addressLine1&gt;<br />                        &lt;addressLine2&gt;Tima Road&lt;/addressLine2&gt;<br />                &lt;/billingAddress&gt;<br />            &lt;/address&gt;<br />    &lt;/customer&gt;<br />&lt;/Customers&gt;<br /></pre><br /><br />这是一个客户的数据模型,每个客户都有客户编号(ID),姓名,性别(gender),<br />电话号码(phoneNumber)和地址,其中地址有两个: 首要地址(PrimaryAddress)<br />和帐单地址(BillingAddress),每个地址有邮编,地址1,和地址2组成.<br />其中帐单地址还有收件人(receiver).<br /><br />    此外,还要准备一个配置文件(文件名customer.xsdconfig),这个文件的<br />作用我后面会讲,它的内容如下:<br /><pre class="overflow" title="pre code"><br />&lt;xb:config xmlns:xb="http://xml.apache.org/xmlbeans/2004/02/xbean/config"&gt;<br /><br />  &lt;xb:namespace&gt;<br />    &lt;xb:package&gt;sample.xmlbean&lt;/xb:package&gt;<br />  &lt;/xb:namespace&gt;<br /><br />&lt;/xb:config&gt;<br /></pre><br /><br /><b><span style="FONT-SIZE: 16px">四、XMLBean使用步骤</span></b><br /><br />    和其他面向Java环境的对象/关系数据库映射工具的使用步骤一样,<br />在正式使用XMLBean前,我们要作两个准备.<br /><br />    1. 生成XML Schema文件<br /><br />       什么是XML Schema文件? 正常情况下,每个XML文件都有一个Schema文件,<br />       XML Schema文件是一个XML的约束文件,它定义了XML文件的结构和元素.<br />       以及对元素和结构的约束. 通俗地讲,如果说XML文件是数据库里的记录,<br />       那么Schema就是表结构定义.<br /><br />       为什么需要这个文件? XMLBean需要通过这个文件知道一个XML文件的<br />       结构以及约束,比如数据类型等. 利用这个Schema文件,XMLBean将会产生<br />       一系列相关的Java Classes来实现对XML的操作. 而作为开发人员,则是<br />       利用XMLBean产生的Java Classes来完成对XML的操作而不需要SAX或DOM.<br /><br />       怎样产生这个Schema文件呢? 如果对于熟悉XML的开发人员,可以自己来<br />       写这个Schema文件,对于不熟悉XML的开发人员,可以通过一些工具来完成.<br />       比较有名的如XMLSPY和Stylus Studio都可以通过XML文件来生成Schema<br />       文件. 加入我们已经生成这个Schema文件(customer.xsd):<br />       <pre class="overflow" title="pre code"><br />       &lt;?xml version="1.0" encoding="UTF-8"?&gt;<br />       &lt;xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"<br />                  elementFormDefault="qualified"&gt;<br />         &lt;xs:element name="Customers"&gt;<br />           &lt;xs:complexType&gt;<br />             &lt;xs:sequence&gt;<br />               &lt;xs:element maxOccurs="unbounded" name="customer"<br />                           type="customerType"/&gt;<br />             &lt;/xs:sequence&gt;<br />           &lt;/xs:complexType&gt;<br />         &lt;/xs:element&gt;<br />       &lt;xs:complexType name="customerType"&gt;<br />             &lt;xs:sequence&gt;<br />               &lt;xs:element name="id" type="xs:int"/&gt;<br />               &lt;xs:element name="gender" type="xs:string"/&gt;<br />               &lt;xs:element name="firstname" type="xs:string"/&gt;<br />               &lt;xs:element name="lastname" type="xs:string"/&gt;<br />               &lt;xs:element name="phoneNumber" type="xs:string"/&gt;<br />               &lt;xs:element name="address" type="addressType"/&gt;<br />             &lt;/xs:sequence&gt;<br />       &lt;/xs:complexType&gt;<br />         &lt;xs:complexType name="addressType"&gt;<br />             &lt;xs:sequence&gt;<br />               &lt;xs:element name="primaryAddress" type="primaryAddressType"/&gt;<br />               &lt;xs:element name="billingAddress" type="billingAddressType"/&gt;<br />             &lt;/xs:sequence&gt;<br />         &lt;/xs:complexType&gt;<br /><br />         &lt;xs:complexType name="primaryAddressType"&gt;<br />             &lt;xs:sequence&gt;<br />               &lt;xs:element name="postalCode" type="xs:string"/&gt;<br />               &lt;xs:element name="addressLine1" type="xs:string"/&gt;<br />               &lt;xs:element name="addressLine2" type="xs:string"/&gt;<br />             &lt;/xs:sequence&gt;<br />         &lt;/xs:complexType&gt;<br />         &lt;xs:complexType name="billingAddressType"&gt;<br />             &lt;xs:sequence&gt;<br />                   &lt;xs:element name="receiver" type="xs:string"/&gt;<br />               &lt;xs:element name="postalCode" type="xs:string"/&gt;<br />               &lt;xs:element name="addressLine1" type="xs:string"/&gt;<br />               &lt;xs:element name="addressLine2" type="xs:string"/&gt;<br />             &lt;/xs:sequence&gt;<br />         &lt;/xs:complexType&gt;<br />       &lt;/xs:schema&gt;<br />       </pre><br /><br />    2. 利用scomp来生成Java Classes<br /><br />       scomp是XMLBean提供的一个编译工具,它在bin的目录下. 通过这个工具,<br />       我们可以将以上的Schema文件生成Java Classes.<br />       scomp的语法如下:-<br /><br />       <pre class="overflow" title="pre code"><br />       scomp [options] [dirs]* [schemaFile.xsd]* [service.wsdl]* [config.xsdconfig]*<br />       </pre><br /><br />       主要参数说明:<br />       -src [dir]                  -- 生成的Java Classes存放目录<br />     -srconly                  -- 不编译Java Classes,不产生Jar文件<br />     -out [jarFileName]  -- 生成的Jar文件,缺省是xmltypes.jar<br />       -compiler                 -- Java编译器的路径,即Javac的位置<br />       schemaFile.xsd    -- XML Schema文件位置<br />       config.xsdconfig   -- xsdconfig文件的位置, 这个文件主要用来制定生成的Java Class<br />                              的一些文件名规则和Package的名称,在本文,package是sample.xmlbean<br /><br />       在本文,我是这样运行的:<br />       <pre class="overflow" title="pre code"><br />       scomp -src build\src  -out build\customerXmlBean.jar schema\customer.xsd<br />             -compiler C:\jdk142_04\bin\javac customer.xsdconfig<br />       </pre><br /><br />       这个命令行的意思是告诉scomp生成customerXmlBean.jar,放在build目录下,同时<br />       生成源代码放在build\src下, Schema文件是customer.xsd,xsdconfig文件是customer.xsdconfig.<br /><br />       其实, 生成的Java源代码没有多大作用,我们要的是jar文件.我们先看一下build\src\sample\xmlbean下生成的Classes.<br />       <pre class="overflow" title="pre code"><br />          CustomersDocument.java    -- 整个XML文档的Java Class映射<br />       CustomerType.java              -- 节点sustomer的映射<br />       AddressType.java                 -- 节点address的映射<br />       BillingAddressType.java        -- 节点billingAddress的映射<br />       PrimaryAddressType.java      -- 节点primaryAddress的映射<br />     </pre><br /><br />       好了,到此我们所有的准备工作已经完成了. 下面就开始进入重点：利用刚才生成的jar文件读写XML.<br /><br /><b><span style="FONT-SIZE: 16px">五、利用XMLBean读XML文件</span></b><br /><br />    新建一个Java Project,将XMLBean2.0.0\lib\下的Jar文件和刚才我们生成的customerXmlBean.jar加入<br />    到Project的ClassPath.<br /><br />    新建一个Java Class: CustomerXMLBean.  源码如下:<br />    <pre class="overflow" title="pre code"><br />    package com.sample.reader;<br /><br />    import java.io.File;<br />    <br />    import sample.xmlbean.*;<br />    import org.apache.commons.beanutils.BeanUtils;<br />    import org.apache.xmlbeans.XmlOptions;<br />    public class CustomerXMLBean {<br />    private String filename = null;<br />    <br />    public CustomerXMLBean(String filename) {<br />            super();<br />            this.filename = filename;<br />    }<br /><br />    public void customerReader() {<br />            try {<br />              File xmlFile = new File(filename);<br />              CustomersDocument doc = CustomersDocument.Factory.parse(xmlFile);<br />              CustomerType[] customers = doc.getCustomers().getCustomerArray();<br />          <br />              for (int i = 0; i &lt; customers.length; i++) {<br />                CustomerType customer = customers[i];<br />                println("Customer#" + i);<br />                println("Customer ID:" + customer.getId());<br />                println("First name:" + customer.getFirstname());<br />                println("Last name:" + customer.getLastname());<br />                println("Gender:" + customer.getGender());<br />                println("PhoneNumber:" + customer.getPhoneNumber());<br />                // Primary address<br />                PrimaryAddressType primaryAddress = customer.getAddress().getPrimaryAddress();<br />                println("PrimaryAddress:");<br />                println("PostalCode:" + primaryAddress.getPostalCode());<br />                println("AddressLine1:" + primaryAddress.getAddressLine1());<br />                println("AddressLine2:" + primaryAddress.getAddressLine2());<br />                // Billing address<br />                BillingAddressType billingAddress = customer.getAddress().getBillingAddress();<br />                println("BillingAddress:");<br />                println("Receiver:" + billingAddress.getReceiver());<br />                println("PostalCode:" + billingAddress.getPostalCode());<br />                println("AddressLine1:" + billingAddress.getAddressLine1());<br />                println("AddressLine2:" + billingAddress.getAddressLine2());<br />            <br />              }<br />            } catch (Exception ex) {<br />                    ex.printStackTrace();<br />            }<br />    }<br />    private void println(String str) {<br />          System.out.println(str);<br />    }<br />   public static void main(String[] args) {<br />      String filename = "F://JavaTest//Eclipse//XMLBean//xml//customers.xml";<br />                   <br />     CustomerXMLBean customerXMLBean = new CustomerXMLBean(filename);<br />                   customerXMLBean.customerReader();<br />    }<br /><br />    }<br />    </pre><br /><br />    运行它,参看输出结果:<br />    <pre class="overflow" title="pre code"><br />       Customer#0<br />       Customer ID:1<br />       First name:Jessica<br />       Last name:Lim<br />       Gender:female<br />       PhoneNumber:1234567<br />       PrimaryAddress:<br />       PostalCode:350106<br />       AddressLine1:#25-1<br />       AddressLine2:SHINSAYAMA 2-CHOME<br />       BillingAddress:<br />       Receiver:Ms Danielle<br />       PostalCode:350107<br />       AddressLine1:#167<br />       AddressLine2:NORTH TOWER HARBOUR CITY<br /><br />       Customer#1<br />       Customer ID:2<br />       First name:David<br />       Last name:Bill<br />       Gender:male<br />       PhoneNumber:808182<br />       PrimaryAddress:<br />       PostalCode:319087<br />       AddressLine1:1033 WS St.<br />       AddressLine2:Tima Road<br />       BillingAddress:<br />       Receiver:Mr William<br />       PostalCode:672993<br />       AddressLine1:1033 WS St.<br />       AddressLine2:Tima Road<br />    </pre><br />    怎么样,是不是很轻松? XMLBean的威力.<br /><br /><b><span style="FONT-SIZE: 16px">六、利用XMLBean写XML文件</span></b><br /><br />    利用XMLBean创建一个XML文档也是一件轻而易举的事.我们再增加一个Method,<br />    请看一下的Java Class:<br />    <pre class="overflow" title="pre code"><br />    public void createCustomer() {<br />    try {<br />        // Create Document<br />        CustomersDocument doc = CustomersDocument.Factory.newInstance();<br />        // Add new customer<br />        CustomerType customer = doc.addNewCustomers().addNewCustomer();<br />        // set customer info<br />        customer.setId(3);<br />        customer.setFirstname("Jessica");<br />        customer.setLastname("Lim");<br />        customer.setGender("female");<br />        customer.setPhoneNumber("1234567");<br />        // Add new address<br />        AddressType address = customer.addNewAddress();<br />        // Add new PrimaryAddress<br />        PrimaryAddressType primaryAddress = address.addNewPrimaryAddress();<br />        primaryAddress.setPostalCode("350106");<br />        primaryAddress.setAddressLine1("#25-1");<br />        primaryAddress.setAddressLine2("SHINSAYAMA 2-CHOME");<br /><br />        // Add new BillingAddress<br />        BillingAddressType billingAddress = address.addNewBillingAddress();<br />        billingAddress.setReceiver("Ms Danielle");<br />        billingAddress.setPostalCode("350107");<br />        billingAddress.setAddressLine1("#167");<br />        billingAddress.setAddressLine2("NORTH TOWER HARBOUR CITY");<br /><br />        File xmlFile = new File(filename);<br />        doc.save(xmlFile);<br />        } catch (Exception ex) {<br />                ex.printStackTrace();<br />        }<br /><br />  }<br />    </pre><br />    修改main method.<br />    <pre class="overflow" title="pre code"><br />    public static void main(String[] args) {<br />    String filename = "F://JavaTest//Eclipse//XMLBean//xml//customers_new.xml";<br />        CustomerXMLBean customerXMLBean = new CustomerXMLBean(filename);<br />        customerXMLBean.createCustomer();<br />    }<br />    </pre><br />    运行,打开customers_new.xml:<br />    <pre class="overflow" title="pre code"><br />    &lt;?xml version="1.0" encoding="UTF-8"?&gt;<br />    &lt;Customers&gt;<br />    &lt;customer&gt;<br />            &lt;id&gt;3&lt;/id&gt;<br />            &lt;gender&gt;female&lt;/gender&gt;<br />            &lt;firstname&gt;Jessica&lt;/firstname&gt;<br />            &lt;lastname&gt;Lim&lt;/lastname&gt;<br />            &lt;phoneNumber&gt;1234567&lt;/phoneNumber&gt;<br />            &lt;address&gt;<br />                    &lt;primaryAddress&gt;<br />                         &lt;postalCode&gt;350106&lt;/postalCode&gt;<br />                         &lt;addressLine1&gt;#25-1&lt;/addressLine1&gt;<br />                                       &lt;addressLine2&gt;SHINSAYAMA 2-CHOME&lt;/addressLine2&gt;<br />                    &lt;/primaryAddress&gt;<br />                    &lt;billingAddress&gt;<br />                        &lt;receiver&gt;Ms Danielle&lt;/receiver&gt;<br />                        &lt;postalCode&gt;350107&lt;/postalCode&gt;<br />                       &lt;addressLine1&gt;#167&lt;/addressLine1&gt;<br />                       &lt;addressLine2&gt;NORTH TOWER HARBOUR CITY&lt;/addressLine2&gt;<br />                    &lt;/billingAddress&gt;<br />                    &lt;/address&gt;<br />            &lt;/customer&gt;<br />    &lt;/Customers&gt;<br />    </pre><br /><br /><br /><b><span style="FONT-SIZE: 16px">七、利用XMLBean修改XML文件</span></b><br /><br />    我们再增加一个Method:<br />    <pre class="overflow" title="pre code"><br />      public void updateCustomer(int id,String lastname) {<br />         try {<br />        File xmlFile = new File(filename);<br />        CustomersDocument doc = CustomersDocument.Factory.parse(xmlFile);<br />        CustomerType[] customers = doc.getCustomers().getCustomerArray();<br />      <br />        for (int i = 0; i &lt; customers.length; i++) {<br />           CustomerType customer = customers[i];<br />          if(customer.getId()==id){<br />                customer.setLastname(lastname);<br />                break;<br />            }<br />        }<br />        doc.save(xmlFile);<br />         } catch (Exception ex) {<br />          ex.printStackTrace();<br />         }<br />           }<br />    </pre><br />    main method:<br />    <pre class="overflow" title="pre code"><br />    public static void main(String[] args) {<br />     String filename = "F://JavaTest//Eclipse//XMLBean//xml//customers_new.xml";<br />                    <br />    CustomerXMLBean customerXMLBean = new CustomerXMLBean(filename);<br />                    <br />    customerXMLBean.updateCustomer(3,"last");<br />    }<br />    </pre><br />    运行之后,我们将会看到客户编号为3的客户的lastname已经改为last.<br /><br /><b><span style="FONT-SIZE: 16px">八、利用XMLBean删除一个customer</span></b><br /><br />    再增加一个Method:<br />    <pre class="overflow" title="pre code"><br />    public void deleteCustomer(int id) {<br />     try {<br />      File xmlFile = new File(filename);<br />     CustomersDocument doc = CustomersDocument.Factory.parse(xmlFile);<br />    CustomerType[] customers = doc.getCustomers().getCustomerArray();<br /><br />   for (int i = 0; i &lt; customers.length; i++) {<br />        CustomerType customer = customers[i];<br />        if(customer.getId()==id){<br />                        customer.setNil() ;<br />                        break;<br />               }<br />   }<br />   doc.save(xmlFile);<br />   } catch (Exception ex) {<br />        ex.printStackTrace();<br />        }<br />   }<br /></pre><br /><br />         main method:<br />    <pre class="overflow" title="pre code"><br />    public static void main(String[] args) {<br />    String filename = "F://JavaTest//Eclipse//XMLBean//xml//customers_new.xml";<br />                    <br />    CustomerXMLBean customerXMLBean = new CustomerXMLBean(filename);<br />                    <br />    customerXMLBean.deleteCustomer(3);<br />    }<br /></pre><br />        <br />运行,我们将会看到客户编号为3的客户的资料已经被删除.<br /><br /><b><span style="FONT-SIZE: 16px">九、查询XML</span></b><br /><br />    除了本文在以上讲述的,利用XMLBean能轻轻松松完成XML的读写操作外,结合XPath和XQuery,<br />   XMLBean还能完成象SQL查询数据库一样方便地查询XML数据. 关于XML查询以及如何创建XML数据库, 我将在另一篇文章里讨论.<br /><br /><br /><br /><b><span style="FONT-SIZE: 16px">十、结束语</span></b><br />    XMLBean能帮助我们轻易读写XML,这将有助于我们降低XML的学习和使用,有了这个基础,<br />    开发人员将为学习更多地XML相关技术和Web Services,JMS等其他J2EE技术打下良好地基础.<br /><br /><br /><b>关于作者：</b><br />叶枫：热爱Java和Oracle. 在软件开发有近10年, 目前在国外一家美国大公司担任SA, 负责技术研究。作者Blog：<a href="http://blog.matrix.org.cn/page/叶枫" target="_new"><font color="#000080">http://blog.matrix.org.cn/page/叶枫</font></a><img src ="http://www.blogjava.net/mkchen/aggbug/89382.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/mkchen/" target="_blank">海思</a> 2006-12-21 23:10 <a href="http://www.blogjava.net/mkchen/archive/2006/12/21/89382.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>编写你自己的单点登录（SSO）服务</title><link>http://www.blogjava.net/mkchen/archive/2006/12/21/89377.html</link><dc:creator>海思</dc:creator><author>海思</author><pubDate>Thu, 21 Dec 2006 14:42:00 GMT</pubDate><guid>http://www.blogjava.net/mkchen/archive/2006/12/21/89377.html</guid><wfw:comment>http://www.blogjava.net/mkchen/comments/89377.html</wfw:comment><comments>http://www.blogjava.net/mkchen/archive/2006/12/21/89377.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/mkchen/comments/commentRss/89377.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/mkchen/services/trackbacks/89377.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 作者的blog: http://yuwang881.blog.sohu.com/http://blog.csdn.net/javachannel/archive/2006/05/24/752437.aspx王昱 yuwang881@gmail.com   博客地址http://yuwang881.blog.sohu.com摘要：单点登录（SSO）的技术被越来越广泛地运用到各个领域的软件系统当中。本...&nbsp;&nbsp;<a href='http://www.blogjava.net/mkchen/archive/2006/12/21/89377.html'>阅读全文</a><img src ="http://www.blogjava.net/mkchen/aggbug/89377.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/mkchen/" target="_blank">海思</a> 2006-12-21 22:42 <a href="http://www.blogjava.net/mkchen/archive/2006/12/21/89377.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>java实现的18位身份证格式验证算法</title><link>http://www.blogjava.net/mkchen/archive/2006/12/21/89366.html</link><dc:creator>海思</dc:creator><author>海思</author><pubDate>Thu, 21 Dec 2006 13:47:00 GMT</pubDate><guid>http://www.blogjava.net/mkchen/archive/2006/12/21/89366.html</guid><wfw:comment>http://www.blogjava.net/mkchen/comments/89366.html</wfw:comment><comments>http://www.blogjava.net/mkchen/archive/2006/12/21/89366.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/mkchen/comments/commentRss/89366.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/mkchen/services/trackbacks/89366.html</trackback:ping><description><![CDATA[公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成.排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。1、地址码表示编码对象常住户口所在县（市、旗、区）的行政区划代码，按GB/T2260的规定执行。<br /><br />　　2、出生日期码表示编码对象出生的年、月、日，按GB/T7408的规定执行。年、月、日代码之间不用分隔符。例：某人出生日期为1966年10月26日，其出生日期码为19661026。<br /><br />　　3、顺序码表示在同一地址码所标识的区域范围内，对同年、同月、同日出生的人编定的顺序号，顺序码的奇数分配给男性，偶数千分配给女性。<br /><br />　　4、校验码校验码采用ISO7064：1983，MOD11-2校验码系统。<br /><br />　　1）十七位数字本体码加权求和公式　S=Sum(Ai*Wi),i=0,...,16，先对前17位数字的权求和　Ai:表示第i位置上的身份证号码数字值　Wi:表示第i位置上的加权因子　Wi:7910584216379105842<br /><br />　　2）计算模　Y=mod(S,11)<br /><br />　　3）通过模得到对应的校验码　:012345678910　验码:10X98765432<br /><br />　　下面是java实现的代码<br /><br />　　/**IDCard.javaCreatedon2004-11-517:03:37**/packageorg.yz21.study.idcard;<br /><br />　　/***@authorviolin2004-11-517:03:37*Copyrightwww.yz21.org2003-2004*/publicclassIDCard{//wi=2(n-1)(mod11)finalint[]wi={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2,1};<br /><br />　　//verifydigitfinalint[]vi={1,0,X,9,8,7,6,5,4,3,2};<br /><br />　　privateint[]ai=newint[18];<br /><br />　　publicIDCard(){}<br /><br />　　//verifypublicbooleanVerify(Stringidcard){if(idcard.length()==15){idcard=uptoeighteen(idcard);}if(idcard.length()!=18){returnfalse;}Stringverify=idcard.substring(17,18);if(verify.equals(getVerify(idcard))){returntrue;}returnfalse;}<br /><br />　　//getverifypublicStringgetVerify(Stringeightcardid){intremaining=0;<br /><br />　　if(eightcardid.length()==18){eightcardid=eightcardid.substring(0,17);}<br /><br />　　if(eightcardid.length()==17){intsum=0;for(inti=0;i&lt;17;i++){Stringk=eightcardid.substring(i,i+1);ai=Integer.parseInt(k);}<br /><br />　　for(inti=0;i&lt;17;i++){sum=sum+wi*ai;}remaining=sum%11;}<br /><br />　　returnremaining==2?"X":String.valueOf(vi[remaining]);}<br /><br />　　//15updateto18publicStringuptoeighteen(Stringfifteencardid){Stringeightcardid=fifteencardid.substring(0,6);eightcardid=eightcardid+"19";eightcardid=eightcardid+fifteencardid.substring(6,15);eightcardid=eightcardid+getVerify(eightcardid);returneightcardid;}<br /><br />　　}<br /><br />　　测试代码：使用的单元测试工具是junit<br /><br />　　/**IDCardTest.javaCreatedon2004-11-517:32:12**/packageorg.yz21.study.idcard;<br /><br />　　importjunit.framework.Test;importjunit.framework.TestCase;importjunit.framework.TestSuite;<br /><br />　　/***@authorviolin2004-11-517:32:12*Copyrightwww.yz21.org2003-2004*/publicclassIDCardTestextendsTestCase{<br /><br />　　privateStringidcard1="11010519491231002X";privateStringidcard2="440524188001010014";<br /><br />　　publicvoidtestVerify(){IDCardidcard=newIDCard();this.assertTrue(idcard.Verify(idcard1));this.assertTrue(idcard.Verify(idcard2));}<br /><br />　　publicstaticTestsuite(){returnnewTestSuite(IDCardTest.class);}<br /><br />　　publicstaticvoidmain(String[]args){junit.textui.TestRunner.run(suite());}} <br /><img src ="http://www.blogjava.net/mkchen/aggbug/89366.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/mkchen/" target="_blank">海思</a> 2006-12-21 21:47 <a href="http://www.blogjava.net/mkchen/archive/2006/12/21/89366.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>