教程:创建LabVIEW Web服务并将其发布到应用程序Web服务器(Real-Time、Windows)
- 更新时间2025-08-27
- 阅读时长12分钟
按照下列步骤创建、发布一个LabVIEW Web服务,并在LabVIEW Web服务和Web客户端(以Web浏览器为例)之间交换数据。
注: 关于本主题中其他概念的详细信息,请参考Web服务介绍。LabVIEW Web服务仅在LabVIEW完整版开发系统和LabVIEW专业版开发系统中可用。
教程包括下列内容:
创建Web服务
在LabVIEW项目中开发Web服务,组合并配置构成Web服务的VI和其他文件。按照下列步骤创建一个Web服务项目和两个HTTP方法VI。
- 创建一个组织Web服务文件的LabVIEW项目。将项目保存为Tutorial.lvproj。
- 右键单击我的电脑并选择新建»Web服务。LabVIEW在该终端下添加一个Web服务项目项和文件夹。注:
- 在本教程中,您将创建一个Web服务,并将服务发布至主机。在LabVIEW项目的RT终端下创建一个Web服务项目,可把Web服务发布至RT终端。
- (Windows) NI建议您在Windows操作系统上使用NI Web服务器托管Web服务。详细信息请参考教程:创建LabVIEW Web服务并将其发布到NI Web服务器。
- 右键单击Web服务项目项
并选择重命名,将Web服务命名为TutorialService。项目显示为:
- 右键单击Web资源并选择新建VI,新建一个HTTP方法VI,该VI从客户端接收HTTP请求并将数据返回客户端。LabVIEW从模板打开一个新的VI。注: 默认状态下,HTTP方法VI通过连线板向客户端返回数据。在该教程中,HTTP方法VI返回默认的JSON格式文本。创建本教程未涵盖的HTTP方法VI时,也可以自定义格式(例如,自定义HTML页或图像数据)返回数据流至客户端,而不是通过连线板返回数据。。在Web服务属性对话框的HTTP方法VI设置页配置输出的格式。
- 在该新VI中,创建如下所示的程序框图、前面板和连线板。将该VI作为Web服务的一部分发布时,Web客户端可发送HTTP请求调用该VI。调用时,VI执行下列操作:
程序框图 前面板 连线板 


- 接收来自客户端HTTP请求分配给连线板的任何控件的值(不包括LabVIEW Web服务请求)。LabVIEW Web服务请求相当于引用句柄,用于识别当前的HTTP请求。
- 计算a和b的和。
- 通过分配给连线板的c显示控件返回这些值的和。
- 执行“读取请求变量”VI并返回客户端在当前HTTP请求中包含的查询字符串,该字符串由LabVIEW Web服务请求识别。提示 更为复杂的Web服务可能需要使用Web服务选板上的其他VI以启用某些功能,例如,HTTP会话、身份验证、HTTP头和cookie等。
- 注意每个输入控件和显示控件均显示在连线板上。默认接线端输出类型中,只有通过分配给HTTP方法VI连线板的输入和输出,Web服务才能从客户端接收数据或将数据发送至客户端。提示 为每个对象分配可识别的名称。因为这些名称将成为Web客户端使用的URL的一部分,用来与VI交换数据。
- 将VI保存为Add.vi。
- 在弹出的对话框中选择文件»另存为,然后选择副本»另外打开副本。确保勾选添加副本至Tutorial.lvproj复选框,然后单击继续。
- 将新副本保存为Subtract.vi。
- 打开Subtract.vi的程序框图,并将“加”函数替换为“减”函数。重新连线输入控件和显示控件。
- 返回项目,右键单击Web资源并选择新建Web资源。重命名新建项目项为AdditionalOperations。
- 拖曳Subtract.vi至AdditionalOperations项目项下。保存项目,项目应显示如下图。

