所以实际上我正在尝试发送一个MP3文件到我的电视上。但由于电视只会给你一个内部服务器错误,我创建了一个MediaRenderer,就像在Cling的示例中一样。通过监视它,我得到了一个奇怪的错误消息。但首先是我的代码:
ActionCallback setAVTransportURIAction = new SetAVTransportURI(service,uri,metadata) {
@Override
public void failure(ActionInvocation invocation, UpnpResponse operation, String defaultMsg) {
System.out.println(defaultMsg);
}
};uri是到本地http服务器的字符串:http://127.0.0.1/file.mp3我用DIDL Parser创建的元数据
DIDLContent didl = new DIDLContent();
ProtocolInfo info = new ProtocolInfo("http-get:*:audio/mpeg:DLNA.ORG_PN=MP3;DLNA.ORG_OP=01;DLNA.ORG_FLAGS=01500000000000000000000000000000");
MusicTrack track =new MusicTrack("0","0",title,creator,album, artist, new Res(info, size, uri));
didl.addItem(track);
DIDLParser parser = new DIDLParser();
String metadata="";
try {
metadata = parser.generate(didl);
} catch (Exception e) {
e.printStackTrace();
}像手册中的示例一样,我通过upnpservice发送它:
upnpService.getControlPoint().execute(setAVTransportURIAction);我知道电视没有得到文件,因为我路由到localhost。但是我用来调试的“假”MediaRenderer发出了这样的信息:
[cling-10 ] WARNING - 18:31:08,478 - A10ServiceDescriptorBinderImpl#generateActionArgument: UPnP specification violation: Not producing <retval> element to be compatible with WMP12: (ActionArgument, OUT) Actions http://127.0.0.1/file.mp3
[cling-35 ] INFO - 18:31:09,447 - DA10DeviceDescriptorBinderImpl#hydrateDevice: Invalid X_DLNADOC value, ignoring value: SST-1.0
[cling-10 ] INFO - 18:31:11,701 - DA10DeviceDescriptorBinderImpl#hydrateDevice: Invalid X_DLNADOC value, ignoring value: SST-1.0
[cling-35 ] INFO - 18:31:11,702 - DA10DeviceDescriptorBinderImpl#hydrateDevice: Invalid X_DLNADOC value, ignoring value: SST-1.0这个伪造的MediaRenderer客户端已经不在Cling的支持示例中了,我没有做太多更改
怎么啦?
发布于 2016-02-19 08:42:43
看一看实际的实现,我可以看到:
if (actionArgument.isReturnValue()) {
// TODO: UPNP VIOLATION: WMP12 will discard RenderingControl service if it contains <retval> tags
log.warning("UPnP specification violation: Not producing <retval> element to be compatible with WMP12: " + actionArgument);
// appendNewElement(descriptor, actionArgumentElement, ELEMENT.retval);
}看起来Action参数不是“返回值”。我也有同样的问题,所以当我进一步找出这个means....will对这个答案的更多内容时!
https://stackoverflow.com/questions/32315929
复制相似问题