按照下列步骤创建、发布一个LabVIEW Web服务,并在LabVIEW Web服务和Web客户端(以Web浏览器为例)之间交换数据。

注: 关于本主题中其他概念的详细信息,请参考Web服务介绍。LabVIEW Web服务仅在LabVIEW完整版开发系统和LabVIEW专业版开发系统中可用。

教程包括下列内容:

  1. 创建Web服务
  2. 测试和调试Web服务
  3. 配置客户端访问Web服务的方式
  4. 发布Web服务至应用程序Web服务器
  5. 从客户端访问Web服务
  6. 监控Web服务

创建Web服务

在LabVIEW项目中开发Web服务,组合并配置构成Web服务的VI和其他文件。按照下列步骤创建一个Web服务项目和两个HTTP方法VI。

  1. 创建一个组织Web服务文件的LabVIEW项目。将项目保存为Tutorial.lvproj
  2. 右键单击我的电脑并选择新建»Web服务。LabVIEW在该终端下添加一个Web服务项目项和文件夹。
    注:
    • 在本教程中,您将创建一个Web服务,并将服务发布至主机。在LabVIEW项目的RT终端下创建一个Web服务项目,可把Web服务发布至RT终端。
    • (Windows) NI建议您在Windows操作系统上使用NI Web服务器托管Web服务。详细信息请参考教程:创建LabVIEW Web服务并将其发布到NI Web服务器
  3. 右键单击Web服务项目项并选择重命名,将Web服务命名为TutorialService。项目显示为:

  4. 右键单击Web资源并选择新建VI,新建一个HTTP方法VI,该VI从客户端接收HTTP请求并将数据返回客户端。LabVIEW从模板打开一个新的VI。
    注: 默认状态下,HTTP方法VI通过连线板向客户端返回数据。在该教程中,HTTP方法VI返回默认的JSON格式文本。创建本教程未涵盖的HTTP方法VI时,也可以自定义格式(例如,自定义HTML页或图像数据)返回数据流至客户端,而不是通过连线板返回数据。。在Web服务属性对话框的HTTP方法VI设置页配置输出的格式。
  5. 在该新VI中,创建如下所示的程序框图、前面板和连线板。
    程序框图前面板连线板
    将该VI作为Web服务的一部分发布时,Web客户端可发送HTTP请求调用该VI。调用时,VI执行下列操作:
    • 接收来自客户端HTTP请求分配给连线板的任何控件的值(不包括LabVIEW Web服务请求)。LabVIEW Web服务请求相当于引用句柄,用于识别当前的HTTP请求。
    • 计算ab的和。
    • 通过分配给连线板的c显示控件返回这些值的和。
    • 执行“读取请求变量”VI并返回客户端在当前HTTP请求中包含的查询字符串,该字符串由LabVIEW Web服务请求识别。
      提示 更为复杂的Web服务可能需要使用Web服务选板上的其他VI以启用某些功能,例如,HTTP会话、身份验证、HTTP头和cookie等。
  6. 注意每个输入控件和显示控件均显示在连线板上。默认接线端输出类型中,只有通过分配给HTTP方法VI连线板的输入和输出,Web服务才能从客户端接收数据或将数据发送至客户端。
    提示 为每个对象分配可识别的名称。因为这些名称将成为Web客户端使用的URL的一部分,用来与VI交换数据。
  7. 将VI保存为Add.vi
  8. 在弹出的对话框中选择文件»另存为,然后选择副本»另外打开副本。确保勾选添加副本至Tutorial.lvproj复选框,然后单击继续
  9. 将新副本保存为Subtract.vi
  10. 打开Subtract.vi的程序框图,并将“加”函数替换为“减”函数。重新连线输入控件和显示控件。
  11. 返回项目,右键单击Web资源并选择新建Web资源。重命名新建项目项为AdditionalOperations
  12. 拖曳Subtract.viAdditionalOperations项目项下。保存项目,项目应显示如下图。

注意项目目录树中的下列功能:

  • LabVIEW向每个HTTP方法VI追加HTTP请求类型,默认值为GET。可对客户端发送至特定HTTP方法VI的HTTP请求类型进行修改,教程后续章节有详细说明。
  • Web服务项目项还包含启动VI文件夹。本教程未使用启动VI,但后续章节对启动VI做了详细说明。

相关信息

Web服务的构成

指定接线端的输入控件和显示控件

开发HTTP方法VI:选择输出数据的格式

配置HTTP头、数据流和缓冲

在LabVIEW中管理项目

测试和调试Web服务

