- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
设备:Belkin WeMo Switch
开发环境:MS VC++ 2010 on Windows7
我正在尝试使用 Windows 中的 C++ 枚举 UPnP 设备的服务。
我有 IUPnPDevice
指针,可以访问多个属性。
我有 IUPnPServices
指针,可以计算出正确的服务数量 (7)。
我使用 QueryInterface()
获取 IEnumVARIANT
指针(似乎成功了)。
但是,Next()
方法总是失败,HRESULT
为 0x80040500
- 翻译为 Windows 错误 1280 (0x500) - ERROR_ALREADY_FIBER
.
这个错误对我来说没有任何意义。
(我试过同时使用 IEnumVARIANT
和 IEnumUnknown
- 因为文档表明它可能是其中之一,但两者产生相同的结果。)
我在下面包含了完整的源文件,以及它产生的输出。
[注意:硬编码为使用我自己设备的udn]
如果有人能提供帮助,我将不胜感激,因为我目前陷入困境。
最好的问候,
戴夫
代码:
// UpnpTest1.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <windows.h>
#include <upnp.h>
static void DumpComError(const TCHAR *api, HRESULT hr);
int _tmain(int argc, _TCHAR* argv[])
{
int retcode=-1; // assume failure
HRESULT hr = CoInitialize(0);
if (hr==S_OK)
{
IUPnPDeviceFinder *deviceFinder=0;
hr = CoCreateInstance(CLSID_UPnPDeviceFinder, 0, CLSCTX_INPROC_SERVER, IID_IUPnPDeviceFinder, (void**)&deviceFinder);
if (hr==S_OK)
{
IUPnPDevice *device=0;
hr = deviceFinder->FindByUDN(L"uuid:Socket-1_0-221239K11002F6", &device);
if (hr==S_OK)
{
if (device)
{
TCHAR *manufacturer=0, *manufacturerUrl=0;
TCHAR *description=0, *name=0, *modelUrl=0;
TCHAR *serialNumber=0, *udn=0, *upc=0, *deviceType=0;
TCHAR *presentationUrl=0;
device->get_ManufacturerName(&manufacturer);
device->get_ManufacturerURL(&manufacturerUrl);
device->get_Description(&description);
device->get_FriendlyName(&name);
device->get_ModelURL(&modelUrl);
device->get_SerialNumber(&serialNumber);
device->get_UniqueDeviceName(&udn);
device->get_UPC(&upc);
device->get_Type(&deviceType);
device->get_PresentationURL(&presentationUrl);
_tprintf(_T("MANUFACTURER: %s [%s]\n"), manufacturer, manufacturerUrl);
_tprintf(_T("MODEL: %s [%s]\n [%s]\n"), description, name, modelUrl);
_tprintf(_T("DEVICE: serial=%s\n udn=%s\n upc=%s\n type=%s\n"), serialNumber, udn, upc, deviceType);
_tprintf(_T("URL: %s\n"), presentationUrl);
IUPnPServices *services=0;
hr = device->get_Services(&services);
if (hr==S_OK)
{
if (services)
{
long numberOfServices=0;
services->get_Count(&numberOfServices);
if (numberOfServices>0)
{
IUnknown *unknown=0;
hr = services->get__NewEnum(&unknown);
if (hr==S_OK)
{
if (unknown)
{
IEnumVARIANT *enumInterface=0;
hr = unknown->QueryInterface(IID_IEnumVARIANT,(void**)&enumInterface);
if (enumInterface)
{
VARIANT var;
unsigned long fetched=0;
hr = enumInterface->Next(1, &var, &fetched);
if (hr==S_OK)
{
}
else
DumpComError(_T("IEnumVARIANT::Next"), hr);
}
else
DumpComError(_T("IUnknown::QueryInterface"), hr);
}
else
fprintf(stderr, "Failed to get enumeration interface.\n");
}
else
DumpComError(_T("IUPnPServices::get__NewEnum"), hr);
}
else
fprintf(stderr, "No services available.\n");
}
else
fprintf(stderr, "Failed to get services collection.\n");
}
else
DumpComError(_T("IUPnPDevice::get_Services"), hr);
}
else
fprintf(stderr, "Device not found.\n");
}
else
DumpComError(_T("IUPnPDeviceFinder::FindByUDN"), hr);
}
else
DumpComError(_T("CoCreateIndex"), hr);
}
else
DumpComError(_T("CoInitialize"), hr);
return retcode;
}
static void AddBoolToString(const TCHAR *name, bool value, TCHAR *buf, int &i, int max)
{
if (name && *name && value && buf && i>=0)
i += _snwprintf_s(&buf[i], max-i, (max-i-1)*sizeof(TCHAR), _T("%s%s=YES"), (i>0? _T("; "): _T("")), name);
}
static void AddIntToString(const TCHAR *name, int value, TCHAR *buf, int &i, int max)
{
if (name && *name && value && buf && i>=0)
i += _snwprintf_s(&buf[i], max-i, (max-i-1)*sizeof(TCHAR), _T("%s%s=%d"), (i>0? _T("; "): _T("")), name, value);
}
static void DumpComError(const TCHAR *api, HRESULT hr)
{
bool failure = (hr&0x80000000? true: false);
bool severe = (hr&0x40000000? true: false);
bool microsoft = (hr&0x20000000? false: true);
bool ntStatus = (hr&0x10000000? true: false);
bool xBit = (hr&0x08000000? true: false);
int facility = (hr&0x07FF0000)>>16;
int code = (hr&0x0000FFFF);
TCHAR buf[1024]={0};
int bufsize = sizeof(buf)/sizeof(TCHAR);
int i=0;
AddBoolToString(_T("failure"), failure, buf, i, bufsize);
AddBoolToString(_T("severe"), severe, buf, i, bufsize);
AddBoolToString(_T("microsoft"), microsoft, buf, i, bufsize);
AddBoolToString(_T("ntStatus"), ntStatus, buf, i, bufsize);
AddBoolToString(_T("xBit"), xBit, buf, i, bufsize);
AddIntToString(_T("facility"), facility, buf, i, bufsize);
AddIntToString(_T("code"), code, buf, i, bufsize);
_ftprintf(stderr, _T("\n%s() failed, hr=0x%08x\n[%s]\n"), api, hr, buf);
}
输出:它产生以下输出:
MANUFACTURER: Belkin International Inc. [http://www.belkin.com/]
MODEL: Belkin Plugin Socket 1.0 [WeMo Switch]
[http://www.belkin.com/plugin/]
DEVICE: serial=221239K11002F6
udn=uuid:Socket-1_0-221239K11002F6
upc=123456789
type=urn:Belkin:device:controllee:1
URL: http://192.168.1.16:49153/pluginpres.html
IEnumVARIANT::Next() failed, hr=0x80040500
[failure=YES; microsoft=YES; facility=4; code=1280]
编辑:
在经历了很多死胡同之后,我设法通过手动构建 SOAP 请求并使用 Windows 套接字通过 TCP 发送请求来实现这一点。棘手的一点是让语法恰到好处,因为我以前没有 SOAP 的经验。 [UPnP 可用于识别 IP 地址和端口号 - 因为这些可以更改]。一旦启动并运行 - 它实际上比 UPnP 界面简单得多。如果您有兴趣,请告诉我,我可以发布代码...它没有直接回答我在这里提出的问题,因此用这个细节回答我的问题没有意义。
但是,如果您有兴趣,请告诉我,我可以发布代码。
干杯,
戴夫
最佳答案
0x80040500的HRESULT并不是你想的那样,而是UPNP_E_INVALID_DOCUMENT .有关这种歧义如何可能的解释,请参阅 my answer in another SO question .
我的猜测是您的 Belkin 设备提供了不一致的设备描述或服务描述 XML。不一致并不一定意味着格式损坏,UPnP 规范有大量的次要要求。从 Intel Developer Tools 尝试 Device Spy(其他答案底部的链接),如果设备弹出,则从同一套件运行 Device Validator。
关于c++ - 如何访问 UPnP 设备的服务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13783680/
我正在浏览 DIAL 的功能,并发现它与 UPnP 非常相似,实际上它使用 UPnP 协议(protocol)进行设备发现 (SSDP)。 拨号提供什么,实际上是 UPnP 协议(protocol)的
我想知道 upnp/dlna 协议(protocol)是否可以同时将音频从单个媒体服务器流式传输到多个媒体渲染器。协议(protocol)允许这样做吗?谢谢。 最佳答案 基本上,这取决于您所说的“同时
我知道 DLNA 是 UPnP 的子集。我读了这篇文章:What's the difference between UPnP AV and DLNA? 但是,我仍然无法清楚地理解。 DLNA 内部有什
我想在网络上搜索我的媒体播放器。我认为它是使用 SSDP m-search 完成的吗? 另外,当我打开设备时,它会广播它的可用性吗?如何收听该广播,以及如何发送 m-search 查询? 最佳答案 I
我注册了一个 UPnP 设备: var o: IUPnPRegistrar; W: string; R: HRESULT; begin w := TFile.ReadAllText
我有一个记录音频的小应用程序,例如。从麦克风。现在我想通过 UPnP 提供该音频流,以便 MediaRenderer 可以访问和播放它。 我已经在使用 CLIG 来发现 MediaRender 的网络
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 6 年前。
我在使用 Upnp 将视频文件发送到带有 java/android 的 xbox 时遇到了问题。 我使用 cling api通过网络发现和连接 upnp 设备。发现操作运行良好,检测到 xbox。问题
我正在尝试为视频编写一个 upnp/dlna 客户端,我希望允许按标题和日期排序的选项。 使用 Windows7/wmp 作为服务器,我可以使用“dc:title”或“dc:date”进行排序,它似乎
我在 Raspberry Pi 上安装了 RaspBMC,在 Window 笔记本电脑上安装了 XBMC,在我的 Android 设备上安装了 UPnPlay。 Raspberry Pi 始终处于开启
我试图找到一个允许我通过UPnP操作它的IP摄像机。 UPnP论坛提供了一个数字安全摄像机配置文件: http://upnp.org/specs/ha/digitalsecuritycamera/ 但
我目前正在将 UPnP 支持添加到应用程序中。它将充当媒体服务器、控制点和媒体渲染器。我的问题是媒体服务器和媒体渲染器应该实现为 2 个独立的设备还是一个带有 1 个嵌入式设备的根设备? 如果是后者那
我想搜索网络上的 Sat>IP 服务器。 Sat>IP 服务器向其他 Sat>IP 服务器和客户端通告其存在。我不能连续发送 M-SEARCH 消息,而是监听服务器 NOTIFY 消息。 初始化设备的
在一个项目中,我通过发送 ssdp 数据报包并接收 http url 发现了 UPnP 打印机设备。 使用这些 url,获取打开的连接,获取描述设备和服务详细信息的 xml 架构 这里我通过dom解析
当我尝试在设备上续订 UPnP 事件订阅时,出现 412 HTTP 错误:前提条件失败,SID 错误。 此错误仅发生在一台设备上,所有其他设备都可以正常工作。 Buggy 设备是 D-Link XTr
有谁知道如何在技术上将视频(即 Youtube 视频)发送到 Roku 播放器?有一个允许流式传输的“Twonky Beam”应用程序,它似乎是将 .mp4 文件发送到 Roku 进行播放。在此处查看
我想知道是否有人有我可以导入到 Eclipse 的 UPnP 设备扫描器的示例。我喜欢这个,因为当我在模拟器中看到它的功能时,我可以更容易地理解它的工作原理。 谢谢 最佳答案 我假设您所说的“设备扫描
我正在做一个应用程序,它在支持 upnp 的电视机中呈现网页。我已经用 Cling UPnP 实现了 UPnP现在我不确定如何进一步进行。电视和设备之间的连接是如何实现的?它是套接字连接吗?有没有人有
我正在尝试为不同的端口进行端口转发以进行通信,但它们似乎在重新启动时丢失了。 我正在使用脚本制作它们,它使用以下语法: upnpc -a 192.168.1.95 22 22 TCP ... 由于我的
我知道有一些不错的 UPnP 堆栈,例如“UPnP 技术的开发人员工具”(http://opentools.homeip.net/dev-tools-for-upnp)。这可行,但我不需要所有这些功能
我是一名优秀的程序员,十分优秀!