示例代码
示例代码下载
PHP:前往Github下载
示例代码仅供参考, 请根据实际情况使用。
示例代码(PHP)
Note:
建议用户使用子账号密钥 + 环境变量的方式调用 SDK,提高 SDK 使用的安全性。为子账号授权时,请遵循 最小权限指引原则,防止泄漏目标存储桶或对象之外的资源。
如果您一定要使用永久密钥,建议遵循 最小权限指引原则 对永久密钥的权限范围进行限制。
以 DescribeCdnHosts 为例:
<?php/*DSA API请求域名*/$HttpUrl="dsa.api.qcloud.com";/*除非有特殊说明,其它接口都支持GET及POST*/$HttpMethod="GET";/*是否https协议,DSA 云API接口都必须为https协议*/$isHttps =true;/*需要填写你的密钥,可从 https://console.cloud.tencent.com/capi 获取 SecretId 及 $secretKey*/$secretId = getenv('CDN_SECRET_ID'); // 用户的 SecretId,建议使用子账号密钥,授权遵循最小权限指引,降低使用风险。子账号密钥获取可参考https://cloud.tencent.com/document/product/598/37140$secretKey = getenv('CDN_SECRET_KEY'); // 用户的 SecretKey,建议使用子账号密钥,授权遵循最小权限指引,降低使用风险。子账号密钥获取可参考https://cloud.tencent.com/document/product/598/37140/*调用接口的名称*/$action='GetDsaHostList';/*下面为接口的公共请求参数*/$COMMON_PARAMS = array('Nonce'=> rand(),'Timestamp'=>time(NULL),'Action'=>$action,'SecretId'=> $SecretId,);/*下面为接口的接口请求参数 */$PRIVATE_PARAMS = array('offset' => 0,'length' => 10,);
/***********************************************************************************/
CreateRequest($HttpUrl,$HttpMethod,$COMMON_PARAMS,$secretKey, $PRIVATE_PARAMS, $isHttps);
function CreateRequest($HttpUrl,$HttpMethod,$COMMON_PARAMS,$secretKey, $PRIVATE_PARAMS, $isHttps)
{
$FullHttpUrl = $HttpUrl."/v2/index.php";
/***************对请求参数 按参数名 做字典序升序排列,注意此排序区分大小写*************/$ReqParaArray = array_merge($COMMON_PARAMS, $PRIVATE_PARAMS);ksort($ReqParaArray);/**********************************生成签名原文*********************************** 将 请求方法, URI地址,及排序好的请求参数 按照下面格式 拼接在一起, 生成签名原文,此请求中的原文为* GETdsa.api.qcloud.com/v2/index.php?Action=GetDsaHostList&Nonce=13029* &SecretId=****************************************&Timestamp=1463122059&length=10&offset=0* ****************************************************************************/$SigTxt = $HttpMethod.$FullHttpUrl."?";$isFirst = true;foreach ($ReqParaArray as $key => $value){if (!$isFirst){$SigTxt = $SigTxt."&";}$isFirst= false;/*拼接签名原文时,如果参数名称中携带_,需要替换成.*/if(strpos($key, '_')){$key = str_replace('_', '.', $key);}$SigTxt=$SigTxt.$key."=".$value;}/*********************根据签名原文字符串 $SigTxt,生成签名 Signature******************/$Signature = base64_encode(hash_hmac('sha1', $SigTxt, $secretKey, true));
/拼接请求串,对于请求参数及签名,需要进行urlencode编码*****/
$Req = "Signature=".urlencode($Signature);
foreach ($ReqParaArray as $key => $value)
{
$Req=$Req."&".$key."=".urlencode($value);
}
/*********************************发送请求********************************/if($HttpMethod === 'GET'){if($isHttps === true){$Req="https://".$FullHttpUrl."?".$Req;}else{$Req="http://".$FullHttpUrl."?".$Req;}$Rsp = file_get_contents($Req);}else{if($isHttps === true){$Rsp= SendPost("https://".$FullHttpUrl,$Req,$isHttps);}else{$Rsp= SendPost("http://".$FullHttpUrl,$Req,$isHttps);}}var_export(json_decode($Rsp,true));}function SendPost($FullHttpUrl,$Req,$isHttps){$ch = curl_init();curl_setopt($ch, CURLOPT_POST, 1);curl_setopt($ch, CURLOPT_POSTFIELDS, $Req);curl_setopt($ch, CURLOPT_URL, $FullHttpUrl);curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);if ($isHttps === true) {curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);}$result = curl_exec($ch);return $result;}?>