2013-05-11 1 views
1

다음은 제 코드입니다. 이 실행되면.txt 파일을 DropBox에 업로드 할 수 없습니다.

public class MainActivity extends Activity { 
     final static private String APP_KEY = "APP_KEY"; 
     final static private String APP_SECRET = "APP_SECRET"; 
     final static private AccessType ACCESS_TYPE = AccessType.APP_FOLDER; 
     private DropboxAPI<AndroidAuthSession> mDBApi; 
     @Override 
     protected void onCreate(Bundle savedInstanceState) { 
      super.onCreate(savedInstanceState); 

      setContentView(R.layout.activity_main); 
      AppKeyPair appKeys = new AppKeyPair(APP_KEY, APP_SECRET); 
      AndroidAuthSession session = new AndroidAuthSession(appKeys, ACCESS_TYPE); 
      mDBApi = new DropboxAPI<AndroidAuthSession>(session); 
      mDBApi.getSession().startAuthentication(MainActivity.this); 

      String filePath = getApplicationContext().getFilesDir().getPath().toString() + "/magnus-opus.txt"; 

      File file = new File(filePath); 


      try { 
       file.createNewFile(); 
      } catch (IOException e2) { 
       // TODO Auto-generated catch block 
       e2.printStackTrace(); 
      } 
      FileInputStream inputStream = null; 

      try { 
       inputStream = new FileInputStream(file); 
      } catch (FileNotFoundException e1) { 
       // TODO Auto-generated catch block 
       e1.printStackTrace(); 
      } 
      try { 
       Entry response = mDBApi.putFile("/magnum-opus.txt", inputStream, 
         file.length(), null, null); 
       Log.i("DbExampleLog", "The uploaded file's rev is: " + response.rev); 
      } catch (DropboxException e) { 
       // TODO Auto-generated catch block 
       e.printStackTrace(); 
      } 

     } 

     @Override 
     public boolean onCreateOptionsMenu(Menu menu) { 
      // Inflate the menu; this adds items to the action bar if it is present. 
      getMenuInflater().inflate(R.menu.activity_main, menu); 
      return true; 
     } 

     /* Called when the application resumes */ 
     @Override 
     protected void onResume() 
     { 
      super.onResume(); 

      if (mDBApi.getSession().authenticationSuccessful()) { 
       try { 
        // Required to complete auth, sets the access token on the session 
        mDBApi.getSession().finishAuthentication(); 

        AccessTokenPair tokens = mDBApi.getSession().getAccessTokenPair(); 
       } catch (IllegalStateException e) { 
        Log.i("DbAuthLog", "Error authenticating", e); 
       } 
      } 
     } 

    } 

앱이 성공적으로 내 보관 용에 응용 프로그램 폴더를 생성하지만, 어떤 파일이 없으면 : 난 그냥 보관 용으로 빈 텍스트 파일을 만들고 업로드 할 노력하고있어. 또한 다음과 같은 오류 추적을 얻을 :

05-11 13:06:42.911: W/System.err(10467): com.dropbox.client2.exception.DropboxUnlinkedException 
05-11 13:06:42.911: W/System.err(10467): at com.dropbox.client2.DropboxAPI.assertAuthenticated(DropboxAPI.java:2486) 
05-11 13:06:42.911: W/System.err(10467): at com.dropbox.client2.DropboxAPI.putFileRequest(DropboxAPI.java:2138) 
05-11 13:06:42.911: W/System.err(10467): at com.dropbox.client2.DropboxAPI.putFileRequest(DropboxAPI.java:1459) 
05-11 13:06:42.911: W/System.err(10467): at com.dropbox.client2.DropboxAPI.putFile(DropboxAPI.java:1419) 
05-11 13:06:42.921: W/System.err(10467): at com.example.receptionlookup.MainActivity.onCreate(MainActivity.java:77) 
05-11 13:06:42.921: W/System.err(10467): at android.app.Activity.performCreate(Activity.java:5066) 
05-11 13:06:42.921: W/System.err(10467): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1101) 
05-11 13:06:42.921: W/System.err(10467): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2307) 
05-11 13:06:42.921: W/System.err(10467): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387) 
05-11 13:06:42.921: W/System.err(10467): at android.app.ActivityThread.access$600(ActivityThread.java:151) 
05-11 13:06:42.921: W/System.err(10467): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1331) 
05-11 13:06:42.921: W/System.err(10467): at android.os.Handler.dispatchMessage(Handler.java:99) 
05-11 13:06:42.921: W/System.err(10467): at android.os.Looper.loop(Looper.java:155) 
05-11 13:06:42.921: W/System.err(10467): at android.app.ActivityThread.main(ActivityThread.java:5454) 
05-11 13:06:42.921: W/System.err(10467): at java.lang.reflect.Method.invokeNative(Native Method) 
05-11 13:06:42.921: W/System.err(10467): at java.lang.reflect.Method.invoke(Method.java:511) 
05-11 13:06:42.921: W/System.err(10467): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1029) 
05-11 13:06:42.921: W/System.err(10467): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:796) 
05-11 13:06:42.921: W/System.err(10467): at dalvik.system.NativeStart.main(Native Method) 

가 원인이라면 나는 심지어 내 애플 (브라우저 인증을 통해) 드롭 박스에 액세스 할 수 있도록 시간을 가지고, 그래서 잘 모르겠어요 전에 추적이 발생하는 것 같습니다이 오류 , 또는 단지 경고. 누구 잘못 알아요?

+0

startAuthentication이 onResume 이벤트에있을 때 나머지 코드를 사용하지 말아야합니까? – muratgu

+0

전화하세요. 답으로 게시하면 받아 들일 것입니다. –

+0

나 같은 기술, 어떤 것을 공유하고 싶지는 않습니다. –

답변

1

startAuthentication 다음에 파일을 처리하는 코드를 이동하여 인증 토큰을 얻는 onResume 이벤트 처리기로 이동합니다.