Rpc - wsdl
5833 ワード
いくつかの省の4 Aに接続して、少し共通性を発見して、記録します.技術:axis
axis 1.*
コアjarパッケージ(最小必要):
1.axis.jar 2.jaxrpc.jar 3.commons-logging-${version}.jar 4.commons-discovery-${version}.jar 5.wsdl4j-1.5.1.jar
よびだし
axis 2.*
コアjarパッケージ:
axiom-api-1.2.15.jar axiom-impl-1.2.15.jar axis2-adb-1.6.4.jar axis2-kernel-1.6.4.jar axis2-transport-http-1.6.4.jar axis2-transport-local-1.6.4.jar commons-codec-1.3.jar commons-httpclient-3.1.jar commons-logging-1.1.1.jar httpcore-4.0.jar neethi-3.0.2.jar wsdl4j-1.6.2.jar XmlSchema-1.4.7.jar
シンプルなWebService
よびだし
プロジェクト設計
4 Aメーカーが提供する形式:は直接webServiceを提供し、axis 2.*を参照することができます.または次の省が提供する はwsdlを提供し、axis 1.*を参照できます.
ある省が提供したように
4 Aプラットフォームは以下の応用認証インターフェース(WebService)を提供し、メーカーの呼び出し:住所:http://10.65.4.109:13001/Venus4A/services/Venus4AService(wsdlにアクセスできない)メソッド名:userSecondarySignatureLogin
入力:
名前
説明
を選択します.
長さ(バイト)
resID
リソース番号、4 Aプラットフォームによって定義され、メーカーに知らせる
Int
--
userName
口座番号、すなわち帰属業務システムに用いる個人口座番号
String
16
signature
認証情報(暗号化方式)
String
1024
参照:
名前
説明
を選択します.
長さ(バイト)
result
認証結果とアカウントからの認証結果:0-失敗1-成功
String
1024
result形式リファレンス:
呼び出し方法:
ドッキング4 A
主にログインとログインを実現する必要がある.ログインは基本的にusername=xxx&token=%&*(!@#()@!#&^($!UIHのような検査パラメータ.現存するシステムへの影響が最も小さい場合、最も理想的な方法は、Filterを追加して最初のブロッカー位置で検査を実現することである.大体以下の方法を実現する必要がある:1>汎用検査権、rpc層検査権限、例えば4 Aメーカーから提供された認証方法2>個人化権限制御、例えばip制限3>システムへの登録、loginを実現するセッションがuser情報を追加するとchain.doFilter
2.登録呼び出し4 Aメーカーが提供する登録方法、呼び出しシステム独自の登録方法
axis 1.*
コアjarパッケージ(最小必要):
1.axis.jar 2.jaxrpc.jar 3.commons-logging-${version}.jar 4.commons-discovery-${version}.jar 5.wsdl4j-1.5.1.jar
よびだし
package ic;
import javax.xml.rpc.ParameterMode;
import org.apache.axis.client.Call;
import org.apache.axis.client.Service;
import org.apache.axis.encoding.XMLType;
public class ICServiceTest1 {
public static void main(String[] args) {
try {
String endpoint = "http://localhost:3000/hy/gw/queryConsignOrder?wsdl";
Service service = new Service();
Call call = (Call) service.createCall();
call.setTargetEndpointAddress(endpoint);
// WSDL ( )
call.setOperationName("getLisQueryConsignOrder");
// , , IN( ), OUT( ) or INOUT( )
call.addParameter("icSystem", XMLType.XSD_STRING, ParameterMode.IN);
call.addParameter("companyFlag", XMLType.XSD_STRING, ParameterMode.IN);
call.addParameter("consignOrderNo", XMLType.XSD_STRING, ParameterMode.IN);
call.addParameter("orderNo", XMLType.XSD_STRING, ParameterMode.IN);
//
call.setReturnType(XMLType.XSD_STRING);
//
Object[] paramValues = new Object[] {"4PL","NJHY,NJHF","TC201309172206",""};
// ,
String result = (String) call.invoke(paramValues);
System.out.println("result is " + result);
} catch (Exception e) {
e.printStackTrace();
}
}
}
axis 2.*
コアjarパッケージ:
axiom-api-1.2.15.jar axiom-impl-1.2.15.jar axis2-adb-1.6.4.jar axis2-kernel-1.6.4.jar axis2-transport-http-1.6.4.jar axis2-transport-local-1.6.4.jar commons-codec-1.3.jar commons-httpclient-3.1.jar commons-logging-1.1.1.jar httpcore-4.0.jar neethi-3.0.2.jar wsdl4j-1.6.2.jar XmlSchema-1.4.7.jar
シンプルなWebService
import java.util.Random;
// : package
public class SimpleService {
public String getGreeting(String name){
return "Hello " + name;
}
public int getPrice(){
return new Random().nextInt(100);
}
}
よびだし
public class RPCClient {
public static String address="http://localhost:8080/axis2/services/SimpleService";
public static void main(String[] args) throws IOException{
Object[] result=invoke("getPrice", new Object[]{}, new Class[]{int.class});
System.out.println(result[0]); // 80
result=invoke("getGreeting", new Object[]{"jack"}, new Class[]{String.class});
System.out.println(result[0]); // Hello jack
}
@SuppressWarnings("rawtypes")
public static Object[] invoke(String method,Object[] params,Class[] classes) throws AxisFault{
// RPC WebService
RPCServiceClient client=new RPCServiceClient();
Options option=client.getOptions();
// URL
EndpointReference reference=new EndpointReference(address);
option.setTo(reference);
/*
*
* http://ws.apache.org/axis2 ( package ) ,
* , http://axis2.webservice.elgin.com ,
* method
*
*/
QName qname=new QName("http://ws.apache.org/axis2", method);
// ,
Object[] result=client.invokeBlocking(qname,params,classes);
return result;
}
プロジェクト設計
4 Aメーカーが提供する形式:
ある省が提供したように
4 Aプラットフォームは以下の応用認証インターフェース(WebService)を提供し、メーカーの呼び出し:住所:http://10.65.4.109:13001/Venus4A/services/Venus4AService(wsdlにアクセスできない)メソッド名:userSecondarySignatureLogin
入力:
名前
説明
を選択します.
長さ(バイト)
resID
リソース番号、4 Aプラットフォームによって定義され、メーカーに知らせる
Int
--
userName
口座番号、すなわち帰属業務システムに用いる個人口座番号
String
16
signature
認証情報(暗号化方式)
String
1024
参照:
名前
説明
を選択します.
長さ(バイト)
result
認証結果とアカウントからの認証結果:0-失敗1-成功
String
1024
result形式リファレンス:
Result >
呼び出し方法:
import org.apache.axis.client.Call;
import org.apache.axis.client.Service;
private static String accessServiceFunction(String endpoint,String function,Object[] obj){
Service service = new Service();
Call call;
String rusult = null;
try {
call = (Call) service.createCall();
URL url = new URL(endpoint);
call.setTargetEndpointAddress(url);
call.setOperationName(function);
return (String)call.invoke(obj);
}catch (Exception e1) {
logger.error(" :" + e1.getMessage());
return rusult = null;
}
}
ドッキング4 A
主にログインとログインを実現する必要がある.ログインは基本的にusername=xxx&token=%&*(!@#()@!#&^($!UIHのような検査パラメータ.現存するシステムへの影響が最も小さい場合、最も理想的な方法は、Filterを追加して最初のブロッカー位置で検査を実現することである.大体以下の方法を実現する必要がある:1>汎用検査権、rpc層検査権限、例えば4 Aメーカーから提供された認証方法2>個人化権限制御、例えばip制限3>システムへの登録、loginを実現するセッションがuser情報を追加するとchain.doFilter
2.登録呼び出し4 Aメーカーが提供する登録方法、呼び出しシステム独自の登録方法