zoukankan      html  css  js  c++  java
  • Spring Remoting: HTTP Invoker--转

    原文地址:http://www.studytrails.com/frameworks/spring/spring-remoting-http-invoker.jsp

    Concept Overview

    In the earlier articles we saw an introduction to spring remoting and its support for RMIHessian and Burlap. In this tutorial we look at one more support for remoting - HttpInvoker. HttpInvoker combines the ease of Hessian and Burlap, in that it is very easy to set up. It serializes and deserializes java object for trasport over the network. However, probably the only drawback is that Http Invoker is bound to java and hence the clients all need to be java based. This is the recommended choice for remoting for java-java based communication. The main classes are :org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter - This is a servlet API based Http request handler. It is used to export the remote services. It takes in a service property that is the service to be exported and aServiceInterface that specifies the interface that the service is tied to. 
    org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean - This is a proxy factory for creating http invoker proxies. It has a serviceUrl property that must be an http url exposing an http invoker service. This class serializes the objects that are sent to remote services and deserializes the objects back.

    Sample Program Overview




    Required Libraries
    • aopalliance.jar
    • commons-logging.jar
    • log4j.jar
    • org.springframework.aop.jar
    • org.springframework.asm.jar
    • org.springframework.beans.jar
    • org.springframework.context.jar
    • org.springframework.context.support.jar
    • org.springframework.core.jar
    • org.springframework.expression.jar
    • org.springframework.web.jar
    • org.springframework.web.servlet.jar






    Interaction Flow


    • Client sends a message call
    • This message call is handled by a HTTP Proxy created by HttpInvokerProxyFactoryBean
    • The HTTP Proxy converts the call into a remote call over HTTP
    • The HTTP Service Adapter created by HttpInvokerServiceExporter intercepts the remote call over HTTP
    • It forwards the method call to Service




    Http Invoker Server Code Package Structure




    Http Invoker Server Source Code




    Create the GreetingService interface as shown below. 
    Create a method named getGreeting() that takes a name as a parameter and returns the greeting message (see line 5 below).

    GreetingService.java
    1
    2
    3
    4
    5
    6
    package com.studytrails.tutorials.springremotinghttpinvokerserver;
     
    public interface GreetingService {
     
    String getGreeting(String name);
    }




    Create a class GreetingServiceImpl as shown below. 
    It implements the GreetingService interface (described earlier) 
    Implement the getGreeting() method by sending a greeting message (see lines 6-8 below).

    GreetingServiceImpl.java
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    package com.studytrails.tutorials.springremotinghttpinvokerserver;
     
    public class GreetingServiceImpl implements GreetingService{
     
    @Override
    public String getGreeting(String name) {
    return "Hello " + name + "!";
    }
     
    }




    Create the httpinvoker-servlet.xml file (see below). 

    Declare the 'greetingService' (see lines 14-15 below). 

    Export the 'greetingService' using Spring's HttpInvokerServiceExporter class (see lines 17-21 below). 
    Note the following properties of HttpInvokerServiceExporter class:

    • service: the service class bean which shall handle the HTTP call (see line 19 below)
    • serviceInterface: The interface to be used by Spring to create proxies for HTTP (see line 20 below)
    httpinvoker-servlet.xml
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    <?xml version="1.0" encoding="UTF-8" ?>
     
     
     
    <bean id="greetingService"
    class="com.studytrails.tutorials.springremotinghttpinvokerserver.GreetingServiceImpl" />
     
    <bean name="/greetingService.http"
    class="org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter">
    <property name="service" ref="greetingService" />
    <property name="serviceInterface" value="com.studytrails.tutorials.springremotinghttpinvokerserver.GreetingService"/>
    </bean>
    </beans>




    Create the web.xml file (see below). 

    Create the servlet mapping for the url pattern '*.http' (see line 16 below) for Spring's DispatcherServlet (see line 10 below) 

    web.xml
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    <!DOCTYPE web-app PUBLIC
    "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
     
    <web-app>
    <display-name>Spring Remoting: Http Invoker Server</display-name>
    <servlet>
    <servlet-name>httpinvoker</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
    </servlet>
     
    <servlet-mapping>
    <servlet-name>httpinvoker</servlet-name>
    <url-pattern>*.http</url-pattern>
    </servlet-mapping>
    </web-app>





    Http Invoker Client Code Package Structure







    Http Invoker Client Source Code




    Create the GreetingService interface as shown below. 
    Copy the GreetingService interface created for Http Invoker Server (described above) and paste it in Http Invoker Client source code while retaining the java package structure. 

    Note: For reference, the source code is shown below. 

    GreetingService.java
    1
    2
    3
    4
    5
    6
    package com.studytrails.tutorials.springremotinghttpinvokerserver;
     
    public interface GreetingService {
     
    String getGreeting(String name);
    }






    Create a class TestSpringRemotingHttpInvoker shown below to test Spring Http Invoker Remoting. 
    Load spring configuration file (see line 11 below) 
    Get a reference to GreetingService using the bean name 'greetingService' (see line 12 below) 
    Call the GreetingService.getGreting() method by passing the name 'Alpha' (see line 13 below) 
    Print the greeting message (see line 14 below).

    TestSpringRemotingHttpInvoker.java
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    package com.studytrails.tutorials.springremotinghttpinvokerclient;
     
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
     
    import com.studytrails.tutorials.springremotinghttpinvokerserver.GreetingService;
     
    public class TestSpringRemotingHttpInvoker {
     
    public static void main(String[] args) {
    ApplicationContext context = new ClassPathXmlApplicationContext("spring-config-client.xml");
    GreetingService greetingService = (GreetingService)context.getBean("greetingService");
    String greetingMessage = greetingService.getGreeting("Alpha");
    System.out.println("The greeting message is : " + greetingMessage);
    }
    }





    Create the spring-config-client.xml file (see below). 
    Declare the 'greetingService' using Spring's HttpInvokerProxyFactoryBean class (see lines 13-16 below). 
    Note the following properties of HttpInvokerProxyFactoryBean class:

    • serviceUrl : refers the URL of the remote service (see line 14 below). 
      Note URL part 'greetingService.http' corresponds to bean name property of HttpInvokerServiceExporter bean defined in httpinvoker-servlet.xml (defined earlier)
    • serviceInterface: The interface to be used by Spring to create proxies for Http Invoker (see line 15 below)
    spring-config-client.xml
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    <?xml version="1.0" encoding="UTF-8"?>
    xsi:schemaLocation="
     
    <bean id="greetingService" class="org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean">
    <property name="serviceInterface" value="com.studytrails.tutorials.springremotinghttpinvokerserver.GreetingService"/>
    </bean>
     
    </beans>



    Running Sample Program





    Http Invoker Server Sample Program

    This sample program has been packaged as a jar installer which will copy the source code (along with all necessary dependencies)on your machine and automatically run the program for you as shown in the steps below. To run the sampleprogram, you only need Java Runtime Environment (JRE) on your machine and nothing else. 

    Download And Automatically Run Http Invoker Server Sample Program



    • Save the springremotinghttpinvokerserver-installer.jar on your machine
    • Execute/Run the jar using Java Runtime Environment


    (Alternatively you can go the folder containing the springremotinghttpinvokerserver-installer.jar and execute the jar using java -jar springremotinghttpinvokerserver-installer.jarcommand) 




    • You will see a wizard page as shown below



    • Enter the location of the directory where you want the program to install and run (say, C:Temp)



    • The installer will copy the program on your machine and automatically execute it. The expected output indicating that the program has run successfully on your machine is shown in the image below. 
      This shows that the Http Invoker Server program has run successfully on your machine








    Http Invoker Client Sample Program

    This sample program has been packaged as a jar installer which will copy the source code (along with all necessary dependencies)on your machine and automatically run the program for you as shown in the steps below. To run the sampleprogram, you only need Java Runtime Environment (JRE) on your machine and nothing else. 

    Download And Automatically Run Http Invoker Client Sample Program



    • Save the springremotinghttpinvokerclient-installer.jar on your machine
    • Execute/Run the jar using Java Runtime Environment


    (Alternatively you can go the folder containing the springremotinghttpinvokerclient-installer.jar and execute the jar using java -jar springremotinghclient-installer.jar command) 




    • You will see a wizard page as shown below



    • Enter the location of the directory where you want the program to install and run (say, C:Temp)

     

    • The installer will copy the program on your machine and automatically execute it. The expected output indicating that the program has run successfully on your machine is shown in the image below. 
      This shows that the Http Invoker Client program has run successfully on your machine






    Browsing the Program



    Http Invoker Server Sample Code

    This source code for this program is downloaded in the folder specified by you (say, C:Temp) as an eclipse project called springremotinghttpinvokerserver . All the required libraries have also been downloaded and placed in the same location. You can open this project from Eclipe IDE and directly browse the source code. See below for details of the project structure.





    Redeploying this sample program in a different web server

    The WAR file for this example is available as springremotinghttpinvokerserver.war in the download folder specified by you earlier (e.g. C:Temp). The path for the WAR file is <DOWNLOAD_FOLDER_PATH>/springremotinghttpinvokerserver/dist/springremotinghttpinvokerserver.war. 
    This WAR file can be deployed in any webserver of your choice and example can be executed. 




    Http Invoker Client Sample Code

    This source code for this program is downloaded in the folder specified by you (say, C:Temp) as an eclipse project called springremotinghttpinvokerclient . All the required libraries have also been downloaded and placed in the same location. You can open this project from Eclipe IDE and directly browse the source code. See below for details of the project structure.

  • 相关阅读:
    事务一致性
    面试汇总
    什么是时间复杂度?
    语言为什么都要实例化后才能用 ?实例化后这里东西是放在堆里面还是栈里面?
    LRU 算法——简单的淘汰算法
    Redis为什么可以做到10万的QPS?
    Redis基础
    Redis基于Set如何实现用户关注模型?
    资深技术Leader曹乐:如何成为技术大牛
    对MySQL查询结果进行替换
  • 原文地址:https://www.cnblogs.com/davidwang456/p/5480845.html
Copyright © 2011-2022 走看看