qianlong / jdcloud-sdk-php
DragonJdCloud SDK for PHP
This package's canonical repository appears to be gone and the package has been frozen as a result.
Requires
- php: >=7.0
- ext-json: *
- ext-pcre: *
- ext-simplexml: *
- ext-spl: *
- guzzlehttp/guzzle: ^7.4.1
- guzzlehttp/promises: ^1.5.1
- guzzlehttp/psr7: ^1.8.3 || ^2.1
- mtdowling/jmespath.php: ~2.2
Requires (Dev)
- ext-dom: *
- andrewsville/php-token-reflection: ^1.4
- behat/behat: ~3.0
- doctrine/cache: ~1.4
- nette/neon: ^2.3
- phpunit/phpunit: ^4.8.35|^5.4.3
- psr/cache: ^1.0
Suggests
- ext-curl: To send requests using cURL
- ext-openssl: Allows using ssl
This package is not auto-updated.
Last update: 2024-06-06 13:49:08 UTC
README
欢迎使用京东云开发者Php工具套件(Php SDK)。使用京东云Php SDK,您无需复杂编程就可以访问京东云提供的各种服务。
为了方便您理解SDK中的一些概念和参数的含义,使用SDK前建议您先查看京东云OpenAPI使用入门。要了解每个API的具体参数和含义,请参考程序注释或参考OpenAPI&SDK下具体产品线的API文档。
环境准备
1.京东云Php SDK适用于Php 5.5及以上。
2.在开始调用京东云open API之前,需提前在京东云用户中心账户管理下的AccessKey管理页面申请accesskey和secretKey密钥对(简称AK/SK)。AK/SK信息请妥善保管,如果遗失可能会造成非法用户使用此信息操作您在云上的资源,给你造成数据和财产损失。
SDK使用方法
建议使用Composer安装京东云Php SDK:
首先在composer.json添加
"require" : {
"php" : ">=5.5",
"jdcloud-api/jdcloud-sdk-php" : ">=4.0.0"
}
然后使用Composer安装
php composer.phar install
或
composer install
您还可以下载sdk源代码自行使用。
SDK使用中的任何问题,欢迎您SDK使用问题反馈页面交流。
注意:京东云并没有提供其他下载方式,请务必使用上述官方下载方式!
调用示例
以下是创建单个云主机实例详情的调用示例
use DragonJd\Credentials\Credentials;
use DragonJd\Result;
use DragonJd\Vm\VmClient;
public function testCreateInstances()
{
$vm = new VmClient([
'credentials' => new Credentials('ak', 'sk'),
'version' => 'latest',
'scheme' => 'https'
]);
try{
$res = $vm->createInstances([
'regionId' => 'cn-north-1',
'instanceSpec' => [
'az' => 'cn-north-1a',
'imageId' => '8e187a0a-ea7c-4ad1-ba32-f21e52fb8926',
'instanceType' => 'g.n2.medium',
'name' => 'phpcreate',
'primaryNetworkInterface' => [
'networkInterface' => [
'subnetId' => 'subnet-ll47yy373i'
]
],
'systemDisk' => [
'diskCategory' => 'local'
]
]
]);
print_r($res);
print("Request Id: ". $res['requestId']. "\n");
print_r($res['result']);
}catch (\DragonJd\Exception\JdcloudException $e) {
print("Detail Message: " . $e->getMessage(). "\n");
print("Request Id: ". $e->getJdcloudRequestId(). "\n");
print("Error Type: ". $e->getJdcloudErrorType(). "\n");
print("Error Code: " . $e->getJdcloudErrorCode(). "\n");
print("Error Detail Status: ". $e->getJdcloudErrorStatus(). "\n");
print("Error Detail Message: ". $e->getJdcloudErrorMessage(). "\n");
}
}
如果需要设置额外的header,例如要调用开启了MFA操作保护的接口,需要传递x-jdcloud-security-token,则按照如下方式:
$res = $vm->deleteInstances([
'regionId' => 'cn-north-1',
'instanceId' => 'xxx',
'extraHeaders' => [
'x-jdcloud-security-token' => 'xxxx'
]
]);
如果需要设置访问点,配置超时等,请参考如下更复杂的例子:
$fix_endpoint = EndpointProvider::patterns([
'*/*' => ['endpoint' => 'vm.cn-north-1.jdcloud-api.com'] //指定非默认访问地址 step 1
]);
$vm = new VmClient([
'credentials' => new Credentials('ak', 'sk'),
'version' => 'latest',
'debug' => [
'logfn' => function ($msg) { echo $msg . "\n"; }, //输出调试详细日志
],
'validate' => false, //关闭客户端参数验证
'endpoint_provider' => $fix_endpoint, //指定非默认访问地址 step 2
'scheme' => 'https',
'http' => [
'verify' => 'C:/ca-bundle.crt', //指定本地证书文件
'connect_timeout' => 20, //指定连接超时
'proxy' => 'http://192.168.16.1:10', //指定代理
'timeout' => 5 //指定请求超时
]
]);
更多调用示例参考 SDK使用Demo