第六章 创建 Web Services - 创建一个Web服务

文章目录

第六章 创建 Web Services - 创建一个Web服务

创建一个Web服务

可以通过以下任何一种方式创建web服务:

  • 通过创建新类或编辑现有类来满足本主题前面描述的需求
  • 通过使用Web服务向导
  • 通过使用SOAP向导和现有的WSDL
  • 通过子类化一个或多个web服务

使用Web服务向导

Web服务向导生成一个简单的存根。

  1. 单击File > New。这将显示"新建"对话框。
  2. 单击"General"选项卡。
  3. 单击新建Web服务,然后单击确定。这将显示一个向导。
  4. 为包名、类名和web服务名输入值。这些都是必需的。
  5. 可选地编辑名称空间URI(或稍后更改此初始值)。这是XML名称空间,而不是名称空间。
  6. 可选地在单独的行上键入方法名称列表。
  7. 单击OK

现在,有了一个新的web服务类,其中包含web方法的存根。例如:

java 复制代码
/// MyApp.StockService
Class MyApp.StockService Extends %SOAP.WebService 
{

/// Name of the WebService.
Parameter SERVICENAME = "StockService";

/// TODO: change this to actual SOAP namespace.
/// SOAP Namespace for the WebService
Parameter NAMESPACE = "https://tempuri.org";

/// Namespaces of referenced classes will be used in the WSDL.
Parameter USECLASSNAMESPACES = 1;

/// TODO: add arguments and implementation.
/// Forecast
Method Forecast() As %String [ WebMethod ]
{
   ;Quit "Forecast"
}

}

对现有WSDL使用SOAP向导

在某些情况下,WSDL已经设计好了,有必要创建与WSDL匹配的web服务;这就是所谓的wsdl优先开发。在 IRIS中,这个开发有三个步骤:

  1. 使用SOAP向导读取WSDL并生成web服务和所有支持类。

此向导还可以生成web客户端类(这是更常见的)。

有关使用此向导的信息,请参见使用SOAP向导。按照该部分中描述的步骤操作,并在向导中选择Create Web Service选项。

或者类中使用 %SOAP.WSDL.Reader,如使用 %SOAP.WSDL.Reader 类中所述。

  1. 检查生成的类,看看是否需要更改方法签名中的任何 %String值。

当向导读取 WSDL 时,它假定任何字符串类型输入或输出都可以在中表示为中的 %String,但这并不总是正确的。在极少数情况下,某些字符串可能会超出最大长度字符串限制。

  1. 编辑生成的 Web 服务中的方法,以便它们执行所需的操作。

每个方法最初都是一个存根,如下例所示:

java 复制代码
Method Add(a As Test.ns2.ComplexNumber, b As Test.ns2.ComplexNumber) As Test.ns2.ComplexNumber 
[ Final, SoapAction = "https://www.mynamespace.org/GSOAP.AddComplexWS.Add", 
SoapBindingStyle = document, SoapBodyUse = literal, WebMethod ]
{
 // Web Service Method Implementation Goes Here.
}

该向导包括编译器关键字,例如 FinalSoapBindingStyle。不应更改这些关键字的值。

如果 WSDL 包含 WS-Policy 元素,则向导还会生成 Web 服务的配置类。默认配置类名称是 Web 服务名称,后面附加 Config。有关 WS-Policy 的信息,请参阅保护 Web 服务。

对现有 Web 服务进行子类化

可以通过创建现有 Web 服务类的子类,然后将 SOAPMETHODINHERITANCE 参数添加到您的类来创建 Web 服务,如下所示:

java 复制代码
PARAMETER SOAPMETHODINHERITANCE = 1;

**此参数的默认值为 0。如果此参数为 0,则类不会将 Web 方法继承为 Web 方法。也就是说,这些方法可作为普通方法使用,但不能作为子类定义的 Web 服务内的 Web 方法进行访问。

**

如果将此参数设置为 1,则类可以使用任何 Web 服务超类中定义的 Web 方法。

相关推荐
小程故事多_8018 小时前
破局 LLM 黑盒困局,Phoenix 凭全链路可观测,重构大模型应用工程化落地规则
java·前端·人工智能·重构·aigc
紫微AI19 小时前
WebMCP:开启 Agentic Web 新时代——Chrome 新 API 的特性与前瞻
前端·chrome
Albert Edison1 天前
【Python】学生管理系统
开发语言·数据库·python
追随者永远是胜利者1 天前
(LeetCode-Hot100)253. 会议室 II
java·算法·leetcode·go
追随者永远是胜利者1 天前
(LeetCode-Hot100)207. 课程表
java·算法·leetcode·go
恋猫de小郭1 天前
AGENTS.md 真的对 AI Coding 有用吗?或许在此之前你没用对?
前端·人工智能·ai编程
heimeiyingwang1 天前
企业供应链 AI 优化:需求预测与智能调度
大数据·数据库·人工智能·机器学习
yanghuashuiyue1 天前
lambda+sealed+record
java·开发语言
山岚的运维笔记1 天前
SQL Server笔记 -- 第73章:排序/对行进行排序
数据库·笔记·后端·sql·microsoft·sqlserver
sunny_1 天前
构建工具的第三次革命:从 Rollup 到 Rust Bundler,我是如何设计 robuild 的
前端·rust·前端工程化