Ruby Web Services 应用 - SOAP4R

  什么是 SOAP?

  简单对象访问协议(SOAP,全写为Simple Object Access Protocol)是交换数据的一种协议规范。

  SOAP 是一种简单的基于 XML 的协议,它使应用程序通过 HTTP 来交换信息。

  简单对象访问协议是交换数据的一种协议规范,是一种轻量的、简单的、基于XML(标准通用标记语言下的一个子集)的协议,它被设计成在WEB上交换结构化的和固化的信息。

  更多 SOAP 教程请查看:http://www.w3cschool.cc/soap/soap-tutorial.html。

  SOAP4R 安装

  SOAP4R 由Hiroshi Nakamura开发实现,用于 Ruby 的 SOAP 应用。

  SOAP4R 下载地址:http://raa.ruby-lang.org/project/soap4r/。

  注意:你的ruby环境可能已经安装了该该组件。

  Linux 环境下你也可以使用 gem 来安装该组件,命令如下:

  $ gem install soap4r --include-dependencies

  如果你是window环境下开发,你需要下载zip压缩文件,并通过执行 install.rb 来安装。

  SOAP4R 服务

  SOAP4R 支持两种不同的服务类型:

  基于 CGI/FastCGI 服务 (SOAP::RPC::CGIStub)

  独立服务 (SOAP::RPC:StandaloneServer)

  本教程将为大家介绍如何建立独立的 SOAP 服务。步骤如下:

  第1步 - 继承SOAP::RPC::StandaloneServer

  为了实现自己的独立的服务器,你需要编写一个新的类,该类为 SOAP::RPC::StandaloneServer 的子类:

  class MyServer < SOAP::RPC::StandaloneServer

  ...............

  end

  注意:如果你要编写一个基于FastCGI的服务器,那么你需要继承 SOAP::RPC::CGIStub 类,程序的其余部分将保持不变。

  第二步 - 定义处理方法

  接下来我们定义Web Services的方法,如下我们定义两个方法,一个是两个数相加,一个是两个数相除:

  class MyServer < SOAP::RPC::StandaloneServer

  ...............

  # 处理方法

  def add(a, b)

  return a + b

  end

  def div(a, b)

  return a / b

  end

  end

  第三步 - 公布处理方法

  接下来添加我们在服务器上定义的方法,initialize方法是公开的,用于外部的连接:

  class MyServer < SOAP::RPC::StandaloneServer

  def initialize(*args)

  add_method(receiver, methodName, *paramArg)

  end

  end

  以下是各参数的说明:

  参数描述

  receiver包含方法名的方法的对象。 如果你在同一个类中定义服务方法,该参数为 self。

  methodName调用 RPC 请求的方法名。

  paramArg参数名和参数模式

  为了理解 inout 和 out 参数,考虑以下服务方法,需要输入两个参数:inParam 和 inoutParam,函数执行完成后返回三个值:retVal、inoutParam 、outParam:

  def aMeth(inParam, inoutParam)

  retVal = inParam + inoutParam

  outParam = inParam . inoutParam

  inoutParam = inParam * inoutParam

  return retVal, inoutParam, outParam

  end

  公开的调用方法如下:

  add_method(self, 'aMeth', [

  %w(in inParam),

  %w(inout inoutParam),

  %w(out outParam),

  %w(retval return)

  ])

  第四步 - 开启服务

  最后我们通过实例化派生类,并调用 start 方法来启动服务:

  myServer = MyServer.new('ServerName',

  'urn:ruby:ServiceName', hostname, port)

  myServer.start

  以下是请求参数的说明:

  参数描述

  ServerName服务名,你可以取你喜欢的

  urn:ruby:ServiceNameHere urn:ruby 是固定的,但是你可以为你的服务取一个唯一的 ServiceName

  hostname指定主机名

  portweb 服务端口

  实例

  接下来我们通过以上的步骤,创建一个独立的服务:

  require "soap/rpc/standaloneserver"

  begin

  class MyServer < SOAP::RPC::StandaloneServer

  # Expose our services

  def initialize(*args)

  add_method(self, 'add', 'a', 'b')

  add_method(self, 'div', 'a', 'b')

  end

  # Handler methods

  def add(a, b)

  return a + b

  end

  def div(a, b)

  return a / b

  end

  end

  server = MyServer.new("MyServer",

  'urn:ruby:calculation', 'localhost', 8080)

  trap('INT){

  server.shutdown

  }

  server.start

  rescue => err

  puts err.message

  end

  执行以上程序后,就启动了一个监听 8080 端口的本地服务,并公开两个方法:add 和 div。

  你可以再后台执行以上服务:

  $ ruby MyServer.rb&

  SOAP4R 客户端

  ruby 中使用 SOAP::RPC::Driver 类开发 SOAP 客户端。接下来我们来详细看下 SOAP::RPC::Driver 类的使用。

  调用 SOAP 服务需要以下信息:

  SOAP 服务 URL 地址 (SOAP Endpoint URL)

  服务方法的命名空间(Method Namespace URI)

  服务方法名及参数信息

  接下来我们就一步步来创建 SOAP 客户端来调用以上的 SOAP 方法:add 、 div:

  第一步 - 创建 SOAP Driver 实例

  我们可以通过实例化 SOAP::RPC::Driver 类来调用它的新方法,如下所示:

  SOAP::RPC::Driver.new(endPoint, nameSpace, soapAction)

  以下是参数的描述:

  参数描述

  endPoint连接 SOAP 服务的 URL 地址

  nameSpace命名空间用于 SOAP::RPC::Driver 对象的所有 RPC .

  soapAction用于 HTTP 头部的 SOAPAction 字段值。如果是字符串是"" 则默认为 nil

  第二步 - 添加服务方法

  为 SOAP::RPC::Driver 添加 SOAP 服务方法,我们可以通过实例 SOAP::RPC::Driver 来调用以下方法:

  driver.add_method(name, *paramArg)

  以下是参数的说明:

  参数描述

  name远程web服务的方法名

  paramArg指定远程程序的参数

  第三步 - 调用SOAP服务

  最后我们可以使用 SOAP::RPC::Driver 实例来调用 SOAP 服务:

  result = driver.serviceMethod(paramArg...)

  serviceMethod SOAP服务的实际方法名,paramArg为方法的参数列表。

  实例

  基于以上的步骤,我们可以编写以下的 SOAP 客户端:

  #!/usr/bin/ruby -w

  require 'soap/rpc/driver'

  NAMESPACE = 'urn:ruby:calculation'

  URL = 'http://localhost:8080/'

  begin

  driver = SOAP::RPC::Driver.new(URL, NAMESPACE)

  # Add remote sevice methods

  driver.add_method('add', 'a', 'b')

  # Call remote service methods

  puts driver.add(20, 30)

  rescue => err

  puts err.message

  end

  以上我们只是简单介绍 Ruby 的 Web Services 。 (编辑:雷林鹏 来源:网络)

