Resource Access Management (RAM) ユーザーに特定の権限を付与できます。これにより、RAM ユーザーは AccessKey ペアを使用して、Object Storage Service (OSS) リソースに長期間アクセスできます。この方法は、Alibaba Cloud アカウントの AccessKey ペアを使用するよりも安全です。
ステップ 1: RAM ユーザーの作成
Alibaba Cloud アカウントまたは RAM 管理者として RAM コンソールにログインします。
左側のナビゲーションウィンドウで、 を選択します。
[ユーザー] ページで、[ユーザーの作成] をクリックします。

[ユーザーの作成] ページの [ユーザーアカウント情報] セクションで、次のパラメーターを設定します。
[ログイン名]: ログイン名は最大 64 文字で、文字、数字、ピリオド (.)、ハイフン (-)、アンダースコア (_) を使用できます。
[表示名]: 表示名は最大 128 文字です。
[タグ]:
アイコンをクリックして、タグキーとタグ値を入力します。タグを追加すると、RAM ユーザーの分類と管理に役立ちます。
説明[ユーザーの追加] をクリックすると、一度に複数の RAM ユーザーを作成できます。
[アクセス方法] セクションで [永続的な AccessKey を使用してアクセス] を選択し、[OK] をクリックします。
[コピー] をクリックして、AccessKey ペア (AccessKey ID と AccessKey Secret) を保存します。
ステップ 2: RAM ユーザーにファイルのアップロード権限を付与する
カスタムポリシーを作成して、ファイルのアップロード権限を付与します。
左側のナビゲーションウィンドウで、 を選択します。
ポリシーの作成 をクリックします。
ポリシーの作成 ページで、スクリプトの編集 タブをクリックします。ポリシードキュメントエディターで、`examplebucket` バケットの `exampledir` ディレクトリにファイルをアップロードするロール権限を付与します。次の設定例は参考用です。
警告次の例は参考用です。過剰な権限によるセキュリティリスクを防ぐために、必要に応じてより詳細な権限付与ポリシーを設定してください。詳細な権限付与ポリシーの設定方法の詳細については、「RAM または STS を使用して他のユーザーに権限を付与する」をご参照ください。
{ "Version": "1", "Statement": [ { "Effect": "Allow", "Action": "oss:PutObject", "Resource": "acs:oss:*:*:examplebucket/exampledir/*" } ] }ポリシーを設定した後、[基本情報の編集を続行] をクリックします。
[基本情報] セクションで、ポリシーの [名前] を RamTestPolicy に設定し、[OK] をクリックします。
カスタムポリシーを RAM ユーザーに関連付けます。
左側のナビゲーションウィンドウで、 を選択します。
ユーザー ページで、対象の RAM ユーザーを見つけます。
RAM ユーザーの行で、権限の追加 をクリックします。
権限の追加 ページで、カスタムポリシー タブをクリックし、カスタムポリシー RamTestPolicy を選択します。
[OK] をクリックします。
ステップ 3: RAM ユーザーの AccessKey ペアを使用して OSS にファイルをアップロードする
次の Java サンプルコードは、ローカルファイル examplefile.txt を exampleobject.txt という名前のオブジェクトとして examplebucket バケットの exampledir ディレクトリにアップロードする方法を示しています。
import com.aliyun.oss.*;
import com.aliyun.oss.common.auth.*;
import com.aliyun.oss.common.comm.SignVersion;
import com.aliyun.oss.model.PutObjectRequest;
import com.aliyun.oss.model.PutObjectResult;
import java.io.File;
public class Demo {
public static void main(String[] args) throws Exception {
// この例では、中国 (杭州) リージョンのエンドポイントが使用されています。実際の エンドポイントを指定してください。
String endpoint = "https://oss-cn-hangzhou.aliyuncs.com";
// 環境変数からアクセス資格情報を取得します。サンプルコードを実行する前に、OSS_ACCESS_KEY_ID および OSS_ACCESS_KEY_SECRET 環境変数が設定されていることを確認してください。
EnvironmentVariableCredentialsProvider credentialsProvider = CredentialsProviderFactory.newEnvironmentVariableCredentialsProvider();
// バケットの名前を指定します。例: examplebucket。
String bucketName = "examplebucket";
// オブジェクトの完全なパスを指定します。完全なパスにバケット名を含めないでください。例: exampledir/exampleobject.txt。
String objectName = "exampledir/exampleobject.txt";
// アップロードするローカルファイルの完全なパスを指定します。例: D:\\localpath\\examplefile.txt。
// デフォルトでは、ローカルファイルのパスが指定されていない場合、ローカルファイルはサンプルプログラムが属するプロジェクトのパスからアップロードされます。
String filePath= "D:\\localpath\\examplefile.txt";
// バケットが配置されているリージョンを指定します。たとえば、バケットが中国 (杭州) リージョンにある場合は、リージョンを cn-hangzhou に設定します。
String region = "cn-hangzhou";
// OSSClient インスタンスを作成します。
// OSSClient が不要になったら、shutdown メソッドを呼び出して関連リソースを解放します。
ClientBuilderConfiguration clientBuilderConfiguration = new ClientBuilderConfiguration();
clientBuilderConfiguration.setSignatureVersion(SignVersion.V4);
OSS ossClient = OSSClientBuilder.create()
.endpoint(endpoint)
.credentialsProvider(credentialsProvider)
.clientConfiguration(clientBuilderConfiguration)
.region(region)
.build();
try {
// PutObjectRequest オブジェクトを作成します。
PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, objectName, new File(filePath));
// 次のサンプルコードは、オブジェクトをアップロードするときにオブジェクトのストレージクラスと ACL を指定する方法の例を示しています。
// ObjectMetadata metadata = new ObjectMetadata();
// metadata.setHeader(OSSHeaders.OSS_STORAGE_CLASS, StorageClass.Standard.toString());
// metadata.setObjectAcl(CannedAccessControlList.Private);
// putObjectRequest.setMetadata(metadata);
// ローカルファイルをアップロードします。
PutObjectResult result = ossClient.putObject(putObjectRequest);
} catch (OSSException oe) {
System.out.println("Caught an OSSException, which means your request made it to OSS, "
+ "but was rejected with an error response for some reason.");
System.out.println("Error Message:" + oe.getErrorMessage());
System.out.println("Error Code:" + oe.getErrorCode());
System.out.println("Request ID:" + oe.getRequestId());
System.out.println("Host ID:" + oe.getHostId());
} catch (ClientException ce) {
System.out.println("Caught an ClientException, which means the client encountered "
+ "a serious internal problem while trying to communicate with OSS, "
+ "such as not being able to access the network.");
System.out.println("Error Message:" + ce.getMessage());
} finally {
if (ossClient != null) {
ossClient.shutdown();
}
}
}
}他の言語のソフトウェア開発キット (SDK) の例については、以下をご参照ください。
よくある質問
RAM ユーザーの AccessKey 情報を表示するにはどうすればよいですか? 以前の AccessKey Secret を表示できますか?
RAM ユーザーの AccessKey ペアを使用してファイルをアップロードするときに「AccessDenied」エラーが報告された場合はどうすればよいですか?
エラーが報告された場合、特定のエラータイプを照会するにはどうすればよいですか?
NoSuchBucket エラーを処理するにはどうすればよいですか?
The bucket you are attempting to access must be addressed using the specified endpoint. エラーを処理するにはどうすればよいですか?
リファレンス
OSS にファイルをアップロードした後、署名付き URL を生成して、プレビューまたはダウンロードのためにサードパーティとファイルを共有できます。詳細については、「署名付き URL を使用してファイルをダウンロードまたはプレビューする」をご参照ください。