注意项目目录树中的下列功能:
- LabVIEW向每个HTTP方法VI追加HTTP请求类型,默认值为GET。可对客户端发送至特定HTTP方法VI的HTTP请求类型进行修改,教程后续章节有详细说明。
- Web服务项目项
还包含启动VI文件夹。本教程未使用启动VI,但后续章节对启动VI做了详细说明。
相关信息
测试和调试Web服务
发布Web服务至终端前,需要测试HTTP方法VI是否按照预期与客户端进行通信。可直接从LabVIEW项目将Web服务置于调试服务器上,从而允许客户端发送请求至HTTP方法VI。调试服务器提供类似沙盒的环境。
- (Windows)右键单击我的电脑下的Web服务项目项
,选择应用程序Web服务器»开始(调试服务器)。(Real-Time)右键单击RT终端下的Web服务项目项
,选择开始(调试服务器)。 - 打开Add.vi。注意运行按钮表示VI保留为执行
,因为LabVIEW加载Web服务,使其可在调试服务器上与客户端通信。 - 关闭Add.vi。
- 按照下列步骤,获取客户端调用Add.vi使用的URL:
- 右键单击Add.vi并选择显示方法URL,显示HTTP方法URL对话框。
- 在可用服务器下拉菜单中,选择包含本地调试的项,然后单击复制URL按钮。如将服务发布至Web服务器,客户端必须通过其他端口与调试服务器上的Web服务进行通信。
- 关闭对话框。注: 如HTTP方法URL对话框打开,则Web服务不响应客户端的任何请求。
- 将复制得到的URL在浏览器中打开,用实际值替换{值}变量。例如,http://127.0.0.1:8001/TutorialService/Add?b=2&a=3。
- 浏览URL。Add.vi接收到浏览器的HTTP请求,计算a和b的值,并返回响应,包括分配给Add.vi连线板每个显示控件的名称和输出值。本教程中的响应格式为JSON字符串,即接线端的默认输出格式。注意Add.vi有两个分配至连线板的显示控件:c和值。HTTP方法VI在响应中返回这两个值。
{"c":5,"value":"b=2&a=3"}
注: 如发现非预期行为,必须停止调试会话才可编辑Web服务文件,因为LabVIEW为执行保留文件时无法对其进行编辑。 - 在Subtract.vi上重复执行第4、5步。也可直接更改第5步中的URL,获得Subtract.vi唯一对应的URL映射:http://127.0.0.1:8001/TutorialService/AdditionalOperations/Subtract?b=2&a=3。
- 对Subtract.vi重复第6步。
- (Windows)右键单击Web服务项目项并选择应用程序Web服务器»停止(调试服务器)。(Real-Time)右键单击Web服务项目项并选择停止(调试服务器)。
相关信息
配置客户端访问Web服务的方式
Web客户端通过URL与HTTP方法VI交换数据。后续教程中,将在Web浏览器中输入特定的URL,直接发送数据至HTTP方法VI连线板上的输入控件。
根据下列步骤,定义客户端可用于方法HTTP方法VI的URL:
- 右键单击Web服务项目项
并选择属性,显示Web服务属性对话框。 - 在HTTP方法VI设置页,注意LabVIEW项目中Web资源文件夹的HTTP方法VI出现在Web服务VI表格中。同时,与Add.vi相比,注意在AdditionalOperations项目项中放置Subtract.vi的方式如何影响URL映射。
- 在表格中选择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客户端的格式,以及权限等安全设置。 - 单击确定,关闭Web服务属性对话框。
- 保存Tutorial.lvproj。
相关信息
发布Web服务至应用程序Web服务器
可将创建的Web服务发布至应用程序Web服务器。在该教程中,您将发布一个独立的Web服务。在更为复杂的应用中,可能需要通过LabVIEW独立应用程序或安装程序发布Web服务。应用程序Web服务器托管Web服务,并提供多种措施以保证网络数据交换的安全性,包括SSL加密。
注: (Windows)也可将Web服务发布至NI Web服务器。详细信息请参考教程:创建LabVIEW Web服务并将其发布到NI Web服务器。
按照下列步骤,将Web服务发布至运行在本地计算机上的应用程序Web服务器:
- 右键单击Web服务项目项并选择应用程序Web服务器»发布。此时将显示部署进度对话框。
- 如LabVIEW成功发布Web服务,单击关闭按钮。Web客户端现可与HTTP方法VI交换数据。
相关信息
从客户端访问Web服务
按照下列步骤,通过URL从Web浏览器发送数据至发布的Web服务:
- 右键单击Add.vi并选择显示方法URL,显示HTTP方法URL对话框。
- 在可用服务器下拉菜单中,选择包含应用程序的项,然后单击复制URL按钮。该URL包含一个与调试服务器URL不同的端口号。LabVIEW使用该端口号与应用程序Web服务器上的Web服务进行通信。
- 关闭对话框。
- 复制URL至标准Web浏览器并用数值替换{值}变量,如http://127.0.0.1:8080/TutorialService/Add?b=2&a=3。注: 如客户端与发布Web服务的系统不同,必须将127.0.0.1替换为主机系统的实际IP地址。
- 浏览器返回JSON响应,包括分配给连线板每个显示控件的输出值。
相关信息
监控Web服务
按照下列步骤,检查发布至应用程序Web服务器的Web服务状态:
- 右键单击Web服务项目项并选择应用程序Web服务器»管理Web服务器。NI基于Web的配置和监控在Web浏览器中打开。
- 单击窗口左侧的Web服务管理按钮
。 - 在已部署的Web服务列表中选择TutorialService。如列表为空,单击刷新按钮。
- 注意Web服务的状态为运行。使用页面底部的按钮暂停、恢复、重新启动和取消部署Web服务。
- 在页面右侧,可看到两个HTTP方法VI的URL映射:Add、AdditionalOperations/Subtract,分别对应于相关的HTTP方法。
延伸阅读
- 从Web客户端与LabVIEW应用程序进行通信
- 概述:基于Web与LabVIEW应用交换数据 - LabVIEW Web服务的总介绍
- 通过独立应用程序发布Web服务 - 在LabVIEW独立应用程序中包括Web服务。Web服务在应用程序运行时一起运行。
- 通过安装程序发布Web服务 - 在Windows安装程序中包括Web服务。Web服务在完成安装流程后运行。
- 开发HTTP方法VI或开发启动VI用于初始化HTTP方法VI并与其进行通信 - 开发更为复杂的HTTP方法VI和启动VI,VI作为Web服务应用程序的一部分但不与Web客户端交换数据。
- 添加静态内容至Web服务 - 与Web服务一同发布静态内容,如HTML页或图片。
范例代码
关于使用Web服务的范例,见下列LabVIEW项目:
- examples\Connectivity\Web Services\Weather Monitor\Web Services — Weather Monitor.lvproj