亚洲一级毛片免费在线观看,亚洲国产精品视频,高清在线亚洲精品国产二区http://www.tkk7.com/jinn/category/33084.html Jinn's Programming Roadzh-cnFri, 18 Jul 2008 14:47:04 GMTFri, 18 Jul 2008 14:47:04 GMT60用Stax組裝及解析XMLhttp://www.tkk7.com/jinn/archive/2008/07/18/215812.htmljinnjinnFri, 18 Jul 2008 07:13:00 GMThttp://www.tkk7.com/jinn/archive/2008/07/18/215812.htmlhttp://www.tkk7.com/jinn/comments/215812.htmlhttp://www.tkk7.com/jinn/archive/2008/07/18/215812.html#Feedback0http://www.tkk7.com/jinn/comments/commentRss/215812.htmlhttp://www.tkk7.com/jinn/services/trackbacks/215812.html閱讀全文

jinn 2008-07-18 15:13 發(fā)表評論
]]>
Axis中用戶名、密碼傳遞http://www.tkk7.com/jinn/archive/2008/07/18/215750.htmljinnjinnFri, 18 Jul 2008 05:18:00 GMThttp://www.tkk7.com/jinn/archive/2008/07/18/215750.htmlhttp://www.tkk7.com/jinn/comments/215750.htmlhttp://www.tkk7.com/jinn/archive/2008/07/18/215750.html#Feedback0http://www.tkk7.com/jinn/comments/commentRss/215750.htmlhttp://www.tkk7.com/jinn/services/trackbacks/215750.htmlWebservice交互經(jīng)常需要驗證用戶,用戶名和密碼的傳遞采用SOAPHeader傳遞不失為一種好辦法。在Axis1中設(shè)置很簡單:
客戶端:
((org.apache.axis.client.Call) call).addHeader(new SOAPHeaderElement("Authorization","username",username));
((org.apache.axis.client.Call) call).addHeader(new SOAPHeaderElement("Authorization","password",password));

經(jīng)包裝后傳遞的內(nèi)容如下
<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>

服務(wù)端通過Handler取得用戶名和密碼進行驗證:
username = (String) messageContext.getRequestMessage().getSOAPEnvelope()
.getHeaderByName("Authorization","username").getValue();
password = (String) messageContext.getRequestMessage().getSOAPEnvelope()
.getHeaderByName("Authorization","password").getValue();

如果覺得這樣不安全,可雙方約定一種加密解密規(guī)則,將用戶名和密碼加密后進行傳輸。

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

包裝后傳遞內(nèi)容(多了最后一句:Authorization: Basic emphZG1pbjox。Axis將用戶名和密碼經(jīng)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

服務(wù)端的Handle:
username =messageContext.getUsername();
password = messageContext.getPassword();

這樣是沒問題,看起來更簡單。可惜調(diào)用部署在weblogic上的ws時,會被weblogic攔截,必須在weblogic安全域中配置相應(yīng)的用戶才能通過驗證,這不是我們所需要的,通常我們有自己的用戶管理機制,調(diào)用WS的用戶也作為系統(tǒng)中的一個用戶納入我們的管理,而不是跟weblogic安全域用戶綁在一起。



jinn 2008-07-18 13:18 發(fā)表評論
]]>
主站蜘蛛池模板: 四虎精品成人免费视频| 亚洲国产日韩在线成人蜜芽| 亚洲精品乱码久久久久蜜桃 | 亚洲免费黄色网址| 69av免费视频| 亚洲一区欧洲一区| 日韩免费在线观看| 美美女高清毛片视频黄的一免费 | 91视频精品全国免费观看| 国产日产亚洲系列最新| 三根一起会坏掉的好痛免费三级全黄的视频在线观看 | 在线免费播放一级毛片| 久久夜色精品国产亚洲| 69视频在线是免费观看| 国产精品亚洲片在线va| 永久黄网站色视频免费观看| 亚洲AV永久无码精品一福利| 伊在人亚洲香蕉精品区麻豆| 精品97国产免费人成视频| 亚洲国产天堂在线观看| 久久久久久国产a免费观看黄色大片 | 中文字幕av免费专区| 亚洲av日韩av无码| 久久天天躁狠狠躁夜夜免费观看| 亚洲欧美精品午睡沙发| 亚洲高清视频一视频二视频三| 中文字幕免费观看全部电影| 久久精品国产亚洲AV嫖农村妇女| a级毛片无码免费真人| 麻豆69堂免费视频| 亚洲v高清理论电影| 在线观看人成网站深夜免费| caoporm超免费公开视频| 亚洲av永久无码精品漫画| 毛片免费vip会员在线看| 特黄特色的大片观看免费视频| 亚洲电影一区二区| 精品久久免费视频| 久久午夜夜伦鲁鲁片无码免费| 亚洲一卡2卡三卡4卡无卡下载| 亚洲免费视频一区二区三区|