すべてのプロダクト
Search
ドキュメントセンター

Object Storage Service:クイックスタート (Android SDK)

最終更新日:Jun 04, 2026

OSS Android SDK を使用して、バケットの作成、オブジェクトのアップロード、オブジェクトのダウンロードを行います。

前提条件

Android SDK がインストールされていること (インストール (Android SDK) をご参照ください)。

サンプルプロジェクト

サンプルプロジェクトを使用するには:

  • ローカルファイルのアップロード、オブジェクトのダウンロード、再開可能なアップロード、コールバックの例については、「サンプルディレクトリ」をご参照ください。

  • Git を使用して「プロジェクト」をクローンしてください。

このプロジェクトを実行する前に、Config ファイルでパラメータを設定してください:

public class Config {    

    // この例では、中国 (杭州) リージョンのエンドポイントを使用しています。実際のリージョンに応じたエンドポイントを指定してください。
    public static final String OSS_ENDPOINT = "https://oss-cn-hangzhou.aliyuncs.com";
    // コールバック URL を指定してください。
    public static final String OSS_CALLBACK_URL = "https://oss-demo.aliyuncs.com:23450";
    // STS 認証サーバーの URL を指定してください。
    // プロジェクトの sts_local_server ディレクトリにあるスクリプトを使用して、ローカル STS 認証サーバーを起動することもできます。
    public static final String STS_SERVER_URL = "http://****/sts/getsts";
    
    public static final String BUCKET_NAME = "yourBucketName";
    public static final String OSS_ACCESS_KEY_ID = "yourAccessKeyId";;
    public static final String OSS_ACCESS_KEY_SECRET = "yourAccessKeySecret";

    public static final int DOWNLOAD_SUC = 1;
    public static final int DOWNLOAD_Fail = 2;
    public static final int UPLOAD_SUC = 3;
    public static final int UPLOAD_Fail = 4;
    public static final int UPLOAD_PROGRESS = 5;
    public static final int LIST_SUC = 6;
    public static final int HEAD_SUC = 7;
    public static final int RESUMABLE_SUC = 8;
    public static final int SIGN_SUC = 9;
    public static final int BUCKET_SUC = 10;
    public static final int GET_STS_SUC = 11;
    public static final int MULTIPART_SUC = 12;
    public static final int STS_TOKEN_SUC = 13;
    public static final int FAIL = 9999;
    public static final int REQUESTCODE_AUTH = 10111;
    public static final int REQUESTCODE_LOCALPHOTOS = 10112;
}

バケットの作成

バケットは、OSS において任意の数のオブジェクトを格納するグローバルに一意な名前空間です。

// バケットが配置されているリージョンのエンドポイントを yourEndpoint に設定します。例えば、バケットが中国 (杭州) リージョンにある場合、エンドポイントを https://oss-cn-hangzhou.aliyuncs.com に設定します。
String endpoint = "yourEndpoint";
// バケットが配置されているリージョンを yourRegion に設定します。例えば、バケットが中国 (杭州) リージョンにある場合、region を cn-hangzhou に設定します。
String region = "yourRegion";
// STS 認証サーバーから取得した一時的なアクセスキーペア (AccessKey ID と AccessKey Secret)。
String accessKeyId = "yourAccessKeyId";
String accessKeySecret = "yourAccessKeySecret";
// STS 認証サーバーから取得したセキュリティトークン。
String securityToken = "yourSecurityToken";

OSSCredentialProvider credentialProvider = new OSSStsTokenCredentialProvider(accessKeyId, accessKeySecret, securityToken);
ClientConfiguration config = new ClientConfiguration();
config.setSignVersion(SignVersion.V4);
// OSSClient インスタンスを作成します。
OSSClient oss = new OSSClient(getApplicationContext(), endpoint, credentialProvider);
oss.setRegion(region);

// バケット名を指定します。
CreateBucketRequest createBucketRequest = new CreateBucketRequest("bucketName");
// バケットのアクセス制御リスト (ACL) をパブリック読み取りに設定します。デフォルトの ACL はプライベートです。
createBucketRequest.setBucketACL(CannedAccessControlList.PublicRead);
// バケットが配置されているリージョンを指定します。
createBucketRequest.setLocationConstraint("oss-cn-hangzhou");
OSSAsyncTask createTask = oss.asyncCreateBucket(createBucketRequest, new OSSCompletedCallback<CreateBucketRequest, CreateBucketResult>() {
    @Override
    public void onSuccess(CreateBucketRequest request, CreateBucketResult result) {
        Log.d("locationConstraint", request.getLocationConstraint());
        }
    @Override
    public void onFailure(CreateBucketRequest request, ClientException clientException, ServiceException serviceException) {
        // リクエストが失敗しました。
        if (clientException != null) {
            // クライアント例外。ネットワークエラーなど。
            clientException.printStackTrace();
        }
        if (serviceException != null) {
            // サービス例外。
            Log.e("ErrorCode", serviceException.getErrorCode());
            Log.e("RequestId", serviceException.getRequestId());
            Log.e("HostId", serviceException.getHostId());
            Log.e("RawMessage", serviceException.getRawMessage());
        }
    }
});

オブジェクトのアップロード

ローカルファイルをオブジェクトとして OSS にアップロードします:

// バケットが配置されているリージョンのエンドポイントを yourEndpoint に設定します。例えば、バケットが中国 (杭州) リージョンにある場合、エンドポイントを https://oss-cn-hangzhou.aliyuncs.com に設定します。
String endpoint = "yourEndpoint";
// バケットが配置されているリージョンを yourRegion に設定します。例えば、バケットが中国 (杭州) リージョンにある場合、region を cn-hangzhou に設定します。
String region = "yourRegion";
// STS 認証サーバーから取得した一時的なアクセスキーペア (AccessKey ID と AccessKey Secret)。
String accessKeyId = "yourAccessKeyId";
String accessKeySecret = "yourAccessKeySecret";
// STS 認証サーバーから取得したセキュリティトークン。
String securityToken = "yourSecurityToken";

OSSCredentialProvider credentialProvider = new OSSStsTokenCredentialProvider(accessKeyId, accessKeySecret, securityToken);
ClientConfiguration config = new ClientConfiguration();
config.setSignVersion(SignVersion.V4);
// OSSClient インスタンスを作成します。
OSSClient oss = new OSSClient(getApplicationContext(), endpoint, credentialProvider);
oss.setRegion(region);

// アップロードリクエストを作成します。
PutObjectRequest put = new PutObjectRequest("<bucketName>", "<objectName>", "<uploadFilePath>");

// 非同期アップロードの進捗コールバックを設定できます。
put.setProgressCallback(new OSSProgressCallback<PutObjectRequest>() {
    @Override
    public void onProgress(PutObjectRequest request, long currentSize, long totalSize) {
        Log.d("PutObject", "currentSize: " + currentSize + " totalSize: " + totalSize);
    }
});

OSSAsyncTask task = oss.asyncPutObject(put, new OSSCompletedCallback<PutObjectRequest, PutObjectResult>() {
    @Override
    public void onSuccess(PutObjectRequest request, PutObjectResult result) {
        Log.d("PutObject", "UploadSuccess");
        Log.d("ETag", result.getETag());
        Log.d("RequestId", result.getRequestId());
    }

    @Override
    public void onFailure(PutObjectRequest request, ClientException clientExcepion, ServiceException serviceException) {
        // リクエストが失敗しました。
        if (clientExcepion != null) {
            // クライアント例外。ネットワークエラーなど。
            clientExcepion.printStackTrace();
        }
        if (serviceException != null) {
            // サービス例外。
            Log.e("ErrorCode", serviceException.getErrorCode());
            Log.e("RequestId", serviceException.getRequestId());
            Log.e("HostId", serviceException.getHostId());
            Log.e("RawMessage", serviceException.getRawMessage());
        }
    }
});
// task.cancel(); // タスクをキャンセルできます。
// task.waitUntilFinished(); // アップロードが完了するまで待機します。

オブジェクトのダウンロード

OSS からローカルファイルにオブジェクトをダウンロードします:

// バケットが配置されているリージョンのエンドポイントを yourEndpoint に設定します。例えば、バケットが中国 (杭州) リージョンにある場合、エンドポイントを https://oss-cn-hangzhou.aliyuncs.com に設定します。
String endpoint = "yourEndpoint";
// STS 認証サーバーから取得した一時的なアクセスキーペア (AccessKey ID と AccessKey Secret)。
String accessKeyId = "yourAccessKeyId";
String accessKeySecret = "yourAccessKeySecret";
// STS 認証サーバーから取得したセキュリティトークン。
String securityToken = "yourSecurityToken";
// バケットが配置されているリージョンを yourRegion に設定します。例えば、バケットが中国 (杭州) リージョンにある場合、region を cn-hangzhou に設定します。
String region = "yourRegion";

OSSCredentialProvider credentialProvider = new OSSStsTokenCredentialProvider(accessKeyId, accessKeySecret, securityToken);
ClientConfiguration config = new ClientConfiguration();
config.setSignVersion(SignVersion.V4);
// OSSClient インスタンスを作成します。
OSSClient oss = new OSSClient(getApplicationContext(), endpoint, credentialProvider);
oss.setRegion(region);
// ダウンロードリクエストを作成します。
GetObjectRequest get = new GetObjectRequest("<bucketName>", "<objectName>");

OSSAsyncTask task = oss.asyncGetObject(get, new OSSCompletedCallback<GetObjectRequest, GetObjectResult>() {
    @Override
    public void onSuccess(GetObjectRequest request, GetObjectResult result) {
        // リクエストが成功しました。
        Log.d("asyncGetObject", "DownloadSuccess");
        Log.d("Content-Length", "" + result.getContentLength());

        InputStream inputStream = result.getObjectContent();
        byte[] buffer = new byte[2048];
        int len;

        try {
            while ((len = inputStream.read(buffer)) != -1) {
                // ダウンロードしたデータを処理するコードをここに追加してください。
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    @Override
    public void onFailure(GetObjectRequest request, ClientException clientExcepion, ServiceException serviceException) {
        // リクエストが失敗しました。
        if (clientExcepion != null) {
            // クライアント例外。ネットワークエラーなど。
            clientExcepion.printStackTrace();
        }
        if (serviceException != null) {
            // サービス例外。
            Log.e("ErrorCode", serviceException.getErrorCode());
            Log.e("RequestId", serviceException.getRequestId());
            Log.e("HostId", serviceException.getHostId());
            Log.e("RawMessage", serviceException.getRawMessage());
        }
    }
});
// タスクをキャンセルします。
// task.cancel(); 
// タスクが完了するまで待機します。
// task.waitUntilFinished();