雷林鹏分享:Ruby Web Services 应用 - SOAP4R的更多相关文章

  1. 雷林鹏分享:Ruby 循环

    Ruby 循环 Ruby 中的循环用于执行相同的代码块若干次.本章节将详细介绍 Ruby 支持的所有循环语句. Ruby while 语句 语法 while conditional [do] code ...

  2. 老李分享:Web Services 组件 1

    老李分享:Web Services 组件   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:9 ...

  3. 老李分享:Web Services 特性 1

    老李分享:Web Services 特性   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:9 ...

  4. 老李分享:Web Services 架构 1

    老李分享:Web Services 架构   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:9 ...

  5. 雷林鹏分享:Ruby CGI 编程

    Ruby CGI 编程 Ruby 是一门通用的语言,不仅仅是一门应用于WEB开发的语言,但 Ruby 在WEB应用及WEB工具中的开发是最常见的. 使用Ruby您不仅可以编写自己的SMTP服务器,FT ...

  6. 雷林鹏分享:Ruby Socket 编程

    Ruby Socket 编程 Ruby提供了两个级别访问网络的服务,在底层你可以访问操作系统,它可以让你实现客户端和服务器为面向连接和无连接协议的基本套接字支持. Ruby 统一支持应用程的网络协议, ...

  7. 雷林鹏分享:Ruby 安装 - Windows

    Ruby 安装 - Windows 下面列出了在 Windows 机器上安装 Ruby 的步骤. 注意:在安装时,您可能有不同的可用版本. 下载最新版的 Ruby 压缩文件.请点击这里下载. 下载 R ...

  8. 雷林鹏分享:Ruby 安装 - Unix

    Ruby 安装 - Unix 下面列出了在 Unix 机器上安装 Ruby 的步骤. 注意:在安装之前,请确保您有 root 权限. 下载最新版的 Ruby 压缩文件.请点击这里下载. 下载 Ruby ...

  9. 雷林鹏分享:Ruby 命令行选项

    Ruby 命令行选项 Ruby 一般是从命令行运行,方式如下: $ ruby [ options ] [.] [ programfile ] [ arguments ... ] 解释器可以通过下列选项 ...

随机推荐

  1. Linux系统下Redis缓存安装配置

    Redis是一个高性能的key-value数据库,现时越来越多企业与应用使用Redis作为缓存服务器.楼主是一枚JAVA后端程序员,也算是半个运维工程师了.在Linux服务器上搭建Redis,怎么可以 ...

  2. mysql 选择优化的数据类型

    选择最小的数据类型,因为它们占更少的磁盘,内存和CPU缓存: 选择简单的数据类型,如用整型来存储ip: http://blog.csdn.net/lyd518/article/details/2070 ...

  3. 170623、springboot编程之JdbcTemplate操作数据库

    使用JdbcTemplate操作mysql数据库! 1.在pom中引入jpa包 <dependency> <groupId>org.springframework.boot&l ...

  4. 使用webmagic搭建一个简单的爬虫

    刚刚接触爬虫,听说webmagic很不错,于是就了解了一下. webmagic的是一个无须配置.便于二次开发的爬虫框架,它提供简单灵活的API,只需少量代码即可实现一个爬虫. 这句话说的真的一点都不假 ...

  5. python基础之协程函数、列表表达式、生成器表达式

    一.协程函数 协程函数的定义?如果在一个函数内部yield的使用方式是表达式形式的话,如x=yield,那么该函数称为协程函数 协程函数补充: def init(func): def wrapper( ...

  6. What Powers Instagram: Hundreds of Instances, Dozens of Technologies(译文,转)

    add by zhj: 对译文略有修改.原文发表时,Instagram还没被Facebook收购,读完只感觉Instagram这三个后台工程师真牛逼. 三个人就可以搞定1400万注册用户.不过,另一方 ...

  7. 【JEECG技术博文】JEECG表单配置-树形表单

    表单配置支持树型表单了,详细效果例如以下图:

  8. xutil3 post 和 get请求

    https://i.cnblogs.com/EditPosts.aspx?postid=7001253 compile 'org.xutils:xutils:3.3.36' 注册xutil3 < ...

  9. EOS token 代币兑换的资料

    eos token 兑换价格预估查询:   https://eosscan.io/ https://steemit.com/eos/@sandwich/how-to-check-which-eos-p ...

  10. centos7.3下ScyllaDB1.6安装

    转自:http://10710016.blog.51cto.com/10700016/1900483 ScyllaDB 安装配置 1.说明: scylladb支持centos7.2 64位 及以上版本 ...