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

Posted

技术标签:

【中文标题】Android aSmack XMPP 文件传输始终显示正在进行和状态 0【英文标题】:Android aSmack XMPP filetransfer always shows in progress and status 0 【发布时间】:2013-03-14 09:21:59 【问题描述】:

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

但打印状态始终保持打印: 日志: 进度: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();
                        
                    
                ); `

感谢任何提示或帮助。

【问题讨论】:

你使用什么聊天服务器? 这不是一个真正的答案,而是一个很好的起点:github.com/Flowdalic/asmack/wiki/aSmack-XMPP-File-Transfer @Vyoma 你完成这个任务了吗? 【参考方案1】:

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

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

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

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

【讨论】:

感谢 4 您的回复。实际上,现在我得到 0 大小的 6.71 kb 图像。并且无法实现自己的服务器。如果我能得到任何问题,你能分享你的工作代码吗?从我这边。 抱歉,我认为工作代码不见了,因为我们已将其更改为使用我们自己的服务器。但是,就像我说的,尝试使用几张 MB 的照片。 6kb 发送太快了。 我尝试了 mbs 的图像,但正如我所说,对于接收器端的任何图像,它显示图像大小为 0。这意味着它已保存但未完全接收。

以上是关于Android aSmack XMPP 文件传输始终显示正在进行和状态 0的主要内容,如果未能解决你的问题,请参考以下文章

aSmack XMPP 文件传输循环处于“进行中”状态

无法使用 Beem-Asmack 在 XMPP FileTransfer 中处理上传

Android 文件传输无法通过 XMPP 和 OpenFire 工作

无法使用 asmack 版本 asmack-android-8-4.0.6.jar 在 xmpp 中返回组列表

XMPP 连接的 asmack-android-8-4.0.6.jar 问题

发送和接收 IQ ASMACK Android XMPP