发布Web服务至终端前,需要测试HTTP方法VI是否按照预期与客户端进行通信。可直接从LabVIEW项目将Web服务置于调试服务器上,从而允许客户端发送请求至HTTP方法VI。调试服务器提供类似沙盒的环境。

  1. (Windows)右键单击我的电脑下的Web服务项目项,选择应用程序Web服务器»开始(调试服务器)。(Real-Time)右键单击RT终端下的Web服务项目项,选择开始(调试服务器)
  2. 打开Add.vi。注意运行按钮表示VI保留为执行,因为LabVIEW加载Web服务,使其可在调试服务器上与客户端通信。
  3. 关闭Add.vi
  4. 按照下列步骤,获取客户端调用Add.vi使用的URL:
    1. 右键单击Add.vi并选择显示方法URL,显示HTTP方法URL对话框。
    2. 可用服务器下拉菜单中,选择包含本地调试的项,然后单击复制URL按钮。如将服务发布至Web服务器,客户端必须通过其他端口与调试服务器上的Web服务进行通信。
    3. 关闭对话框。
      注:HTTP方法URL对话框打开,则Web服务不响应客户端的任何请求。
  5. 将复制得到的URL在浏览器中打开,用实际值替换{值}变量。例如,http://127.0.0.1:8001/TutorialService/Add?b=2&a=3
  6. 浏览URL。Add.vi接收到浏览器的HTTP请求,计算ab的值,并返回响应,包括分配给Add.vi连线板每个显示控件的名称和输出值。本教程中的响应格式为JSON字符串,即接线端的默认输出格式。注意Add.vi有两个分配至连线板的显示控件:c。HTTP方法VI在响应中返回这两个值。

    {"c":5,"value":"b=2&a=3"}

    注: 如发现非预期行为,必须停止调试会话才可编辑Web服务文件,因为LabVIEW为执行保留文件时无法对其进行编辑。
  7. Subtract.vi上重复执行第4、5步。也可直接更改第5步中的URL,获得Subtract.vi唯一对应的URL映射:http://127.0.0.1:8001/TutorialService/AdditionalOperations/Subtract?b=2&a=3
  8. Subtract.vi重复第6步。
  9. (Windows)右键单击Web服务项目项并选择应用程序Web服务器»停止(调试服务器)。(Real-Time)右键单击Web服务项目项并选择停止(调试服务器)

相关信息

测试和调试应用程序Web服务器上的Web服务

配置客户端访问Web服务的方式

Web客户端通过URL与HTTP方法VI交换数据。后续教程中,将在Web浏览器中输入特定的URL,直接发送数据至HTTP方法VI连线板上的输入控件。

根据下列步骤,定义客户端可用于方法HTTP方法VI的URL:

  1. 右键单击Web服务项目项并选择属性,显示Web服务属性对话框。
  2. HTTP方法VI设置页,注意LabVIEW项目中Web资源文件夹的HTTP方法VI出现在Web服务VI表格中。同时,与Add.vi相比,注意在AdditionalOperations项目项中放置Subtract.vi的方式如何影响URL映射。
  3. 在表格中选择Subtract.vi,注意页面底部URL映射选项卡的下列功能:
    • 可在方法下拉菜单中改变HTTP请求的类型。设置Subtract.vi为默认值GET。
    • 可选择禁用LabVIEW用于映射URL至VI的标准格式,自定义显示在服务名称后的URL部分。本教程使用标准URL映射并包含VI名称。
    • URL栏显示了LabVIEW为HTTP方法VI创建的基本URL。例如,LabVIEW为Subtract.vi创建的默认URL映射为/AdditionalOperations/Subtract。

    注: 在更为复杂的Web服务中,可能需要使用该页的其他选项卡配置VI返回输出数据至Web客户端的格式,以及权限等安全设置。
  4. 单击确定,关闭Web服务属性对话框。
  5. 保存Tutorial.lvproj

相关信息

理解Web服务中的URL映射和查询字符串

发布Web服务至应用程序Web服务器

可将创建的Web服务发布至应用程序Web服务器。在该教程中,您将发布一个独立的Web服务。在更为复杂的应用中,可能需要通过LabVIEW独立应用程序或安装程序发布Web服务。应用程序Web服务器托管Web服务,并提供多种措施以保证网络数据交换的安全性,包括SSL加密。

注: (Windows)也可将Web服务发布至NI Web服务器。详细信息请参考教程:创建LabVIEW Web服务并将其发布到NI Web服务器

按照下列步骤,将Web服务发布至运行在本地计算机上的应用程序Web服务器:

  1. 右键单击Web服务项目项并选择应用程序Web服务器»发布。此时将显示部署进度对话框。
  2. 如LabVIEW成功发布Web服务,单击关闭按钮。Web客户端现可与HTTP方法VI交换数据。

相关信息

发布Web服务

为Web服务设置应用程序Web服务器

从客户端访问Web服务

按照下列步骤,通过URL从Web浏览器发送数据至发布的Web服务:

  1. 右键单击Add.vi并选择显示方法URL,显示HTTP方法URL对话框。
  2. 可用服务器下拉菜单中,选择包含应用程序的项,然后单击复制URL按钮。该URL包含一个与调试服务器URL不同的端口号。LabVIEW使用该端口号与应用程序Web服务器上的Web服务进行通信。
  3. 关闭对话框。
  4. 复制URL至标准Web浏览器并用数值替换{值}变量,如http://127.0.0.1:8080/TutorialService/Add?b=2&a=3
    注: 如客户端与发布Web服务的系统不同,必须将127.0.0.1替换为主机系统的实际IP地址。
  5. 浏览器返回JSON响应,包括分配给连线板每个显示控件的输出值。

相关信息

通过URL发送数据至已部署的应用程序

监控Web服务

按照下列步骤,检查发布至应用程序Web服务器的Web服务状态:

  1. 右键单击Web服务项目项并选择应用程序Web服务器»管理Web服务器。NI基于Web的配置和监控在Web浏览器中打开。
  2. 单击窗口左侧的Web服务管理按钮
  3. 已部署的Web服务列表中选择TutorialService。如列表为空,单击刷新按钮。
  4. 注意Web服务的状态为运行。使用页面底部的按钮暂停、恢复、重新启动和取消部署Web服务。
  5. 在页面右侧,可看到两个HTTP方法VI的URL映射:AddAdditionalOperations/Subtract,分别对应于相关的HTTP方法。

延伸阅读

范例代码

关于使用Web服务的范例,见下列LabVIEW项目:

  • examples\Connectivity\Web Services\Weather Monitor\Web Services — Weather Monitor.lvproj