数据批量保存
一次保存多个游戏数据。
URL确认
API service-storage-api.playnanoo.com 域名 使用。
API信息
- URL:
https://service-storage-api.playnanoo.com/storage/v20221001/save/multi - Method:
PUT - 需要认证: 是
请求参数
| 参数 | 类型 | 必填 | 说明 |
|---|---|---|---|
| storage_items | array | 必填 | 保存 数据 列表 |
storage_items 数组元素
| 字段 | 类型 | 必填 | 说明 |
|---|---|---|---|
| storage_key | string | 必填 | 要保存的数据的密钥 |
| storage_value | string | 必填 | 要保存的数据的值 |
响应数据
| 字段 | 类型 | 说明 |
|---|---|---|
| Status | string | 处理状态 |
代码示例
void UMyGame::SaveMultiData()
{
// storage_items 배열 생성
TArray<TSharedPtr<FJsonValue>> ItemsArray;
TSharedPtr<FJsonObject> Item1 = MakeShareable(new FJsonObject());
Item1->SetStringField(TEXT("storage_key"), TEXT("player_level"));
Item1->SetStringField(TEXT("storage_value"), TEXT("10"));
ItemsArray.Add(MakeShareable(new FJsonValueObject(Item1)));
TSharedPtr<FJsonObject> Item2 = MakeShareable(new FJsonObject());
Item2->SetStringField(TEXT("storage_key"), TEXT("player_gold"));
Item2->SetStringField(TEXT("storage_value"), TEXT("5000"));
ItemsArray.Add(MakeShareable(new FJsonValueObject(Item2)));
// 플레이어 정보가 포함된 요청 바디 생성
TSharedPtr<FJsonObject> Body = FPlayNANOOHelper::CreateRequestBody();
Body->SetArrayField(TEXT("storage_items"), ItemsArray);
// JSON 문자열 변환
FString JsonBody = FPlayNANOOHelper::ToJsonString(Body);
// HTTP 요청
TSharedRef<IHttpRequest> Request = FHttpModule::Get().CreateRequest();
Request->SetURL(TEXT("https://service-storage-api.playnanoo.com/storage/v20221001/save/multi"));
Request->SetVerb(TEXT("PUT"));
FPlayNANOOHelper::SetCommonHeaders(Request, true); // 인증 토큰 포함
Request->SetContentAsString(JsonBody);
Request->OnProcessRequestComplete().BindLambda(
[](FHttpRequestPtr Req, FHttpResponsePtr Res, bool bSuccess)
{
if (bSuccess && Res.IsValid())
{
TSharedPtr<FJsonObject> JsonObject;
TSharedRef<TJsonReader<>> Reader = TJsonReaderFactory<>::Create(Res->GetContentAsString());
if (FJsonSerializer::Deserialize(Reader, JsonObject))
{
FString Status = JsonObject->GetStringField(TEXT("Status"));
UE_LOG(LogTemp, Log, TEXT("다중 데이터 저장 성공: %s"), *Status);
}
}
});
Request->ProcessRequest();
}
高效保存
需要同时保存多个数据时使用此API可以减少网络请求次数,更加高效。
事务
所有数据会原子性保存。即使有一个失败,也会全部按失败处理。