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
よびだし
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メーカーが提供する形式:
  • は直接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形式リファレンス:
    
    
                 
                 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メーカーが提供する登録方法、呼び出しシステム独自の登録方法