Witam,
Próbuję napisać aplikację na Androida która ma za zadanie skopiować z folderu udostępnionego na Windowsie do telefonu. Niestety aplikacja się wykrzacza w momencie tworzenia obiektu klasy kopiującej z smb na telefon.

Kod klasy kopiującej z smb.

public class SmbCopyToLocal {

    private String urlToCopyFile;   // Ściezka do pliku do skopiowania
    private String pathToSaveFile;   //Scieżda do pliku do zapisania
    private NtlmPasswordAuthentication auth;    // Dane do autoryzacji
    private SmbFile smbFile;    // Utworzenie obiektu pliku do otwarcia
    private SmbFileInputStream fileIn;   // Otwarcie strumienia odczytu
    private OutputStream fileOut;   //Otwarcie strumienia zapisu
//----------------------------------------------------------------------------------------Deklaracja składowych


    public SmbCopyToLocal(String url, String path, String user, String pass) {

        urlToCopyFile = url;
        pathToSaveFile = path;
        auth = new NtlmPasswordAuthentication(null, user, pass);
        try {
            smbFile = new SmbFile(urlToCopyFile, auth);
            fileIn = new SmbFileInputStream(smbFile);
            fileOut = new FileOutputStream(pathToSaveFile);

        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (UnknownHostException e) {
            e.printStackTrace();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (SmbException e) {
            e.printStackTrace();
        }


    }  
}

LogCat wyrzuca mi:

05-24 22:57:32.902  12604-12604/lolo.androidtest.apptest E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: lolo.androidtest.apptest, PID: 12604
    java.lang.ExceptionInInitializerError
            at jcifs.UniAddress.<clinit>(UniAddress.java:62)
            at jcifs.smb.SmbFile.getFirstAddress(SmbFile.java:864)
            at jcifs.smb.SmbFile.connect(SmbFile.java:951)
            at jcifs.smb.SmbFile.connect0(SmbFile.java:880)
            at jcifs.smb.SmbFile.open0(SmbFile.java:972)
            at jcifs.smb.SmbFile.open(SmbFile.java:1006)
            at jcifs.smb.SmbFileInputStream.<init>(SmbFileInputStream.java:73)
            at jcifs.smb.SmbFileInputStream.<init>(SmbFileInputStream.java:65)
            at lolo.androidtest.apptest.SmbCopyToLocal.<init>(SmbCopyToLocal.java:32)
            at lolo.androidtest.apptest.MainActivity$1.onClick(MainActivity.java:28)
            at android.view.View.performClick(View.java:4438)
            at android.view.View$PerformClick.run(View.java:18422)
            at android.os.Handler.handleCallback(Handler.java:733)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5050)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: android.os.NetworkOnMainThreadException
            at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1145)
            at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
            at java.net.InetAddress.getLocalHost(InetAddress.java:365)
            at jcifs.netbios.NbtAddress.<clinit>(NbtAddress.java:187)
            at jcifs.UniAddress.<clinit>(UniAddress.java:62)
            at jcifs.smb.SmbFile.getFirstAddress(SmbFile.java:864)
            at jcifs.smb.SmbFile.connect(SmbFile.java:951)
            at jcifs.smb.SmbFile.connect0(SmbFile.java:880)
            at jcifs.smb.SmbFile.open0(SmbFile.java:972)
            at jcifs.smb.SmbFile.open(SmbFile.java:1006)
            at jcifs.smb.SmbFileInputStream.<init>(SmbFileInputStream.java:73)
            at jcifs.smb.SmbFileInputStream.<init>(SmbFileInputStream.java:65)
            at lolo.androidtest.apptest.SmbCopyToLocal.<init>(SmbCopyToLocal.java:32)
            at lolo.androidtest.apptest.MainActivity$1.onClick(MainActivity.java:28)
            at android.view.View.performClick(View.java:4438)
            at android.view.View$PerformClick.run(View.java:18422)
            at android.os.Handler.handleCallback(Handler.java:733)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5050)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
            at dalvik.system.NativeStart.main(Native Method)

LogCat pokazuje, że aplikacja wykrzacza się na linii:

fileIn = new SmbFileInputStream(smbFile);

at lolo.androidtest.apptest.SmbCopyToLocal.<init>(SmbCopyToLocal.java:32)

smbCopyToLocal = new SmbCopyToLocal("smb://192.168.1.3/workspace/tes/test6.jpg","/storage/sdcard0/ARC/te.jpg","test","test");

at lolo.androidtest.apptest.MainActivity$1.onClick(MainActivity.java:28)

Jednak nie mogę dojść co źle robię. Wcześniej używałem tej klasy w aplikacji napisanej na komputer i tam wszystko działa bez problemu.