ildarbahtigozin / odata-1c
用于与1C一起使用的ODATA协议客户端
0.1.2
2023-04-19 10:32 UTC
Requires
- guzzlehttp/guzzle: ^7.2
Requires (Dev)
- phpunit/phpunit: ^8.1
This package is auto-updated.
Last update: 2024-09-19 13:58:05 UTC
README
1C的OData客户端
安装
推荐通过 Composer 安装
$ composer require kilylabs/odata-1c
使用
代码示例
<?php use Kily\Tools1C\OData\Client; require __DIR__.'/vendor/autoload.php'; $client = new Client('http://HOSTNAME/BASE/odata/standard.odata/',[ 'auth' => [ 'YOUR LOGIN', 'YOUR PASSWORD' ], 'timeout' => 300, ]); $product_data = [ 'Артикул'=>'CERTANLY_NONEXISTENT', 'Description'=>'test test test nonexistent', ]; // Creation $data = $client->{'Catalog_Номенклатура'}->create($product_data); echo "CREATED!\n"; // Getting using filter.... $data = $client->{'Catalog_Номенклатура'}->get(null,"Артикул eq 'CERTANLY_NONEXISTENT'"); echo "GOT!\n"; var_dump($data); // ... or using Ref_Key $id = $data['value'][0]['Ref_Key']; $data = $client->{'Catalog_Номенклатура'}->get($id); echo "GOT BY ID!\n"; var_dump($data); // Updating $data = $client->{'Catalog_Номенклатура'}->update($id,[ 'Description'=>'Test description', ]); echo "UPDATED!\n"; // deletion $data = $client->{'Catalog_Номенклатура'}->delete($id); echo "DELETED!\n"; // out metadata $data = $client->getMetadata(); var_dump($data);
异常处理
当服务器返回错误响应时,组件会抛出 Kily\Tools1C\OData\RequestException 异常。该异常有一个 $request 属性,其值为 Kily\Tools1C\OData\Request 类的实例,包含处理错误所需的所有必要信息。例如,在搜索记录时出现意外错误,需要记录日志
try { $data = $client->{'Catalog_Номенклатура'}->get($id); if(!$client->isOk()) { var_dump('Something went wrong: ',$client->getErrorCode(),$client->getErrorMessage(),$data); die(); } } catch (Exception $e) { log('Error while requested ' . $e->request->url . ': ' . $e->getMessage()); }
性能分析
为了能够拦截对oData服务器的请求以进行性能分析或类似目的,需要实现一个抽象类 Profiler
use Kily\Tools1C\OData\Profiler; class CustomProfiler extends Profiler { public function begin() { echo 'Start request ' . $this->url . ' (' . $this->method . ')'; if (!empty($this->data)) { echo ' with data: ' . var_export($this->data, true) . "\n<br>"; } } public function end() { echo 'Ending request ' . $this->url . ' (' . $this->method . ')' . "\n<br>"; } }
并将其传递给 oData 客户端构造函数或通过设置器设置
$profiler = new Profiler; $client = new Client($url, $options, $profiler); $client->setProfiler($profiler);
TODO
- 实现 getLastId() 方法;
- 支持XML吗?