posts - 11,  comments - 14,  trackbacks - 0
  2006年12月4日
一、el
var el =Ext.get('例如:formname');
var map = new Ext.KeyMap(el, {
key: Ext.EventObject.ENTER,
fn: function(){
event.keyCode=9;
}
});

二、EditGrid,需修改源码
onEditorKey:function (F, E) {
 var C = E.getKey(), G, D = this.grid, B = D.activeEditor;
 var A = E.shiftKey;
 if (C == E.TAB) {
  E.stopEvent();
  B.completeEdit();
  if (A) {
   G = D.walkCells(B.row, B.col - 1, -1, this.acceptsNav, this);
  } else {
   G = D.walkCells(B.row, B.col + 1, 1, this.acceptsNav, this);
  }
 } else {
  if (C == E.ENTER) {
   E.stopEvent();
   B.completeEdit();
   if (this.moveEditorOnEnter !== false) {
    if (A) {
     //G = D.walkCells(B.row - 1, B.col, -1this.acceptsNav,this)
     G = D.walkCells(B.row, B.col - 1, -1, this.acceptsNav, this);
    } else {
     // G = D.walkCells(B.row + 1, B.col, 1this.acceptsNav,this)
     G = D.walkCells(B.row, B.col + 1, 1, this.acceptsNav, this);
    }
   }
  } else {
   if (C == E.ESC) {
    B.cancelEdit();
   }
  }
 }
 if (G) {
  D.startEditing(G[0], G[1]);
 }
}

posted @ 2008-08-24 12:14 jinn 阅读(2670) | 评论 (4)编辑 收藏
     摘要: Webservice交互中需要双方约定数据格式,用XML表示数据库记录是不错的选择。 先定义个DTD: <!--      DTD for the Xml-Format-String used to transmit business data --> <!-- The "DBSET" element is the root of...  阅读全文
posted @ 2008-07-18 15:13 jinn 阅读(2032) | 评论 (1)编辑 收藏
Webservice交互经常需要验证用户,用户名和密码的传递采用SOAPHeader传递不失为一种好办法。在Axis1中设置很简单:
客户端:
((org.apache.axis.client.Call) call).addHeader(new SOAPHeaderElement("Authorization","username",username));
((org.apache.axis.client.Call) call).addHeader(new SOAPHeaderElement("Authorization","password",password));

经包装后传递的内容如下
<soapenv:Header>
  <ns1:username
   soapenv:actor="http://schemas.xmlsoap.org/soap/actor/next"
   soapenv:mustUnderstand="0" xsi:type="soapenc:string"
   xmlns:ns1="Authorization"
   xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/">
   admin
  </ns1:username>
  <ns2:password
   soapenv:actor="http://schemas.xmlsoap.org/soap/actor/next"
   soapenv:mustUnderstand="0" xsi:type="soapenc:string"
   xmlns:ns2="Authorization"
   xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/">
   1
  </ns2:password>
 </soapenv:Header>

服务端通过Handler取得用户名和密码进行验证:
username = (String) messageContext.getRequestMessage().getSOAPEnvelope()
.getHeaderByName("Authorization","username").getValue();
password = (String) messageContext.getRequestMessage().getSOAPEnvelope()
.getHeaderByName("Authorization","password").getValue();

如果觉得这样不安全,可双方约定一种加密解密规则,将用户名和密码加密后进行传输。

我曾试过使用如下方法,
客户端:
((org.apache.axis.client.Call) call).setUsername(username);
((org.apache.axis.client.Call) call).setPassword(password);

