magento api分页获取最近更新订单的方法

2,926次阅读
没有评论

共计 4969 个字符,预计需要花费 13 分钟才能阅读完成。

首先创建文件test.php,代码如下(其中$page为当前页码,$size为每页记录数):

[php]

$url = ‘http://127.0.0.1/magento/api/soap/?wsdl’;
 $appKey = ‘API账号’;
 $appSecret = ‘API密码’;
 $client = new SoapClient($url, array("trace" => true, "connection_timeout" => 600));
 $sessionKey = $client->login($appKey,$appSecret);
 $filterData = array(array(‘page’=>$page,’page_size’=>$size,’updated_at’=>array(‘from’=>$start, ‘to’=>$end)));
 $Res = $client->call($sessionKey,’sales_order.list’,$filterData);
 $total = $Res[‘total’];
 for ($i = 0; !empty($Res[$i]); $i++) {

……
 }

[/php]

然后还要修改magento的API文件app/code/core/Mage/Sales/Model/Order/Api.php为如下所示:

[php]

/**
     * Retrieve list of orders by filters
     *
     * @param array $filters
     * @return array
     */
    public function items($filters = null)
    {
        //TODO: add full name logic
        $billingAliasName = ‘billing_o_a’;
        $shippingAliasName = ‘shipping_o_a’;

        $collection = Mage::getModel("sales/order")->getCollection()
            ->addAttributeToSelect(‘*’)
            ->addAddressFields()
            ->addExpressionFieldToSelect(
                ‘billing_firstname’, "{{billing_firstname}}", array(‘billing_firstname’=>"$billingAliasName.firstname")
            )
            ->addExpressionFieldToSelect(
                ‘billing_lastname’, "{{billing_lastname}}", array(‘billing_lastname’=>"$billingAliasName.lastname")
            )
            ->addExpressionFieldToSelect(
                ‘shipping_firstname’, "{{shipping_firstname}}", array(‘shipping_firstname’=>"$shippingAliasName.firstname")
            )
            ->addExpressionFieldToSelect(
                ‘shipping_lastname’, "{{shipping_lastname}}", array(‘shipping_lastname’=>"$shippingAliasName.lastname")
            )
            ->addExpressionFieldToSelect(
                    ‘billing_name’,
                    "CONCAT({{billing_firstname}}, ‘ ‘, {{billing_lastname}})",
                    array(‘billing_firstname’=>"$billingAliasName.firstname", ‘billing_lastname’=>"$billingAliasName.lastname")
            )
            ->addExpressionFieldToSelect(
                    ‘shipping_name’,
                    ‘CONCAT({{shipping_firstname}}, " ", {{shipping_lastname}})’,
                    array(‘shipping_firstname’=>"$shippingAliasName.firstname", ‘shipping_lastname’=>"$shippingAliasName.lastname")
            );

        if (is_array($filters)) {
            try {
                foreach ($filters as $field => $value) {
                    if ($field != ‘page’ && $field != ‘page_size’) {
                    if (isset($this->_attributesMap[‘order’][$field])) {
                        $field = $this->_attributesMap[‘order’][$field];
                    }

$collection->addFieldToFilter($field, $value);
                    }
                }
            } catch (Mage_Core_Exception $e) {
                $this->_fault(‘filters_invalid’, $e->getMessage());
            }
        }

$result = array();

  $result[‘total’] = $collection->count();

        $collection = Mage::getModel("sales/order")->getCollection()
            ->addAttributeToSelect(‘*’)
            ->addAddressFields()
            ->addExpressionFieldToSelect(
                ‘billing_firstname’, "{{billing_firstname}}", array(‘billing_firstname’=>"$billingAliasName.firstname")
            )
            ->addExpressionFieldToSelect(
                ‘billing_lastname’, "{{billing_lastname}}", array(‘billing_lastname’=>"$billingAliasName.lastname")
            )
            ->addExpressionFieldToSelect(
                ‘shipping_firstname’, "{{shipping_firstname}}", array(‘shipping_firstname’=>"$shippingAliasName.firstname")
            )
            ->addExpressionFieldToSelect(
                ‘shipping_lastname’, "{{shipping_lastname}}", array(‘shipping_lastname’=>"$shippingAliasName.lastname")
            )
            ->addExpressionFieldToSelect(
                    ‘billing_name’,
                    "CONCAT({{billing_firstname}}, ‘ ‘, {{billing_lastname}})",
                    array(‘billing_firstname’=>"$billingAliasName.firstname", ‘billing_lastname’=>"$billingAliasName.lastname")
            )
            ->addExpressionFieldToSelect(
                    ‘shipping_name’,
                    ‘CONCAT({{shipping_firstname}}, " ", {{shipping_lastname}})’,
                    array(‘shipping_firstname’=>"$shippingAliasName.firstname", ‘shipping_lastname’=>"$shippingAliasName.lastname")
            );

        if (is_array($filters)) {
            try {
                foreach ($filters as $field => $value) {
                    if ($field != ‘page’ && $field != ‘page_size’) {
                    if (isset($this->_attributesMap[‘order’][$field])) {
                        $field = $this->_attributesMap[‘order’][$field];
                    }

$collection->addFieldToFilter($field, $value);
                    }
                }
            } catch (Mage_Core_Exception $e) {
                $this->_fault(‘filters_invalid’, $e->getMessage());
            }
        }
        if (is_array($filters) && $filters[‘page’] && $filters[‘page_size’]) {
   $collection->setPage($filters[‘page’]);
   $collection->setPageSize($filters[‘page_size’]);
        }

foreach ($collection as $order) {
            $result[] = $this->_getAttributes($order, ‘order’);
        }

return $result;
    }

