三、odataproducer代码改写

2024-06-19 11:38
文章标签 代码 改写 odataproducer

本文主要是介绍三、odataproducer代码改写,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这两周导师一直在美国,所以联系起来很不方便,加上现有的资料很少,所以只能自己摸索,上周确定了思路,导师也说思路是正确的,那么这周就要对代码进行改写。

要改写的代码包括IDataServiceMetaDataProvider,IDataServiceQuery Provider,IDataServiceQueryProvider2,IServiceProvider ,IExpressionProvider,Metadata Mapping这几个部分,每一个部分的功能在上周的报告中已经说过,这里就不在赘述,那么我们一个个来。

 

首先是IDataServiceMetaDataProvider,用来描述实体集和实体的属性及实体间的联系,我们选择SugarCRM中的Contacts实体,首先定义Contacts实体,我们选取

id;   序号
first_name;    名
last_name;    姓
phone_mobile;手机
phone_fax; 传真
primary_address_street;  地址-街道
primary_address_city;地址-城市

primary_address_country;地址-国家
birthdate; 生日
其中id为主键,下面会用到

class Contacts
{//Key Edm.Int32public $id;//Edm.Stringpublic $first_name;//Edm.Stringpublic $last_name;//Edm.Stringpublic $phone_mobile;//Edm.Stringpublic $phone_fax;//Edm.Stringpublic $primary_address_street;//Edm.Stringpublic $primary_address_city;//Edm.Stringpublic $primary_address_country;//Edm.Stringpublic $birthdate;//Edm.String
}

 

然后创建元数据类class CreateSugarCRMMetadata

    public static function create(){$metadata = new ServiceBaseMetadata('SugarCRMEntities', 'SugarCRM');//Register the entity (resource) type 'Contacts'$ContactsEntityType = $metadata->addEntityType(new ReflectionClass('Contacts'), 'Contacts', 'SugarCRM');$metadata->addKeyProperty($ContactsEntityType, 'id', EdmPrimitiveType::INT32);$metadata->addPrimitiveProperty($ContactsEntityType, 'first_name', EdmPrimitiveType::STRING);$metadata->addPrimitiveProperty($ContactsEntityType, 'last_name', EdmPrimitiveType::STRING);$metadata->addPrimitiveProperty($ContactsEntityType, 'primary_address_street', EdmPrimitiveType::STRING);$metadata->addPrimitiveProperty($ContactsEntityType, 'primary_address_city', EdmPrimitiveType::STRING);$metadata->addPrimitiveProperty($ContactsEntityType, 'primary_address_country', EdmPrimitiveType::STRING);$metadata->addPrimitiveProperty($ContactsEntityType, 'phone_mobile', EdmPrimitiveType::STRING);$metadata->addPrimitiveProperty($ContactsEntityType, 'phone_fax', EdmPrimitiveType::STRING);$metadata->addPrimitiveProperty($ContactsEntityType, 'birthdate', EdmPrimitiveType::DATETIME);$ContactsResourceSet = $metadata->addResourceSet('Contacts', $ContactsEntityType);return $metadata;}

首先初始化了metadata对象,继承基类ServiceBaseMetadata,为其添加实体Contacts

然后为实体添加属性,分别为上面我们定义的属性,除了id使用添加主键的方法addKeyProperty,其他调用addPrimitiveProperty函数,最后将实体Contacts加入实体集

 

然后我们看IDataServiceQuery Provider和IDataServiceQuery Provider2这里我们直接用IDataServiceQuery Provider2

首先定义MySQL配置

/** The name of the database for WordPress */
define('DB_NAME', 'SugarCRM');/** MySQL database username */
define('DB_USER', 'root');/** MySQL database password */
define('DB_PASSWORD', '');/** MySQL hostname */
define('DB_HOST', 'localhost');


在构造函数中连接数据库

public function __construct(){$this->_connectionHandle = @mysql_connect(DB_HOST, DB_USER, DB_PASSWORD, true);if ( $this->_connectionHandle ) {} else {             die(print_r(mysql_error(), true));} mysql_select_db(DB_NAME, $this->_connectionHandle);}


IDataServiceQuery Provider2中有5个方法,这里我们只用到两个

第一个是getResourceSet(ResourceSet $resourceSet,$filter=null,$select=null,$orderby=null,$top=null,$skip=null),这个函数返回经过过滤器筛选的结果

public function getResourceSet(ResourceSet $resourceSet,$filter=null,$select=null,$orderby=null,$top=null,$skip=null){ODataException::createNotImplementedError($this->_message);$resourceSetName =  $resourceSet->getName();if ($resourceSetName !== 'Contacts' ) {die('(SugarCRMQueryProvider) Unknown resource set ' . $resourceSetName);}$returnResult = array();switch ($resourceSetName) {case 'Contacts':$query = "SELECT * FROM `contacts`";if ($filter !== null) {$query .= " AND $filter";}$stmt = mysql_query($query); $returnResult = $this->_serializeContacts($stmt);     break;                   }mysql_free_result($stmt);return $returnResult;}


这里stmt为执行sql语句返回的结果,作为_serializeContacts函数的参数,_serializeContacts参数用于将结果传入一个Contacts对象中

    private function _serializeContacts($record){$contacts = new Contacts();$contacts->id = $record['id'];$contacts->first_name = $record['first_name'];$contacts->last_name = $record['last_name'];$contacts->phone_mobile = $record['phone_mobile'];$contacts->phone_fax = $record['phone_fax'];$contacts->primary_address_street = $record['primary_address_street'];$contacts->primary_address_city = $record['primary_address_city'];$contacts->primary_address_county = $record['primary_address_county'];if (!is_null($record['birthdate'])) {$dateTime = new DateTime($record['birthdate']);$contacts->birthdate = $dateTime->format('Y-m-d\TH:i:s');} else {$contacts->birthdate = null;}return $contacts;}


而getResourceFromResourceSet(ResourceSet $resourceSet, KeyDescriptor $keyDescriptor)则是带有关键字的查询

 public function getResourceFromResourceSet(ResourceSet $resourceSet, KeyDescriptor $keyDescriptor){ODataException::createNotImplementedError($this->_message);$resourceSetName =  $resourceSet->getName();if ($resourceSetName !== 'Contacts' ) {die('(WordPressQueryProvider) Unknown resource set ' . $resourceSetName);}$namedKeyValues = $keyDescriptor->getValidatedNamedValues();$condition = null;foreach ($namedKeyValues as $key => $value) {$condition .= $key . ' = ' . $value[0] . ' and ';}$len = strlen($condition);$condition = substr($condition, 0, $len - 5);$query = "SELECT * FROM [$resourceSetName] WHERE $condition";$stmt = mysql_query($query);if (!mysql_num_rows($stmt)) {return null;}$data = mysql_fetch_assoc($stmt);switch ($resourceSetName) {case 'Contacts':$result = $this->_serializeContacts($data);break;}mysql_free_result($stmt);return $result;}


 

其中$keyDescriptor->getValidatedNamedValues()返回关键字数组,然后用循环取得关键字及对应的值

 

下面改写IDataService,分别改写

public function getService($serviceType){if(($serviceType === 'IDataServiceMetadataProvider') || ($serviceType === 'IDataServiceQueryProvider2') ||($serviceType === 'IDataServiceStreamProvider')) {if (is_null($this->_SugarCRMExpressionProvider)) {$this->_SugarCRMExpressionProvider = new SugarCRMDSExpressionProvider();    			}    	}if ($serviceType === 'IDataServiceMetadataProvider') {if (is_null($this->_SugarCRMMetadata)) {$this->_SugarCRMMetadata = CreateSugarCRMMetadata::create();// $this->_SugarCRMMetadata->mappedDetails = CreateSugarCRMMetadata::mappingInitialize();}return $this->_SugarCRMMetadata;} else if ($serviceType === 'IDataServiceQueryProvider2') {if (is_null($this->_SugarCRMQueryProvider)) {$this->_SugarCRMQueryProvider = new SugarCRMQueryProvider();}return $this->_SugarCRMQueryProvider;} else if ($serviceType === 'IDataServiceStreamProvider') {return new SugarCRMStreamProvider();}return null;}// For testing we overridden the DataService::handleRequest method, one thing is the// private memeber variable DataService::_dataServiceHost is not accessible in this class,// so we are using getHost() below.public function handleRequest(){try {$this->createProviders();$this->getHost()->validateQueryParameters();$requestMethod = $this->getOperationContext()->incomingRequest()->getMethod();if ($requestMethod !== ODataConstants::HTTP_METHOD_GET) {ODataException::createNotImplementedError(Messages::dataServiceOnlyReadSupport($requestMethod));}} catch (\Exception $exception) {throw $exception;}$uriProcessor = null;try {$uriProcessor = UriProcessor::process($this);return $uriProcessor;} catch (\Exception $exception) {throw $exception;}}

这两个函数,将metadata,queryprovider连接起来。

下一步的测试还需要跟导师沟通,下周将进行初步的测试。

 

这篇关于三、odataproducer代码改写的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1074927

相关文章

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

MySQL实现多源复制的示例代码

《MySQL实现多源复制的示例代码》MySQL的多源复制允许一个从服务器从多个主服务器复制数据,这在需要将多个数据源汇聚到一个数据库实例时非常有用,下面就来详细的介绍一下,感兴趣的可以了解一下... 目录一、多源复制原理二、多源复制配置步骤2.1 主服务器配置Master1配置Master2配置2.2 从服

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据