Post上传
OSS Java SDK目前暂不支持Post上传Object,示例提供了PostObject的示例程序,您可以直接使用或再示例基础上修改,请参考
PostObjectSample。如果您对Put Object有疑惑请参考OSS Post Object的API,请参考
PostObject。让您在修改或实现Post Object过程中有问题或疑问,请参考
JAVA模拟PostObject表单上传OSS。
上传进度条
OSS Java sdk支持进度条功能,指示上传/下载的进度。下面的代码以OSSClient.putObject为例,说明进度条功能的使用。
提示:
- static class PutObjectProgressListener implements ProgressListener {
- private long bytesWritten = 0;
- private long totalBytes = -1;
- private boolean succeed = false;
- @Override
- public void progressChanged(ProgressEvent progressEvent) {
- long bytes = progressEvent.getBytes();
- ProgressEventType eventType = progressEvent.getEventType();
- switch (eventType) {
- case TRANSFER_STARTED_EVENT:
- System.out.println("Start to upload......");
- break;
- case REQUEST_CONTENT_LENGTH_EVENT:
- this.totalBytes = bytes;
- System.out.println(this.totalBytes + " bytes in total will be uploaded to OSS");
- break;
- case REQUEST_BYTE_TRANSFER_EVENT:
- this.bytesWritten += bytes;
- if (this.totalBytes != -1) {
- int percent = (int)(this.bytesWritten * 100.0 / this.totalBytes);
- System.out.println(bytes + " bytes have been written at this time, upload progress: " + percent + "%(" + this.bytesWritten + "/" + this.totalBytes + ")");
- } else {
- System.out.println(bytes + " bytes have been written at this time, upload ratio: unknown" + "(" + this.bytesWritten + "/...)");
- }
- break;
- case TRANSFER_COMPLETED_EVENT:
- this.succeed = true;
- System.out.println("Succeed to upload, " + this.bytesWritten + " bytes have been transferred in total");
- break;
- case TRANSFER_FAILED_EVENT:
- System.out.println("Failed to upload, " + this.bytesWritten + " bytes have been transferred");
- break;
- default:
- break;
- }
- }
- public boolean isSucceed() {
- return succeed;
- }
- }
- public static void main(String[] args) {
- String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
- String accessKeyId = "<accessKeyId>";
- String accessKeySecret = "<accessKeySecret>";
- String bucketName = "<bucketName>";
- String key = "object-get-progress-sample";
- OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
- try {
- // 带进度条的上传
- ossClient.putObject(new PutObjectRequest(bucketName, key, new FileInputStream("<yourLocalFile>")).
- <PutObjectRequest>withProgressListener(new PutObjectProgressListener()));
- } catch (Exception e) {
- e.printStackTrace();
- }
- ossClient.shutdown();
- }
提示:
- putObject/getObject/uploadPart都支持进度条功能;
- uploadFile/downloadFile不支持进度条功能。
上传回调
OSS在上传文件完成的时候可以提供回调(Callback)给应用服务器。用户只需要在发送给OSS的请求中携带相应的Callback参数,即能实现回调。现在支持CallBack的接口有:PutObject、PostObject、CompleteMultipartUpload。
上传回调的一种典型应用场景是与授权第三方上传同时使用,客户端在上传文件到OSS的时候指定到服务器端的回调,当客户端的上传任务在OSS执行完毕之后,OSS会向应用服务器端主动发起HTTP请求进行回调,这样服务器端就可以及时得到上传完成的通知从而可以完成诸如数据库修改等操作,当回调请求接收到服务器端的响应之后OSS才会将状态返回给客户端。
您想了解上传回调的更详细信息,请参考
上传回调。下面以PutObject为例说明上传回调的用法。
提示:
- // endpoint以杭州为例,其它region请按实际情况填写
- String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
- // 云账号AccessKey有所有API访问权限,建议遵循阿里云安全最佳实践,创建并使用RAM子账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建
- String accessKeyId = "<yourAccessKeyId>";
- String accessKeySecret = "<yourAccessKeySecret>";
- String bucketName = "<yourBucketName>";
- // 您的回调服务器地址,如http://oss-demo.aliyuncs.com或http://127.0.0.1:9090
- String callbackUrl = "<yourCallbackServerUrl>";
- // 创建OSSClient实例
- OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
- String content = "Hello OSS";
- PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, "key",
- new ByteArrayInputStream(content.getBytes()));
- // 上传回调参数
- Callback callback = new Callback();
- callback.setCallbackUrl(callbackUrl);
- callback.setCallbackHost("oss-cn-hangzhou.aliyuncs.com");
- callback.setCallbackBody("{\\\"mimeType\\\":${mimeType},\\\"size\\\":${size}}");
- callback.setCallbackBodyType(CallbackBodyType.JSON);
- callback.addCallbackVar("x:var1", "value1");
- callback.addCallbackVar("x:var2", "value2");
- putObjectRequest.setCallback(callback);
- PutObjectResult putObjectResult = ossClient.putObject(putObjectRequest);
- // 读取上传回调返回的消息内容
- byte[] buffer = new byte[1024];
- putObjectResult.getCallbackResponseBody().read(buffer);
- // 一定要close,否则会造成连接资源泄漏
- putObjectResult.getCallbackResponseBody().close();
- // 关闭client
- ossClient.shutdown();
提示:
- 上传回调的中的参数,请参考上传回调中的说明;
- 上传回调返回的消息体一定要close,否则会造成连接资源泄漏。