gpt4 book ai didi

Android Smack XMPP 文件传输始终显示正在进行和状态 0

转载 作者:太空狗 更新时间:2023-10-29 15:12:40 25 4
gpt4 key购买 nike

我正在开发一个聊天应用程序,我需要在其中在点对点聊天用户之间发送图像。现在我可以发送图像,我的文件接收器也接受请求并开始接收文件。

但是打印状态一直在打印:日志:进度:0.0 & 状态:进行中

在完成线程之后 -LOG ###文件传输未完成。状态:进行中

如果我让这个线程运行并删除计数,它会继续打印 - 进度:0.0 & 状态:进行中

有时会稍后收到完整图像..这需要很长时间,而且很多时候是一半或 0 大小。

private ServiceDiscoveryManager sdm;    
if (sdm == null)
sdm = new ServiceDiscoveryManager(connection);
Log.v("---fileReceive----","after discover connectin.....");
sdm.addFeature("http://jabber.org/protocol/disco#info");
sdm.addFeature("jabber:iq:privacy");

ProviderManager.getInstance().addIQProvider("query","http://jabber.org/protocol/bytestreams", new BytestreamsProvider());
ProviderManager.getInstance().addIQProvider("query","http://jabber.org/protocol/disco#items", new DiscoverItemsProvider());
ProviderManager.getInstance().addIQProvider("query","http://jabber.org/protocol/disco#info", new DiscoverInfoProvider());
ProviderManager.getInstance().addIQProvider("si", "http://jabber.org/protocol/si", new StreamInitiationProvider());
ProviderManager.getInstance().addIQProvider("query", "http://jabber.org/protocol/bytestreams", new BytestreamsProvider());
ProviderManager.getInstance().addIQProvider("open", "http://jabber.org/protocol/ibb", new OpenIQProvider());
ProviderManager.getInstance().addIQProvider("data", "http://jabber.org/protocol/ibb", new DataPacketProvider());
ProviderManager.getInstance().addIQProvider("close", "http://jabber.org/protocol/ibb", new CloseIQProvider());
ProviderManager.getInstance().addExtensionProvider("data", "http://jabber.org/protocol/ibb", new DataPacketProvider());

sdm = ServiceDiscoveryManager.getInstanceFor(connection);


FileTransferNegotiator.setServiceEnabled(connection, true);
FileTransferNegotiator.IBB_ONLY = true;
manager = new FileTransferManager(connection);
// Create the listener
// fListner=new FileTransferListener() {
manager.addFileTransferListener(new FileTransferListener() {
@Override
public void fileTransferRequest(FileTransferRequest request) {
// TODO Auto-generated method stub
Log.v("----Recieve File",
"new file transfere requesttttt------------");

Log.v("-----file request","from" + request.getRequestor());

// Accept it

try {
IncomingFileTransfer transfer = request.accept();
Log.v("----transfer--","accepted");

double percents = 0.0;
int currentCycle = 0;
transfer.recieveFile(new File( Environment.getExternalStorageDirectory().getPath()+"/"+transfer.getFileName()));


while(!transfer.isDone() && currentCycle < 100) {
if(transfer.getStatus().equals(Status.in_progress)) {
percents = ((int) (transfer.getProgress()*10000)) / 100.0;
//percents is 100.0 after 1 cycle
Log.i(LOG, "Filetransfer Progress: "+percents + " Status: "+transfer.getStatus().toString());
} else if (transfer.getStatus().equals(Status.error)) {
Log.e(LOG, "FileTransfer ERROR"+transfer.getError().getMessage());
break;
}
currentCycle ++;
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}

if(transfer.getStatus().equals(Status.complete)) {
if (onFileReceivedListener != null) {
onFileReceivedListener.onFileReceived(transfer);
}
}else{
Log.e(LOG, "###Filetransfer not complete. Status:" + transfer.getStatus().toString());
//FILE IS HERE
}
} catch (XMPPException e) {
e.printStackTrace();
}
}
}); `

感谢任何提示或帮助。

最佳答案

最近我确实对 asmack 和 smackx 有了一点经验,对它们不能太肯定。

我不知道你的问题到底出在哪里,但我可以告诉你这是正常的。在任何进度实际开始之前,您将首先获得 progress = 0 的负载。如果您发送的是一个小文件,那么它发送的速度太快以至于没有任何实际进展。

但是,如果您成功发送了一个更大的文件,这个功能确实可以很好地工作并且会给您粗略的进度。

最后我们得出结论,这个功能只是为了调试和限制,并实现了我们自己的文件传输 xmpp 消息,并处理通过我们自己的服务器发送它。像这样,您还可以将文件分组 (MUC) 发送给离线人员,并在双方(发送和接收)上显示出不错的进展。

关于Android Smack XMPP 文件传输始终显示正在进行和状态 0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15405339/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com