包装后传递内容(多了最后一句:Authorization: Basic emphZG1pbjox。Axis将用户名和密码经Base64加密后传递):
POST /web/services/GenericServer HTTP/1.0
Content-Type: text/xml; charset=utf-8
Accept: application/soap+xml, application/dime, multipart/related, text/*
User-Agent: Axis/1.4
Host: localhost:8083
Cache-Control: no-cache
Pragma: no-cache
SOAPAction: ""
Content-Length: 807
Authorization: Basic emphZG1pbjox

服务端的Handle:
username =messageContext.getUsername();
password = messageContext.getPassword();

这样是没问题,看起来更简单。可惜调用部署在weblogic上的ws时,会被weblogic拦截,必须在weblogic安全域中配置相应的用户才能通过验证,这不是我们所需要的,通常我们有自己的用户管理机制,调用WS的用户也作为系统中的一个用户纳入我们的管理,而不是跟weblogic安全域用户绑在一起。

posted @ 2008-07-18 13:18 jinn 阅读(5899) | 评论 (1)编辑 收藏
     摘要: Jacob的下载、配置就不说了,提醒下,官方的提供的17版本似乎不支持jdk1.5,得下载19版的(CSDN上有)。 研究这个的目的是想用java生成符合格式的word文档,文档内容大体上有三种格式,Heading1、Heading2和Normal,在word的文档结构图显示的样子如下 Heading 1    Heading 2    H...  阅读全文
posted @ 2008-07-18 11:21 jinn 阅读(4610) | 评论 (4)编辑 收藏
     摘要: 2007,也许会有危险,也许会有障碍,所以......  阅读全文
posted @ 2006-12-31 15:18 jinn 阅读(341) | 评论 (0)编辑 收藏

alphal 内部测试版

beta 外部测试版

demo 演示版

Enhance 增强版或者加强版 属于正式版

Free 自由版

Full version 完全版 属于正式版

shareware 共享版

Release 发行版 有时间限制

Upgrade 升级版

Retail 零售版

Cardware 属共享软件的一种,只要给作者回复一封电邮或明信片即可。(有的作者并由此提供注册码等),目前这种形式已不多见。

Plus 属增强版,不过这种大部分是在程序界面及多媒体功能上增强。

Preview 预览版

Corporation & Enterprise 企业版

Standard 标准版

Mini 迷你版也叫精简版只有最基本的功能

Premium -- 贵价版

Professional -- 专业版

Express -- 特别版

Deluxe -- 豪华版

Regged -- 已注册版

CN -- 简体中文版

CHT -- 繁体中文版

EN -- 英文版

Multilanguage -- 多语言版

 


 

posted @ 2006-12-15 18:56 jinn 阅读(417) | 评论 (2)编辑 收藏
static:用来修饰字段和方法。
通常情况下,我们通过创建类的对象来访问其字段和方法,而将字段或方法声明为static意味着这个字段或方法作为整个类而不是类的某个特定对象而存在,可以通过类名直接引用它们。
一个static字段对每个类来说都只有一份存储空间,而非static字段则是对每个对象有一份存储空间。
static方法的一个重要用法就是不用创建对象而通过类直接引用它。

final:用来修饰字段、方法和类。
final修饰字段。对于基本类型,final使数值恒定不变,而对于对象引用,final使引用恒定不变,一旦引用被初始化指向一个对象,就无法把它改为指向另一个对象,然而,对象其本身是可以被修改的。
一个既是static又是final的字段只占据一段不能改变的存储空间。
带有恒定初始值(即,编译时常量)的static final基本类型全用大写字母命名,并且字与字之间用下划线隔开。
空白final是指声明为final但又未给定初值的字段,这个字段在运行时初始化,并在以后保持恒定不变。
final参数意味着你无法在方法中更改参数引用所指向的对象,你可以引用参数,但无法改变它。
   
final修饰方法。使用final方法的原因有两个,第一个原因是把方法锁定,以防任何继承类来修改它的含义。这个出于设计的考虑:想要保证在继承中使方法行为保持不变,并且不会被覆盖。
使用final方法的第二个原因是效率。如果将一个方法指定为final,就是同意编译器将针对改方法的所有调用都转为内嵌调用,而编译器会根据开销情况明智的抉择是否对final方法执行内嵌调用。
类中的所有private方法都隐式的指定为final的。

final修饰类。将某个类定义为final表明该类不能被继承。
final类的字段可以根据个人的意愿选择是或不是final,不论类是否定义为final,相同的规则都适用与final字段。
而final类的所有方法都隐式的指定为final的。
posted @ 2006-12-04 01:22 jinn 阅读(674) | 评论 (0)编辑 收藏
<2006年12月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用链接

留言簿(3)

随笔分类

文章分类

相册

网站链接

搜索

  •  

最新评论

阅读排行榜

评论排行榜