java - 使用 Dropbox Java api : DropboxSSLException: javax.net.ssl.SSLPeerUnverifiedException: peer not authenticated

标签 java ssl dropbox dropbox-api

我正在尝试使用 Dropbox java API 让我的 java 应用程序上传文件。不知何故,我最终遇到了我无法解决的相同 SSL 错误。有什么建议吗?

我使用了这段代码 (http://aaka.sh/patel/2011/12/20/authenticating-dropbox-java-api/)

    public class DropboxTest {

    // App key & secret that Dropbox's developer website gives your app
    private static final String APP_KEY = "myAppKey";
    private static final String APP_SECRET = "myAppSecret";
    // Define AccessType for DropboxAPI object
    final static private AccessType ACCESS_TYPE = AccessType.APP_FOLDER;
    private static DropboxAPI<WebAuthSession> mDBApi;

    public static void main(String[] args) throws Exception{

        // Initialize the goods/session
        AppKeyPair appKeys = new AppKeyPair(APP_KEY, APP_SECRET);
        WebAuthSession session = new WebAuthSession(appKeys, ACCESS_TYPE);

        // Initialize DropboxAPI object
        mDBApi = new DropboxAPI<WebAuthSession>(session);

        // Get ready for user input
        Scanner input = new Scanner(System.in);

        // Open file that stores tokens, MUST exist as a blank file
        File tokensFile = new File("TOKENS");

        System.out.println("Enter 'a' to authenticate, or 't' to test reauthentication: ");
        String command = input.next();

        if(command.equals("a")){

            try {

                // Present user with URL to allow app access to Dropbox account on
                System.out.println("Please go to this URL and hit \"Allow\": " + mDBApi.getSession().getAuthInfo().url);
                AccessTokenPair tokenPair = mDBApi.getSession().getAccessTokenPair();

                // Wait for user to Allow app in browser
                System.out.println("Finished allowing?  Enter 'next' if so: ");
                if(input.next().equals("next")){
                    RequestTokenPair tokens = new RequestTokenPair(tokenPair.key, tokenPair.secret);
                    mDBApi.getSession().retrieveWebAccessToken(tokens);
                    PrintWriter tokenWriter = new PrintWriter(tokensFile);
                    tokenWriter.println(session.getAccessTokenPair().key);
                    tokenWriter.println(session.getAccessTokenPair().secret);
                    tokenWriter.close();
                    System.out.println("Authentication Successful!");

                }

            } catch (DropboxException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }

        else if(command.equals("t")){

            Scanner tokenScanner = new Scanner(tokensFile);       // Initiate Scanner to read tokens from TOKEN file
            String ACCESS_TOKEN_KEY = tokenScanner.nextLine();    // Read key
            String ACCESS_TOKEN_SECRET = tokenScanner.nextLine(); // Read secret
            tokenScanner.close(); //Close Scanner 

            //Re-auth
            AccessTokenPair reAuthTokens = new AccessTokenPair(ACCESS_TOKEN_KEY, ACCESS_TOKEN_SECRET);
            mDBApi.getSession().setAccessTokenPair(reAuthTokens);
            System.out.println("Re-authentication Sucessful!");

            //Run test command
            System.out.println("Hello there, " + mDBApi.accountInfo().displayName);

        }
    }
}

以 SSL 异常结束:

com.dropbox.client2.exception.DropboxSSLException: javax.net.ssl.SSLPeerUnverifiedException: peer not authenticated
    at com.dropbox.client2.RESTUtility.execute(RESTUtility.java:416)
    at com.dropbox.client2.RESTUtility.execute(RESTUtility.java:337)
    at com.dropbox.client2.RESTUtility.streamRequest(RESTUtility.java:192)
    at com.dropbox.client2.session.WebAuthSession.setUpToken(WebAuthSession.java:218)
    at com.dropbox.client2.session.WebAuthSession.getAuthInfo(WebAuthSession.java:158)
    at com.dropbox.client2.session.WebAuthSession.getAuthInfo(WebAuthSession.java:128)
    at DropboxTest.main(DropboxTest.java:45)
Caused by: javax.net.ssl.SSLPeerUnverifiedException: peer not authenticated
    at sun.security.ssl.SSLSessionImpl.getPeerCertificates(SSLSessionImpl.java:397)
    at org.apache.http.conn.ssl.AbstractVerifier.verify(AbstractVerifier.java:128)
    at org.apache.http.conn.ssl.SSLSocketFactory.createSocket(SSLSocketFactory.java:399)
    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:143)
    at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:149)
    at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:108)
    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:415)
    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:641)
    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:576)
    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:554)
    at com.dropbox.client2.RESTUtility.execute(RESTUtility.java:385)
    ... 6 more

最佳答案

想通了。我在 OSX 上使用 OpenJDK。 我使用 -Djavax.net.debug=ssl 运行 JVM 进行调试,最终出现了根异常

java.security.InvalidAlgorithmParameterException: the trustAnchors parameter must be non-empty

经过一些研究,我在这里找到了解决方案: http://architecturalatrocities.com/post/19073788679/fixing-the-trustanchors-problem-when-running-openjdk-7

现在工作正常!

关于java - 使用 Dropbox Java api : DropboxSSLException: javax.net.ssl.SSLPeerUnverifiedException: peer not authenticated,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14155971/

相关文章:

ios - 在 iOS 中预览 Dropbox 文件

Java 8 查找最大值

java - JOpenDocument:空白行和单元格的问题

java - 调整 JscrollPane 的大小

mysql - 在 delphi 中将 ca.pem 文件的内容作为硬编码字符串提供给 SSL 连接

python - 使用 Dropbox Python API 将目录上传到 Dropbox(包括所有文件和子目录)时出错

python-2.7 - Dropbox 脚本/下载完成后执行某些操作

Java:使 jcombobox 的一项不可选择(如子标题)并编辑该项目的字体

ssl - ngx_slab_alloc() 失败 : no memory in SSL session shared cache "le_nginx_SSL"

ssl - CA 签名的 SSL 证书不受信任,声称是自签名的