2012-11-22 150 views
2

我试图通过HTTP Post将图像上传到SmugMug,因为它们的documentation。我把所有的标题是正确的,但令人困惑的说我是设置在机身的二进制数据的部分:通过发布请求上传文件

这种方法需要在身体 二进制数据和其他所有元数据的POST请求标题。

我曾尝试:

  • SMResponse response = builder.post(SMResponse.class, Files.readAllBytes(image.toPath())); 
    
  • SMResponse response = builder.post(SMResponse.class, new String(Files.readAllBytes(image.toPath()))); 
    
  • SMResponse response = builder.post(SMResponse.class, new String(Base64.encode(Files.readAllBytes(image.toPath())))); 
    
  • SMResponse response = builder.post(SMResponse.class, Base64.encode(Files.readAllBytes(image.toPath()))); 
    

我最好的猜测是第一位的工作,但所有这些回报:

{"stat":"fail","method":"smugmug.images.upload","code":5,"message":"system error"} 

这里是不会上传,万一完整的方法我错过了一些东西:

public boolean upload(File image, int albumId, String caption, String keywords, 
     Boolean hidden, Integer imageId, Integer altitude, Float latitude, 
     Float longitude, boolean pretty) throws IOException, InvalidKeyException, NoSuchAlgorithmException, SmugMugException { 
    logger.debug("upload() called"); 
    byte[] imageBytes = Files.readAllBytes(image.toPath()); 

    WebResource resource = SmugMugAPI.CLIENT.resource("http://upload.smugmug.com/"); 

    LoggingFilter logFilter = new LoggingFilter(); 
    resource.addFilter(logFilter); 

    OAuthSecrets secrets = new OAuthSecrets().consumerSecret(smugmug.getConsumerSecret()); 
    OAuthParameters oauthParams = new OAuthParameters().consumerKey(smugmug.getCosumerKey()). 
      signatureMethod("HMAC-SHA1").version("1.0"); 
    // Create the OAuth client filter 
    OAuthClientFilter filter = new OAuthClientFilter(SmugMugAPI.CLIENT.getProviders(), oauthParams, secrets); 
    // Add the filter to the resource 
    if (smugmug.getToken() != null){ 
     secrets.setTokenSecret(smugmug.getToken().getSecret()); 
     oauthParams.token(smugmug.getToken().getId()); 
    } 
    resource.addFilter(filter); 

    WebResource.Builder builder = resource.getRequestBuilder(); 
    //User agent 
    builder = builder.header("User-Agent", smugmug.getAppName()); 
    //API Version header 
    builder = builder.header("X-Smug-Version", "1.3.0"); 
    //Response Type header 
    builder = builder.header("X-Smug-ResponseType", "JSON"); 
    //Content-Length header 
    builder = builder.header("Content-Length", Long.toString(image.length())); 
    //Content-MD5 header 
    builder = builder.header("Content-MD5", DigestUtils.md5Hex(imageBytes)); 
    //X-Smug-FileName header 
    builder = builder.header("X-Smug-FileName", image.getName()); 
    //X-Smug-AlbumID header 
    builder = builder.header("X-Smug-AlbumID", Integer.toString(albumId)); 
    //X-Smug-Caption header 
    if(caption != null){ 
     builder = builder.header("X-Smug-Caption", caption); 
    } 
    //X-Smug-Caption header 
    if(keywords != null){ 
     builder = builder.header("X-Smug-Keywords", keywords); 
    } 
    //X-Smug-Hidden header 
    if(hidden != null){ 
     builder = builder.header("X-Smug-Hidden", hidden.toString()); 
    } 
    //X-Smug-ImageID header 
    if(imageId != null){ 
     builder = builder.header("X-Smug-ImageID", imageId.toString()); 
    } 
    //X-Smug-Altitude header 
    if(altitude != null){ 
     builder = builder.header("X-Smug-Altitude", altitude.toString()); 
    } 
    //X-Smug-Latitude header 
    if(latitude != null){ 
     builder = builder.header("X-Smug-Latitude", latitude.toString()); 
    } 
    //X-Smug-Latitude header 
    if(longitude != null){ 
     builder = builder.header("X-Smug-Longitude", longitude.toString()); 
    } 
    //X-Smug-Pretty header 
    if(pretty){ 
     builder = builder.header("X-Smug-Pretty", Boolean.toString(pretty)); 
    } 

    SMResponse response = builder.post(SMResponse.class, new String(imageBytes)); 
    if (!"ok".equals(response.getStat())) { 
     throw new SmugMugException(response); 
    } 
    return true; 
} 

我在哪里出了错?


尝试只是为了看看回应:

SMResponse response = builder.entity(image).post(SMResponse.class); 

实际上,它发回一个空白响应(无JSON),这本身就是奇怪,因为我本来期望一些消息发回。下面是输出:

Nov 21, 2012 11:55:48 PM com.sun.jersey.api.client.filter.LoggingFilter log 
INFO: 1 * Client in-bound response 
1 < 200 
1 < Edge-Control: no-store 
1 < X-SmugMug-Hiring: How to love what you do: http://www.smugmug.com/jobs/ 
1 < Date: Thu, 22 Nov 2012 05:55:48 GMT 
1 < Content-Length: 0 
1 < X-SmugMug-Values: 4/4 - It's the product, stupid 
1 < Expires: Thu, 22 Nov 2012 05:55:49 GMT 
1 < Connection: keep-alive 
1 < Content-Type: application/json; charset=utf-8 
1 < X-Powered-By: SmugMug/0.9 
1 < Server: Apache 
1 < Cache-Control: private, no-store, no-cache, max-age=1, must-revalidate 
1 < 
+0

你可以试试SMResponse response = builder.entity(image).post(SMResponse.class); – Reddy

+0

@Reddy问题在于,我在哪里设置图像本身的数据。 –

+0

它本质上是一个HTTP请求,因此尝试使用调试工具(如Fiddler/BurpSuite)捕获流量,我发现这种方法在尝试查找问题时特别有用。 –

回答

1

我不完全知道发生了什么,但我能得到的SmugMug的帐户设置找到上传日志(要到那里去工具后它的工作 - >帐户设置 - >统计信息 - >上传 - >详细信息)。请注意,在上传日志中有一个切换,只显示错误或所有上传。

现在就如何设置Post Request的实际“主体”的实际答案。实际的格式应该是第一个我贴:

SMResponse response = builder.post(SMResponse.class, Files.readAllBytes(image.toPath())); 

所以无论是我搞砸了,并认为这是不工作的时候它是有当时的smugmug的最终出了问题,或者有什么事否则在我的代码中是错误的,在我尝试修复这个非问题的过程中已经修复。