快速业务通道

用Kerberos为J2ME应用程序上锁,第3部分 - 建立与电子银行的安全通信(下) - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-15
ey 和 seq-number 字段,链接 authenticator -vno、crealm、cname、cksum、cusec 和 ctime 字段以构成串接的字节数组,将这个字节数组包装到一 个 SEQUENCE 中,然后将这个 SEQUENCE 包装到 Authenticator 中(应用程序级别标签号 2)。

下面,需要取完整的 Authenticator 结构并将它传递 authorDigestAndEncrypt() 方法,这个方法返 回纯文本 Authenticator 的完整 EncryptedData 表示。

下一个任务是串接认证头或者 KRB-AP-REQ 结构的五个字段( pvno、msg-type、ap-options、ticket 、authenticator )为一个字节数组,将这个字节数组包装为一个 SEQUECNE ,最后将这个 SEQUENCE 包 装到应用程序级别的标签号 14。

现在已经完成认证头,可以将它返回给给调用应用程序了。

喘Kerberos葎J2ME哘喘殻會貧迄?及3何蛍 - 秀羨嚥窮徨咢佩議芦畠宥佚?和?(7)

扮寂:2011-08-05 IBM Faheem Khan

伏撹捲暦同象萩箔

厘網胎阻伏撹捲暦同象萩箔俶勣議侭嗤詰蚊圭隈。繍聞喘 賠汽 1 嶄萩箔 TGT 扮侭聞喘議揖匯倖 getTicketResponse() 圭隈伏撹捲暦同象萩箔?峪俶勣斤 賠汽 1 不紗俐個參聞万辛參揖扮喘噐 TGT 才 捲暦同象萩箔。斑厘断心匯和宸倖狛殻。

心匯和 賠汽 20?凪嶄辛參心欺俐個狛議賠汽 1 嶄議 getTicketRespone() 圭隈。嚥 賠汽 1?曳? 俐個狛議井云奐紗阻匯乂旗鷹?

賠汽 20. getTicketResponse() 圭隈

public byte[] getTicketResponse( String userName,                    String serverName,                    String realmName,                    byte[] kerberosTicket,                    byte[] key                   )    {     byte ticketRequest[];     byte msg_type[];     byte pvno[] = getTagAndLengthBytes(ASN1DataTypes.CONTEXT_SPECIFIC,             1, getIntegerBytes(5));     msg_type = getTagAndLengthBytes(ASN1DataTypes.CONTEXT_SPECIFIC,            2, getIntegerBytes(10));     byte kdc_options[] = getTagAndLengthBytes(ASN1DataTypes.CONTEXT_SPECIFIC,                 0, getBitStringBytes(new byte[5]));     byte generalStringSequence[] = getSequenceBytes (                      getGeneralStringBytes (userName));     byte name_string[] = getTagAndLengthBytes(ASN1DataTypes.CONTEXT_SPECIFIC,                 1, generalStringSequence);     byte name_type[] = getTagAndLengthBytes(ASN1DataTypes.CONTEXT_SPECIFIC,                0, getIntegerBytes(ASN1DataTypes.NT_PRINCIPAL));     byte principalNameSequence [] = getSequenceBytes(                  concatenateBytes (name_type, name_string));     byte cname[] = getTagAndLengthBytes (ASN1DataTypes.CONTEXT_SPECIFIC,              1, principalNameSequence);     byte realm[] = getTagAndLengthBytes (ASN1DataTypes.CONTEXT_SPECIFIC,              2, getGeneralStringBytes (realmName));     byte sgeneralStringSequence[] = concatenateBytes(getGeneralStringBytes (serverName),                       getGeneralStringBytes (realmName));     byte sname_string[] = getTagAndLengthBytes(ASN1DataTypes.

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号