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

相关文章

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

IIS 7.0 及更高版本中的 FTP 状态代码

《IIS7.0及更高版本中的FTP状态代码》本文介绍IIS7.0中的FTP状态代码,方便大家在使用iis中发现ftp的问题... 简介尝试使用 FTP 访问运行 Internet Information Services (IIS) 7.0 或更高版本的服务器上的内容时,IIS 将返回指示响应状态的数字代

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元