[/php]

正文完
 0
评论(没有评论)

空瓶子部落

文章搜索
推荐阅读
马斯洛需求层次理论,早已被更新

马斯洛需求层次理论,早已被更新

01 认识马斯洛需求层次理论及其缺陷。 很多人都知道亚伯拉罕·马斯洛(Abraham Maslow)的需求层次...
现场可视化管理手册

现场可视化管理手册

设施涂色标准 厂房涂色标准 厂房围栏:采用耐候性极强的深蓝色或墨绿色涂料,这两种颜色不仅美观大方,易于从远处识...
解决问题的高手:重实践的丰田,重策略的麦肯锡

解决问题的高手:重实践的丰田,重策略的麦肯锡

在解决问题上,丰田和麦肯锡堪称行业的先驱,在业界享有盛誉。 丰田的方法更注重实际操作和持续改进,他们就像是在车...
华为干部管理七步曲

华为干部管理七步曲

华为干部管理七步曲 1.明确使命与责任:干部需践行和传承公司核心,价值观,聚焦客户需求,抓业务增长,同时开展端...
最新文章
群晖 Let’s Encrypt 泛域名证书自动更新

群晖 Let’s Encrypt 泛域名证书自动更新

目前acme协议版本更新,开始支持泛域名(wildcard),也就是说,可以申请一个类似*.domain.co...
可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

可以卸载TV Box 了,这款支持「绅士模式」的影视神器你值得拥有

还在为找优秀片源难、广告多、平台会员太贵而烦恼?今天给大家挖到一款真正的影视宝藏工具——小猫影视! 作为开源免...
【收藏】一次性解决TV点播/直播自由

【收藏】一次性解决TV点播/直播自由

很多时候,资源就在面前,但是我们视而不见,因为长久的安逸,已经让人失去动手的兴趣。但是每次我需要挨个切换APP...
OpenWrt 存储空间扩容的两种方案

OpenWrt 存储空间扩容的两种方案

说明:当我们通过群晖 VMM 虚拟机安装 Open­Wrt 时,默认会分配一个 10GB 的存储空间,而实际情...
OpenWrt修改IP地址两种方法(直接命令修改跟后台修改)

OpenWrt修改IP地址两种方法(直接命令修改跟后台修改)

OpenWrt是什么?OpenWrt一般常见于无线路由器(软路由)第三方固件,它是一个高效、可靠、功能多的路由...
热门文章
提高过程能力指数(CP/CPK)的途径

提高过程能力指数(CP/CPK)的途径

编者按:过程能力指数(CP/CPK)想必各位质量人都耳熟能详、运用自如,质量工程师之家前期也共享过数篇关于过程...
SPC控制图的八种模式分析

SPC控制图的八种模式分析

SPC控制图有八种模式,即八种判断异常的检验准则,每一种检验准则代表一种异常现象,应用SPC控制图进行过程评估...
测量高手放大招:圆跳动测量技巧总结

测量高手放大招:圆跳动测量技巧总结

01. 前言 在五金机加工厂实际的测量工作中,经常碰到要求测量两个要素的圆跳动问题, 利用不同的测量辅件及夹具...
过程能力分析(CP&cpk)

过程能力分析(CP&cpk)

引入过程能力分析的目的? 在我们现有的管理过程中,我们经常会遇到有些具体指标总是不尽人意,存在许多需要改进的地...
新能源汽车 “两会”精神宣贯会

新能源汽车 “两会”精神宣贯会

此次和大家分享新能源汽车相关政策: [embeddoc url=”https://www.ctro...
最新评论
多乐士 多乐士 通过摸索发现ssh拉取会报错,直接网页访问下载会报404错误,不知道原因;但是可以通过群晖CM注册表访问下载,其方法如下: Container Manager-注册表-设置-新增-注册表名称随便写,注册表URL填你的加速地址,勾选信任的SSL自我签署证书,登录信息不填-应用-使用你的地址,这是注册表会显示了,在搜索栏中输入映像名称,搜索结果在每一页的最后一个,你需要划到最后一个进行下载,实测可正常下载安装。 以上供网友参考。
多乐士 多乐士 还有一个比较简单的方法,只是需要一些外部工具。 1、讲损毁硬盘取出,装入外部移动硬盘 2、打开Diskgenius,定位到硬盘 3、格式化系统分区 4、重新插入硬盘 5、存储池->修复存储池即可
多乐士 多乐士 写的不错的文章
辞了老衲 辞了老衲 这个确实有帮助。
渋驀 渋驀 当然任何时候都可以用curl命令和crontab来实现动态更新DDNS的ip地址: 1、安装crontab之后为root用户创建文件/var/spool/cron/root 2、创建并配置ddnsupdate.sh,放到/usr/bin/文件下,文件内容(以he.net为例): Autodetect my IPv4/IPv6 address: IPV4:curl -4 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" IPV6:curl -6 "http://dyn.example.com:password@dyn.dns.he.net/nic/update?hostname=dyn.example.com" 3、添加执行权限chomod +x /usr/bin/ddnsupdate.sh 4、编辑root用户的crontab:*/10 * * * * /usr/binddnsupdate.sh,每10分钟执行一次。好了,可以享受你的DDNS了
21410 21410 请问下载链接在那里?
madkylin madkylin 不错,不错,谢谢分享了,好东西啊 :lol:
feilung feilung 求方法
zengsuyi zengsuyi 应该挺不错的
zise zise 看看是怎么操作的。。 :oops: