• WebService学习笔记系列(四)


    今天主要来看看服务端的编写及发布。
    服务端的编写主要包括三个步骤:
    1.编写一个接口,即SEI(server endpoint interface)
    2.编写接口的实现类,即SIB (server implements bean)
    3.发布服务

    在接口和实现类上都要用注解说明情况。

    接口

    @WebService
    public interface IMyServer {
    
        public int add(int a,int b);
        public int minus(int a,int b);
    }

    实现类:

    @WebService(endpointInterface="server.lenve.IMyServer")
    public class MyServerImpl implements IMyServer {
    
        @Override
        public int add(int a, int b) {
            System.out.println(a+"+"+b+"="+(a+b));
            return a+b;
        }
    
        @Override
        public int minus(int a, int b) {
            System.out.println(a+"-"+b+"="+(a-b));
            return a-b;
        }
    
    }

    发布:

    public class PublishMyServer {
    
        public static void main(String[] args) {
            String address = "http://localhost:9999/ns";
            Endpoint.publish(address, new MyServerImpl());
        }
    }

    通过wsimport拿到相关类,
    这里写图片描述

    将这些类拷贝到客户端,然后在客户端调用:
    这里写图片描述

    客户端调用:

    public class MyFirstClient {
    
        public static void main(String[] args) {
                IMyServer myServerImpl = new MyServerImplService()
                        .getMyServerImplPort();
                System.out.println(myServerImpl.add(3, 4)+"------");
        }
    
    }

    当我们把网上的东西导成Java文件后,有些参数变得不是那么讨人喜欢,比如,所有函数的参数命名均为arg0,arg1….,这样让我们很难识别,该怎么办呢?
    那就是在服务端的接口中来做一个简单处理:
    在每个参数前加上@WebParam注解,我们再尝试在方法前加上@WebResult注解,看代码:

    @WebService
    public interface IMyServer {
    
        @WebResult(name="addResult")
        public int add(@WebParam(name="a")int a,@WebParam(name="b")int b);
        public int minus(int a,int b);
    }
    

    add方法添加了注解,minus方法没有添加注解,我们看看生成的代码有什么不同?

    这里写图片描述

    这里写图片描述

    参数名变了吧?再看看返回有什么不同:

    这里写图片描述

    这里写图片描述

  • 相关阅读:
    九省联考2018 解题报告
    「PKUSC2018」最大前缀和(状压dp)
    「雅礼集训 2017 Day2」解题报告
    UVA10829 L-Gap Substrings(后缀数组+ST表)
    [BZOJ2738]矩阵乘法(整体二分+二维树状数组)
    「雅礼集训 2017 Day1」 解题报告
    LeetCode 190. Reverse Bits (算32次即可)
    LeetCode 437. Path Sum III (STL map前缀和)
    LeetCode 744. Find Smallest Letter Greater Than Target (时间复杂度O(n))
    LeetCode 1. Two Sum (c++ stl map)
  • 原文地址:https://www.cnblogs.com/lenve/p/4517990.html
Copyright © 2020-2023  润新知