MirrorLink(三 UPNP)- Application Server Service

2024-02-11 13:32

本文主要是介绍MirrorLink(三 UPNP)- Application Server Service,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、UPnP Application Server Service

1、Service Type

urn:schemas-upnp-org:service:TmApplicationServer:1

2、State Variables

(1)AppStatusUpdate:是一个以逗号作为分隔符的appIDs(status发生变化的)的队列,appIDs参考TmApplicationServer 第一次event上来的的applist,每个appID都是A_ARG_TYPE_AppID类型。

例如:<AppStatusUpdate>0x5,0x1,0x4,0x3,0x7,0x2,0x6</AppStatusUpdate>

(2)AppListUpdate:是一个以逗号作为分隔符的appIDs(entries发生变化的)的队列,每个appID都是A_ARG_TYPE_AppID类型。

例如:<AppListUpdate>0x5,0x1,0x4,0x3,0x7,0x2,0x6</AppListUpdate>

(3)A_ARG_TYPE_AppStatus:这个变量是用xml格式表示的。表示的是某个特定的应用或者所有应用的status,这些应用都是可以被远程控制的。

(4)A_ARG_TYPE_AppID:32bit的unsigned int类型(16进制,以0x开头)

     0x45ab and 0x45AB (case insensitivity of the hexadecimal numbers) 
 0x45ab and 0X45ab (case insensitivity of the 0x) 
 0x00001234 and 0x001234 (leading zeros do not matter)

(5)A_ARG_TYPE_ProfileID:大约等于0的unsigned int

(6)A_ARG_TYPE_AppList:这个变量是用xml格式表示的。表示所有应用的列表

每个application用到的protocol如下:

(7)A_ARG_TYPE_URI:格式如下:

各个application的url组成:

(8) A_ARG_TYPE_String :sting类型
(9) A_ARG_TYPE_Bool :bool类型,false或者true
(10) A_ARG_TYPE_INT :unsigned int
(11) A_ARG_TYPE_AppCertificateInfo:这个变量是用xml格式表示的,结构如下:

UUID格式如下:

UUID = 4 * <hexOctet> “-” 2 * <hexOctet> “-” 2 * <hexOctet> “-” 2 * <hexOctet> “-” 6 * <hexOctet> 
hexOctet = <hexDigit> <hexDigit> 
hexDigit = “0”|“1”|“2”|“3”|“4”|“5”|“6”|“7”|“8”|“9”| “a”|“b”|“c”|“d”|“e”|“f”|“A”|“B”|“C”|“D”|“E”|“F”

例如:“uuid:2fac1234-31f8-11b4-a222-08002b34c003”

3、event,application service需要订阅的event如下图所示:

二、Action

1、GetApplicationList:这个action可以获取到一个application列表,这里面的application都可以远程开启和关闭

参数:

         AppListingFilter:这是一个过滤器,具体使用方法看文档,一般写"*"或者""表示获取所有的application及其属性

         ProfileID:这个是TmClientProfile service获取到的,如果TmClientProfile service没有设置,则为0

返回值:AppListing:返回一个applications的列表,这些 applications可以被远程控制和访问(可以用LaunchApplication, TerminateApplication and GetApplicationStatus actions控制)

2、LaunchApplication:用来远程启动一个程序。即使没有再UI上的程序也可以启动,如果某个程序使用相同profileID,调用LaunchApplication则会让此程序变为前台执行并或者UI控制权。

参数:AppID:GetApplicationList中获取到的中的某个AppID

ProfileID:这个是TmClientProfile service获取到的,如果TmClientProfile service没有设置,则为0

返回值:AppURI:一个对应protocol ID的url,protocol ID对应的是GetApplicationList action返回值里面的<remotingInfo>中的

例如:

<remotingInfo>
            <protocolID>RTP</protocolID>
            <format>98</format>
            <direction>in</direction>
            <audioIPL>4800</audioIPL>
            <audioMPL>9600</audioMPL>
</remotingInfo>

3、TerminateApplication:这个action可以使client远程关闭AppList的应用。即使这个app不是用LaunchApplication action启动的,也可以关闭。这个action有一个参数是profileID,指的是关闭实现了这个profile的实例,如果不是用LaunchApplication,启动的则profileID设置为0

参数:AppID:GetApplicationList中获取到的中的某个AppID

ProfileID:这个是TmClientProfile service获取到的,如果TmClientProfile service没有设置,则为0

返回值:TerminationResult:关闭成功为true,关闭失败为false

例如:

<TerminationResult>true</TerminationResult>

4、GetApplicationStatus:根据AppID获取对应application的status,如果AppID设置为"*",则返回所有application的status

参数:AppID,如果为"*"则返回所有application的status

返回值:AppStatus

5、GetApplicationCertificateInfo:获取一个application的证书数据

注意:AppID没说可以用"*"

6、GetCertifiedApplicationsList:Get a list of certified applications, matching a set of criteria

参数:AppCertFilter:具体看手册,一般用"*",表示不过滤

ProfileID:跟上面其他action的一样

返回值:CertifiedAppList:一个以逗号为分隔符的appIDs的列表

<AppID>0x5</AppID>

7、GetAppCertificationStatus:Return the certification status of a given application, under the provided properties

参数:AppID:某个application

AppCertFilter:一般用"*"

ProfileID:

返回值:AppCertified:返回认证的状态,认证为true,未认证为false

三、关于个数据类型的Example查看文档后续解释

这篇关于MirrorLink(三 UPNP)- Application Server Service的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/699911

相关文章

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

Windows Server 2025 搭建NPS-Radius服务器的步骤

《WindowsServer2025搭建NPS-Radius服务器的步骤》本文主要介绍了通过微软的NPS角色实现一个Radius服务器,身份验证和证书使用微软ADCS、ADDS,具有一定的参考价... 目录简介示意图什么是 802.1X?核心作用802.1X的组成角色工作流程简述802.1X常见应用802.

SQL Server身份验证模式步骤和示例代码

《SQLServer身份验证模式步骤和示例代码》SQLServer是一个广泛使用的关系数据库管理系统,通常使用两种身份验证模式:Windows身份验证和SQLServer身份验证,本文将详细介绍身份... 目录身份验证方式的概念更改身份验证方式的步骤方法一:使用SQL Server Management S

Spring AI 实现 STDIO和SSE MCP Server的过程详解

《SpringAI实现STDIO和SSEMCPServer的过程详解》STDIO方式是基于进程间通信,MCPClient和MCPServer运行在同一主机,主要用于本地集成、命令行工具等场景... 目录Spring AI 实现 STDIO和SSE MCP Server1.新建Spring Boot项目2.a

SQL Server中的PIVOT与UNPIVOT用法具体示例详解

《SQLServer中的PIVOT与UNPIVOT用法具体示例详解》这篇文章主要给大家介绍了关于SQLServer中的PIVOT与UNPIVOT用法的具体示例,SQLServer中PIVOT和U... 目录引言一、PIVOT:将行转换为列核心作用语法结构实战示例二、UNPIVOT:将列编程转换为行核心作用语

Spring Boot 整合 SSE的高级实践(Server-Sent Events)

《SpringBoot整合SSE的高级实践(Server-SentEvents)》SSE(Server-SentEvents)是一种基于HTTP协议的单向通信机制,允许服务器向浏览器持续发送实... 目录1、简述2、Spring Boot 中的SSE实现2.1 添加依赖2.2 实现后端接口2.3 配置超时时