亚洲一级毛片免费在线观看,亚洲国产精品视频,高清在线亚洲精品国产二区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閱讀全文

]]> - 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安全域用戶綁在一起。

]]>
主站蜘蛛池模板:
免费AA片少妇人AA片直播|
免费在线看黄网站|
国内自产少妇自拍区免费|
亚洲一区二区三区精品视频|
57pao国产成永久免费视频|
亚洲国产精品一区二区久久|
国产情侣久久久久aⅴ免费|
亚洲av无码成h人动漫无遮挡|
色吊丝最新永久免费观看网站|
日韩视频免费在线|
久久精品国产亚洲AV|
波多野结衣中文一区二区免费|
国产亚洲A∨片在线观看|
中文字幕免费人成乱码中国|
亚洲人成影院在线无码按摩店|
亚洲国产成a人v在线|
韩国日本好看电影免费看|
国产亚洲综合视频|
久久久久久久亚洲精品|
99re6热视频精品免费观看|
亚洲人成在线播放|
亚洲äv永久无码精品天堂久久|
亚洲最大AV网站在线观看|
免费一区二区三区|
亚洲日本国产综合高清|
妞干网免费视频观看|
无人视频在线观看免费播放影院|
九九精品免费视频|
日韩在线视频播放免费视频完整版|
97免费人妻无码视频|
亚洲欧美自偷自拍另类视|
国产亚洲精品免费视频播放|
波多野结衣免费一区视频
|
亚洲精品国产免费|
亚洲国产日韩精品|
亚洲色无码专区在线观看|
中文字幕无码成人免费视频|
免费国产a理论片|
亚洲欧洲日产v特级毛片|
国产一区二区三区在线免费|
一区二区三区观看免费中文视频在线播放|