array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(3) "428" ["text"]=> string(77) "Visual Studio 2017 单独启动MSDN帮助(Microsoft Help Viewer)的方法" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(8) "DonetRen" ["tagsname"]=> string(55) "Visual Studio 2017|MSDN帮助|C#程序|.NET|Help Viewer" ["tagsid"]=> string(23) "[401,402,403,"300",404]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400964" ["_id"]=> string(3) "428" } [1]=> array(10) { ["id"]=> string(3) "427" ["text"]=> string(42) "npm -v;报错 cannot find module "wrapp"" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "zzty" ["tagsname"]=> string(50) "node.js|npm|cannot find module "wrapp“|node" ["tagsid"]=> string(19) "[398,"239",399,400]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400760" ["_id"]=> string(3) "427" } [2]=> array(10) { ["id"]=> string(3) "426" ["text"]=> string(54) "说说css中pt、px、em、rem都扮演了什么角色" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(12) "zhengqiaoyin" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400640" ["_id"]=> string(3) "426" } [3]=> array(10) { ["id"]=> string(3) "425" ["text"]=> string(83) "深入学习JS执行--创建执行上下文(变量对象,作用域链,this)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "Ry-yuan" ["tagsname"]=> string(33) "Javascript|Javascript执行过程" ["tagsid"]=> string(13) "["169","191"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511399901" ["_id"]=> string(3) "425" } [4]=> array(10) { ["id"]=> string(3) "424" ["text"]=> string(30) "C# 排序技术研究与对比" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "vveiliang" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(8) ".Net Dev" ["catesid"]=> string(5) "[199]" ["createtime"]=> string(10) "1511399150" ["_id"]=> string(3) "424" } [5]=> array(10) { ["id"]=> string(3) "423" ["text"]=> string(72) "【算法】小白的算法笔记:快速排序算法的编码和优化" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "penghuwan" ["tagsname"]=> string(6) "算法" ["tagsid"]=> string(7) "["344"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511398109" ["_id"]=> string(3) "423" } [6]=> array(10) { ["id"]=> string(3) "422" ["text"]=> string(64) "JavaScript数据可视化编程学习(二)Flotr2,雷达图" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "chengxs" ["tagsname"]=> string(28) "数据可视化|前端学习" ["tagsid"]=> string(9) "[396,397]" ["catesname"]=> string(18) "前端基本知识" ["catesid"]=> string(5) "[198]" ["createtime"]=> string(10) "1511397800" ["_id"]=> string(3) "422" } [7]=> array(10) { ["id"]=> string(3) "421" ["text"]=> string(36) "C#表达式目录树(Expression)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "wwym" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1511397474" ["_id"]=> string(3) "421" } [8]=> array(10) { ["id"]=> string(3) "420" ["text"]=> string(47) "数据结构 队列_队列实例:事件处理" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "idreamo" ["tagsname"]=> string(40) "C语言|数据结构|队列|事件处理" ["tagsid"]=> string(23) "["246","247","248",395]" ["catesname"]=> string(12) "数据结构" ["catesid"]=> string(7) "["133"]" ["createtime"]=> string(10) "1511397279" ["_id"]=> string(3) "420" } [9]=> array(10) { ["id"]=> string(3) "419" ["text"]=> string(47) "久等了,博客园官方Android客户端发布" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(3) "cmt" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511396549" ["_id"]=> string(3) "419" } } ["count"]=> int(200) } 222 WebService学习总结(三)--调用第三方提供的webService服务 - 爱码网
maoyali

 

  互联网上面有很多的免费webService服务,我们可以调用这些免费的WebService服务,将一些其他网站的内容信息集成到我们的Web应用中显示,下面就以获取电子邮箱验证和查询火车时刻表天气预报为例进行说明。

一、调用WebService验证 Email 地址是否正确

1.1、找到提供Email验证的Webservice的网络地址

  http://www.webxml.com.cn/WebServices/ValidateEmailWebService.asmx访问如图所示:

找到WebService的wsdl描述,通过URL地址http://www.webxml.com.cn/WebServices/ValidateEmailWebService.asmx?wsdl:如下:

1.2、客户端编码方式访问第三方提供的webService服务

 

1、借助wsimport命令工具自动生成客户端代码

  创建一个测试项目,如下:

 

打开命令行窗口,切换到项目的src目录,执行"wsimport -keep http://www.webxml.com.cn/WebServices/ValidateEmailWebService.asmx?wsdl"生成客户端代码,如下图所示:

生成的代码如下:

借助生成的代码编写请求代码

package cn.com.emailWsClient;

import cn.com.webxml.ValidateEmailWebService;
import cn.com.webxml.ValidateEmailWebServiceSoap;

public class EmailWsClient {
    public static void main(String[] args) {
        //创建ValidateEmailWebService工厂
        ValidateEmailWebService factory = new ValidateEmailWebService();
        //创建ValidateEmailWebServiceSoap对象
        ValidateEmailWebServiceSoap emailInfo = factory.getValidateEmailWebServiceSoap();
        
        String email = "myl@163.com";
        //调用Email验证方法
        //
        /**
         * 输入参数:EmailAddress = Email 地址(默认SMTP端口25)
         * 返回数据: Byte 字节。
         * 返回值: 
         * 0 = 请重新验证;
         * 1 = 邮件地址合法;
         * 2 = 只是域名正确;
         * 3 = 一个未知错误;
         * 4 = 邮件服务器没有找到;
         * 5 = 电子邮件地址错误;
         * 6 = 免费用户验证超过数量(50次/24小时);
         * 7 = 商业用户不能通过验证
         * 
         */
        int emaileResult = emailInfo.validateEmailAddress(email);
        switch (emaileResult) {
        case 0:
            System.out.println("重新验证");
            break;
        case 1:
            System.out.println("邮件地址合法");
            break;
        case 2:
            System.out.println("只是域名正确");
            break;
        case 3:
            System.out.println("一个未知错误");
            break;
        case 4:
            System.out.println("邮件服务器没有找到");
            break;
        case 5:
            System.out.println("电子邮件地址错误");
            break;
        case 6:
            System.out.println("免费用户验证超过数量(50次/24小时)");
            break;
        case 7:
            System.out.println("商业用户不能通过验证");
            break;
        default:
            break;
        }
        
    }
}

测试多个Email地址,返回值

 

 

这样,我们通过生成的Client代码调用了第三方提供的webService服务获取email是否通过验证。

 

二、 调用免费的web service查询国内火车时刻表

2.1、找到提供服务的Webservice的网络地址

http://www.webxml.com.cn/WebServices/TrainTimeWebService.asmx如图所示:

 

 找到WebService的wsdl描述信息,通过URL地址http://www.webxml.com.cn/WebServices/TrainTimeWebService.asmx?wsdl:如下:

 

2.2、编写客户端访问调用WebService服务

1、创建客户端项目(如例1)

2、根据WebService的wsdl描述生成客户端代码

 打开命令行窗口,切换到Phone_Client的src目录,执行wsimport -keep http://www.webxml.com.cn/WebServices/TrainTimeWebService.asmx?wsdl 如下图所示:

 

运行结果显示,使用wsimport工具直接生成客户端代码会抛异常, 无法生成客户端代码, 只是因为我们要调用的WebService是用.net写的,这个是Java调用net的webservice都有的问题,这个问题的解决办法如下:

  1、将对应的wsdl文档保存到本地(Ctrl+s)

    

 

  2、修改wsdl文档的部分内容: <s:element ref="s:schema" /><s:any /> 替换成 <s:any minOccurs="2" maxOccurs="2"/>

  替换成 

 

 

 根据刚刚保存到本地的wsdl文件生成代码,如下图所示:

 

 从执行结果显示,这一次可以正常生成代码了,刷新一下src目录,就可以看到生成的代码了,如下图所示:

 

2、借助生成的代码编写请求代码

package cn.com.TrainTimeClient;

import java.util.Date;
import java.util.List;

import cn.com.webxml.ArrayOfString;
import cn.com.webxml.GetStationNameDataSetResponse.GetStationNameDataSetResult;
import cn.com.webxml.TrainTimeWebService;
import cn.com.webxml.TrainTimeWebServiceSoap;
/**
 * 
 * @author myl
 * @version 2018.4.15
 * 火车时刻表 WEB 服务 (第六次提速最新列车时刻表)
 */
public class TrinTimeClient {

    public static void main(String[] args) {
        //创建TrainTimeWebService工厂
        TrainTimeWebService factory = new TrainTimeWebService();
        //创建TrainTimeWebServiceSoap对象
        TrainTimeWebServiceSoap trainInfo = factory.getTrainTimeWebServiceSoap();
        //获得本火车时刻表Web Services的全部始发站名称
        ArrayOfString trainResult = trainInfo.getStationName();
        List<String> listTrain = trainResult.getString();
        for(String train : listTrain){
            System.out.println(train);
        }
        //获得本火车时刻表Web Services的数据库版本更新时间
        String date = trainInfo.getVersionTime();
        System.out.println(date);
        
        //获得本火车时刻表Web Services支持的全部站台名称和拼音缩写 DataSet
        GetStationNameDataSetResult dataSet = trainInfo.getStationNameDataSet();
        List<Object> listds = dataSet.getAny();
        for(Object ds : listds){
            System.out.println(ds.toString());
        }
    }
}

返回值

这样,我们通过生成的Client代码调用了第三方提供的webService服务获取火车时刻表的一些信息。

三、调用免费的web service获取天气预报信息

3.1、找到提供天气预报信息的Webservice的网络地址

 http://www.webxml.com.cn/WebServices/WeatherWebService.asmx访问结果如下图所示:

找到WebService的wsdl描述,通过URL地址http://www.webxml.com.cn/WebServices/WeatherWebService.asmx?wsdl:如下:

 

3.2、客户端编码方式访问第三方提供的webService服务

  1、借助wsimport命令工具自动生成客户端代码

  创建一个测试项目,如下:

 

打开命令行窗口,切换到项目的src目录,执行"wsimport -keep http://www.webxml.com.cn/WebServices/WeatherWebService.asmx?wsdl"生成客户端代码,如下图所示:

运行结果显示,使用wsimport工具直接生成客户端代码会抛异常, 无法生成客户端代码, 只是因为我们要调用的WebService是用.net写的,这个是Java调用net的webservice都有的问题,这个问题的解决办法如下:

  1、将对应的wsdl文档保存到本地(Ctrl+s)

    

 

 

  2、修改wsdl文档的部分内容: <s:element ref="s:schema" /><s:any /> 替换成 <s:any minOccurs="2" maxOccurs="2"/>

    替换成 

 

根据刚刚保存到本地的wsdl文件生成代码,如下图所示:

 

从执行结果显示,这一次可以正常生成代码了,刷新一下src目录,就可以看到生成的代码了,如下图所示

  

2、借助生成的代码编写客户端请求代码

package cn.com.client;

import java.util.List;
import cn.com.webxml.ArrayOfString;
import cn.com.webxml.WeatherWebService;
import cn.com.webxml.WeatherWebServiceSoap;

/**
 * 
 * @author myl
 * @version 2018.4.15
 *
 */
public class WeatherWSClient {

    public static void main(String[] args) {
        //创建WeatherWebService工厂
        WeatherWebService factory = new WeatherWebService();
        //创建WeatherWebServiceSoap对象
        WeatherWebServiceSoap weatherInfo = factory.getWeatherWebServiceSoap();
        //根据地区获取天气情况
        ArrayOfString weatherResult = weatherInfo.getWeatherbyCityName("北京");
        //ArrayOfString 保存转化为List对象
        List<String> listWeather = weatherResult.getString();
        for(String weather : listWeather){
            System.out.println(weather);
        }
    }

}

返回结果:

 

 这样,我们通过生成的Client代码调用了第三方提供的webService服务获取到了南宁市的天气预报信息。

 

分类:

技术点:

相关文章: