三、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

相关文章

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(

JAVA利用顺序表实现“杨辉三角”的思路及代码示例

《JAVA利用顺序表实现“杨辉三角”的思路及代码示例》杨辉三角形是中国古代数学的杰出研究成果之一,是我国北宋数学家贾宪于1050年首先发现并使用的,:本文主要介绍JAVA利用顺序表实现杨辉三角的思... 目录一:“杨辉三角”题目链接二:题解代码:三:题解思路:总结一:“杨辉三角”题目链接题目链接:点击这里

SpringBoot使用注解集成Redis缓存的示例代码

《SpringBoot使用注解集成Redis缓存的示例代码》:本文主要介绍在SpringBoot中使用注解集成Redis缓存的步骤,包括添加依赖、创建相关配置类、需要缓存数据的类(Tes... 目录一、创建 Caching 配置类二、创建需要缓存数据的类三、测试方法Spring Boot 熟悉后,集成一个外

轻松掌握python的dataclass让你的代码更简洁优雅

《轻松掌握python的dataclass让你的代码更简洁优雅》本文总结了几个我在使用Python的dataclass时常用的技巧,dataclass装饰器可以帮助我们简化数据类的定义过程,包括设置默... 目录1. 传统的类定义方式2. dataclass装饰器定义类2.1. 默认值2.2. 隐藏敏感信息

opencv实现像素统计的示例代码

《opencv实现像素统计的示例代码》本文介绍了OpenCV中统计图像像素信息的常用方法和函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 统计像素值的基本信息2. 统计像素值的直方图3. 统计像素值的总和4. 统计非零像素的数量

IDEA常用插件之代码扫描SonarLint详解

《IDEA常用插件之代码扫描SonarLint详解》SonarLint是一款用于代码扫描的插件,可以帮助查找隐藏的bug,下载并安装插件后,右键点击项目并选择“Analyze”、“Analyzewit... 目录SonajavascriptrLint 查找隐藏的bug下载安装插件扫描代码查看结果总结Sona

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

Java实现批量化操作Excel文件的示例代码

《Java实现批量化操作Excel文件的示例代码》在操作Excel的场景中,通常会有一些针对Excel的批量操作,这篇文章主要为大家详细介绍了如何使用GcExcel实现批量化操作Excel,感兴趣的可... 目录前言 | 问题背景什么是GcExcel场景1 批量导入Excel文件,并读取特定区域的数据场景2