본문으로 건너뛰기

캐시 다중 조회

여러 캐시 값을 한 번에 조회하는 API입니다.

URL 확인

이 API는 service-api.playnanoo.com 도메인을 사용합니다.

API 정보

  • URL: https://service-api.playnanoo.com/cache/v20241201/mget
  • Method: PUT
  • 인증 필요: 예

요청 파라미터

파라미터타입필수설명
cache_keysList\<string>필수조회할 캐시 키 목록
DeviceInfo 상속

이 API의 Req 클래스는 DeviceInfo를 상속받습니다. DeviceInfo의 모든 속성이 자동으로 포함됩니다.

응답 데이터

Res 클래스

필드타입설명
ItemsList\<CacheItems>캐시 아이템 목록

CacheItems 구조

필드타입설명
keystring캐시 키
valuestring캐시 값

Unity C# 구현

using System;
using System.Collections;
using System.Collections.Generic;
using UnityEngine.Networking;

public class CacheMultiGet
{
static string path = "https://service-api.playnanoo.com/cache/v20241201/mget";

[Serializable]
public class Req : DeviceInfo
{
public List<string> cache_keys;

public IEnumerator Send(List<string> cacheKeys, Action<Res> onSuccess, Action<BaseResponse> onError)
{
this.cache_keys = cacheKeys;

yield return HttpClient.Send<Req, Res>(
UnityWebRequest.kHttpVerbPUT,
path,
requireToken: true,
body: this,
onSuccess: onSuccess,
onError: onError
);
}
}

[Serializable]
public class Res : BaseResponse
{
public List<CacheItems> Items;
}

[Serializable]
public class CacheItems
{
public string key;
public string value;
}
}

사용 예제

public void GetMultipleCaches()
{
CacheMultiGet.Req req = new CacheMultiGet.Req();

List<string> keys = new List<string>
{
"player_level",
"player_score",
"player_hp"
};

StartCoroutine(req.Send(
cacheKeys: keys,
onSuccess: res =>
{
foreach (var item in res.Items)
{
Debug.Log($"{item.key}: {item.value}");
}
},
onError: (error) =>
{
Debug.LogError($"Mget 실패: [{error.ErrorCode}] [{error.Message}]");
}
));
}