`
kirenenko04
  • 浏览: 152125 次
  • 性别: Icon_minigender_2
  • 来自: 上海
社区版块
存档分类
最新评论

深入PrestaShop核心开发

 
阅读更多

1.数据库结构
表名都是以_ps前缀开头,这个可以再安装过程中进行指定
所有表名是小写的,单词用下划线_分割
当一个表建立了两个实体的连接,两个实体的名字会再表名中被提到,举个例子。
ps_category_product连接了商品和他们的分类

一些细节;
用id_lang 字段存储语言关联一条记录
用id_shop字段存储商店关联一条记录
表包含翻译必须用_lang结尾, 例如ps_product_lang包含所有关于ps_product表的翻译
表包含记录一个指定商店连接,必须以_shop结尾,例如,ps_category_shop包含每个类别取决于店面的位置。

0bjectModel类
这个主要对象,在Prestashp对象模型中,它可以被覆盖和预处理。

它是一个活动记录类型的类。
prestashop的数据库表属性或者视图属性是封装在类当中的,
因此,类是和数据库记录相关联的,在对象被初始化之后,一个记录被加到数据库中,
每一个对象检索它的数据。从数据库中,当一个对象被更新,被绑定的记录也会被更新,类实现存取每一个属性

定义一个model
你必须用$definition 静态变量来定义一个model
举例:

/**
* Example from the CMS model (CMSCore)
*/
public static $definition = array(
  'table' => 'cms',
  'primary' => 'id_cms',
  'multilang' => true,
  'fields' => array(
    'id_cms_category'  => array('type' => self::TYPE_INT, 'validate' => 'isUnsignedInt'),
    'position'         => array('type' => self::TYPE_INT),
    'active'           => array('type' => self::TYPE_BOOL),
    // Lang fields
    'meta_description' =>
        array('type' => self::TYPE_STRING, 'lang' => true, 'validate' => 'isGenericName', 'size' => 255),
    'meta_keywords'    =>
        array('type' => self::TYPE_STRING, 'lang' => true, 'validate' => 'isGenericName', 'size' => 255),
    'meta_title'       =>
        array('type' => self::TYPE_STRING, 'lang' => true, 'validate' => 'isGenericName', 'required' => true, 'size' => 128),
    'link_rewrite'     =>
        array('type' => self::TYPE_STRING, 'lang' => true, 'validate' => 'isLinkRewrite', 'required' => true, 'size' => 128),
    'content'          =>
        array('type' => self::TYPE_HTML,   'lang' => true, 'validate' => 'isString', 'size' => 3999999999999),
  ),
);

 一个model,对于许多商店或者语言

 

为了让一个对象可以用多语言

'multilang' => true

 为了让一个对象取决于当前商店

'multishop' => true

 为了让对象取决于当前商店,而且有多种语言

'multilang_shop' => true

 

主要方法:

任何覆盖的方法会影响到所有其他类和方法,小心使用:

Method name and parameters
Description

__construct($id = NULL, $id_lang = NULL)

建立对象

add($autodate = true, $nullValues = false)

保存当前对象到数据库(增加或更新)

associateTo(integer|array $id_shops)

关联一个项

delete()

删除当前对象,从数据库

deleteImage(mixed $force_delete = false)

删除对象关联的图片

deleteSelection($selection)

删除几个对象,从数据库

getFields()

为对象模型类准备字段

getValidationRules($className = _CLASS_)

返回对象验证规则(字段验证)

save($nullValues = false, $autodate = true)

保存当前对象到数据库(增加或者更新)

toggleStatus()

切换对象状态,在数据库中

update($nullValues = false)

更新当前对象到数据库

validateFields($die = true, $errorReturn = false)

在与数据库互动之前检查字段

 

DBQuery 类

DBQuery类是一个查询创建器,帮助你创建SQL查询,举例:

$sql = new DbQuery();
$sql->select('*');
$sql->from('cms', 'c');
$sql->innerJoin('cms_lang', 'l', 'c.id_cms = l.id_cms AND l.id_lang = '.(int)$id_lang);
$sql->where('c.active = 1');
$sql->orderBy('position');
return Db::getInstance()->executeS($sql);

 一些类的常用方法:

Method name and parameters
Description
where(string $restriction)

增加一个WHERE子句(每个控制条件将以AND分割)

string build() 生成或者给到一个查询
select(string $fields) 增加字段到查询的SELECT中
orderBy(string $fields) 增加一个排序字句
naturalJoin(string $table, string $alias = null) 增加一个自然连接
limit(string $limit, mixed $offset = 0) 限定查询结果行数
leftOuterJoin(string $table, string $alias = null, string $on = null)

增加一个左外连接

leftJoin(string $table, string $alias = null, string $on = null) 增加左连接
join(string $join)

增加join表连接

innerJoin(string $table, string $alias = null, string $on = null)

增加inner join 表连接

having(string $restriction)

增加HAVING子句(每一个约束讲以AND分割)

groupBy(string $fields) 增加GROUP子句
from(string $table, mixed $alias = null) 设定FROM子句
__toString() 生成SQL语句的字符串

 

路径

路径是1.5版本的特色功能之一,它控制URL的重定向,替代使用个目录下多个文件,例如product.php,order.php 或者category.php, 只有一个文件被使用:index.php, 从现在开始,内部URL会是这种样子:index.php?controller=category, index.php?controller=product, 等等

另外,路径支持URL重写,因此,当URL重写被关闭,prestaShop将使用以下格式的路径:

http://myprestashop.com/index.php?controller=category&id_category=3&id_lang=1
http://myprestashop.com/index.php?controller=product&id_product=1&id_lang=1

 如果开启了URL重写,(或者友好连接),PrestaShop的路径会支持像这样的格式

http://myprestashop.com/en/3-music-ipods
http://myprestashop.com/en/1-ipod-nano.html

 有这些优点:

很简单来增加一个controller

你可以用自定义路由规则来改变你的油耗连接(对于SEO更好)

只有一个单独的入口进入到软件内部,提高了prestashop的可靠性,更容易开发。

调节器使用了3个新的1.5的抽象类:Controller, FrontController和AdminController(后两个继承字第一个)

新的路由规则可以用覆盖loadRoutes()方法来创建

商店管理员可以改变一个controller的路径,使用"SEO & URLs" 页面,在后台,“Preference”菜单下

 

Controllers

在MVC结构中,一个controller管理同步化事件,在View和Model之间,保持他们同步更新,它接受所有用户事件和触发操作到前台展示。

如果一个操作需要数据被更新,控制器将 “告知” Model来更改数据,然后是Model通知View数据已经被改变,让View可以自我更新

 

所有PrestaShop的controller 确实覆盖了Controller类,通过其他继承类,比如说AdminController, ModuleAdminController,FrontController, 或者ModuleFrontController.

 

FrontController类

 

$template

页面内容的模板名.
$p 当前页数
$orderWay 降序或者升序排列.
$orderBy 按照哪个字段排序.
$n 每页显示的数量.
$js_files JS文件的数组.
$iso ISO 编码,当前选择则的语言.
$initialized init()方法是否被调用过.
$guestAllowed guest用户是否被允许访问本页.
$errors 错误信息的数组.
$css_files CSS文件的数组.

$ajax

Ajax参数被请求的,设置这个参数为true

执行controller方法的顺序

1.__contruct():配置所有控制器的成员变量

2.init():初始化控制器

3.setMedia() or setMobileMedia():增加所有JS和CSS脚本到页面,他们可以整合,压缩,缓存(请查看prestashop的CCC工具,在后台的“performance”页面,在Advanced preferences 菜单下面)

4.postProcess():控制ajax进程

5.initHeader(): 在initContent()之前

6.initContent(): 在initHeader()之后

7.initFooter():在initContent()之后

8.display() 或者 displayAjax():显示内容

 

本来存在的一些Controllers

Controller's filename
Description
AddressController.php 编辑一个客户的一个地址
AddressesController.php 编辑一个客户的多个地址
AuthController.php 处理用户登陆
BestSalesController.php 获取销售排行
CartController.php 管理用户的购物车
CategoryController 获取商品分类
CMSController.php 获取一个CMS页面
CompareController.php 比较商品.
ContactController.php 发送信息
DiscountController.php 获取一个用户的抵用券
GuestTrackingController.php 管理游客订单
HistoryController.php 获取一个客户订单
IdentityController.php 获取用户的信息
IndexController.php 显示首页
ManufacturerController.php 获取制造商
MyAccountController.php 管理用户账号
NewProductsController.php 获取新商品
OrderConfirmationController.php 订单确认
OrderController.php 管理五步结账流程
OrderDetailController.php 获取一个订单详细信息
OrderFollowController.php 获取一个用户的退货信息.
OrderOpcController.php 管理one-page结账流程.
OrderReturnController.php 获取一个制造商的退货信息.
OrderSlipController.php 获取一个客户的信用卡售货单
PageNotFoundController.php 管理“页面没找到”页面.
ParentOrderController.php 管理分享订单代码
PasswordController.php 重置丢失密码.
PricesDropController.php 获取打折的商品.
ProductController.php 获取一个商品.
SearchController.php 获取搜索结果.
SitemapController.php 获取 sitemap.
StoresController.php 获取商店信息
SupplierController.php

获取供应商

 

覆盖一个controller

多亏了对象继承,你可以更改controller的行为,或者增加一个新的

PrestaShop的控制器都被存放在/controllers目录下面, 而且使用“Core”后缀

举例:

    File: /controllers/CategoryController.php
    Class: CategoryControllerCore

 

 

为了覆盖一个controller,你必须先创建一个新的类,不包含Core后缀,然后放到/override/controllers目录下面

例如:

    File: /override/controllers/front/CategoryController.php
    Class: CategoryController

 

Views

PrestaShop使用Smarty模板引擎:http://www.smarty.net/

视图文件以.tpl保存

一个视图名通常和代码脚本名字一样例如404.php 使用404.tpl

View覆盖

因为没有继承,所以不能覆盖一个视图

为了换一个视图,你必须重写模板文件,而且把它放到你的主题目录下面

 

Cookies

Prestashop使用加密cookies,来存储所有会话信息,

对于访问者/客户端,也可以对于职员/管理人模式

Cookie类(/classes/Cookie.php)被用于读和写cookies

为了接近cookies,你可以用以下方式

$this->context->cookie;

 所有存储于cookie当中的变量可以这么访问

$this->context->cookie->variable;

 如果你需要使用PrestaShop cookie 从一个非Prestashop代码,你可以用以下代码:

include_once('path_to_prestashop/config/config.inc.php');
include_once('path_to_prestashop/config/settings.inc.php');
include_once('path_to_prestashop/classes/Cookie.php');
$cookie = new Cookie('ps'); // Use "psAdmin" to read an employee's cookie.

 被存储在访客/客户端的cookie数据:

viewed 以逗号形式分割最近访问过的商品ID
passwd 以MD5加密方式的_COOKIE_KEY_ 在config/settings.inc.php中配置,用户登陆后的密码
logged 用户是否已经登录
last_visited_category 最后访问的分类ID
id_wishlist 当前收藏夹,显示在收藏夹区域
id_lang 选中的语言ID
id_guest 未登录状态的游客ID
id_customer 登陆状态的顾客ID
id_currency 选择的货币ID
id_connections 当前访问者的会话连接ID
id_cart 当前购物车的ID
email 用户过去经常登录的Email地址
date_add cookie创建的时间
customer_lastname 客户的姓氏
customer_firstname 客户的名字
checksum 校验cookie是否被第三方修改,用户将注销,cookie会被清除,如果校验不匹配的话

checkedTOS 服务条款复选框是否被勾选(1:勾选。0:未勾选)
ajax_blockcart_display 购物车区块是展开的还是闭合的

存储于 职员/管理员中的cookie

date_add 创建的时间
id_lang 选中的语言
id_employee 职员的id
lastname 职员姓氏
firstname 职员名字
email 职员邮箱地址
profile 资料的ID,决定哪个TAB是职员可以访问的
passwd MD5加密的_COOKIE_KEY 在config/settings.inc.php中配置的,职员登陆用的密码
checksum 验证cookie是否有被第三方修改,如果验证不通过,会被登出,然后清除cookie

Hooks

Hooks 是用于关联你的代码到一些特殊的PrestaShop的事件

大多数时间,他们用于插入内容到一个页面

举个例子

PrestaShop默认主题的主页有以下Hooks

displayHeader 显示页面头部区域的内容.
displayTop 显示页面顶部区域的内容
displayLeftColumn 显示左侧边栏的内容
displayHome 显示中间区块的内容
displayRightColumn 显示右边栏的内容.
displayFooter

显示页脚的内容.

Hooks可以被用于显示特殊操作,(比如说发送一个邮件给客户)

使用Hooks

在一个controller内

调用一个hook在一个controller内,你只需要使用他的名字,用hookExce()方法

例如

$this->context->smarty->assign('HOOK_LEFT_COLUMN', Module::hookExec('displayLeftColumn'));

 

在module中,

为了绑定你的代码到一个hook上,你必须创建一个非静态共用方法,以hook关键字开始后边跟Display或者action还有你想取的名字

这个方法接受一个(只有一个)参数:一个数组。一个上下文信息要传送给hook的数组

public function hookDisplayNameOfHook($params)
{
    // Your code.
}

 

为了让一个module相应到一个hook的调用,hook必须被注册到prestaShop, hook注册可以用registerHook()方法,注册是将在模块安装的时候被完成

public function install()
{
    return parent::install() && $this->registerHook('NameOfHook');
}

 在主题内:

在一个tpl文件中,你只需要使用hook方法,你可以添加一个想要挂钩的module的名字。

{hook h='displayLeftColumn' mod='blockcart'}

 增加你自己的hook:

你可以增加一个新的PrestaShop钩子,用以下SQL语句

INSERT INTO `ps_hook` (`name`, `title`, `description`) VALUES ('nameOfHook', 'The name of your hook', 'This is a custom hook!');

但是你需要知道,在1.5版本中不需要这样做

现在当你的模块执行安装方法,你想要注册一个钩子。你可以这么做:

$this->registerHook('NameOfHook');

 

如果钩子”NameOfHook“ 不存在,PrestaShop将创建,没有必要执行SQL语句。

 

分享到:
评论

相关推荐

    微商城prestashop源代码

    在本文中,我们将详细介绍PrestaShop的核心特性、安装流程以及如何利用源代码进行二次开发。 首先,PrestaShop 1.7.1.1是该平台的一个稳定版本,它包含了多项改进和新功能,旨在提供更高效、更个性化的购物体验。这...

    prestashop后台添加功能

    本文将深入探讨如何在PrestaShop的后台添加自定义功能,这对于想要扩展平台功能或者定制化店铺的开发人员至关重要。 首先,理解PrestaShop的架构是关键。PrestaShop基于MVC(模型-视图-控制器)设计模式,这意味着...

    PHP实例开发源码-PrestaShop 网上购物系统.zip

    同时,PrestaShop还支持模块化开发,这意味着你可以添加或删除功能模块,以满足特定的商业需求。 在安全性方面,PrestaShop遵循最佳实践,比如使用预编译SQL语句防止SQL注入,对敏感数据进行加密,以及使用HTTPS...

    prestashop-978-1-7832-8025-4:PrestaShop模块开发

    通过学习《prestashop-978-1-7832-8025-4:PrestaShop模块开发》,开发者不仅可以掌握PrestaShop模块开发的核心技术,还能获得实战经验,为创建个性化的电商解决方案打下坚实基础。文件"prestashop-978-1-7832-8025-...

    PHP实例开发源码—PrestaShop 网上购物系统.zip

    PrestaShop的核心特性包括: 1. **易用性**:PrestaShop提供了一个直观的后台管理系统,使得非技术背景的商家也能轻松上手,进行商品添加、订单处理和店铺设置等操作。 2. **模板系统**:PrestaShop支持多种主题...

    PHP实例开发源码—开源的PHP网店系统 PrestaShop.zip

    【标题】"PHP实例开发源码—开源的PHP网店系统 PrestaShop.zip"涉及的核心知识点是PHP编程语言以及开源网店系统PrestaShop。PrestaShop是一款基于PHP技术构建的电子商务解决方案,它以其易用性、灵活性和丰富的功能...

    prestashop网店

    2. **PHP基础**:PrestaShop的核心是用PHP编写的,因此了解PHP语法、面向对象编程、MVC(模型-视图-控制器)架构以及PHP框架原理是必不可少的。PHP的特性,如错误处理、类与对象、数据库交互(如MySQLi或PDO),在...

    基于PHP的PrestaShop 网上购物系统.zip

    首先,我们来深入了解一下PrestaShop的核心特点和优势: 1. **开源免费**:PrestaShop遵循GNU General Public License(GPL)协议,这意味着任何人都可以免费下载、使用、修改和分发这个软件。 2. **易用性**:...

    基于PHP的开源的PHP网店系统 PrestaShop.zip

    以下是对PrestaShop核心知识点的详细介绍: 1. **PHP语言基础**:PrestaShop的构建基础是PHP,一种广泛使用的服务器端脚本语言,特别适合Web开发。了解PHP的基本语法、变量、数据类型、控制结构、函数和面向对象...

    基于PHP的PrestaShop网上购物系统源码.zip

    在实际的压缩包中,通常会包含各种PrestaShop的核心文件,如控制器、模板、语言文件、模块、主题、配置文件等。解压后,开发者会找到如`prestashop/`目录,其中包含`admin/`(后台管理界面)、`config/`(配置)、`...

    基于PHP的开源的PHP网店系统PrestaShop源码.zip

    首先,我们要了解PrestaShop的核心特点。它采用MVC(Model-View-Controller)设计模式,使得代码结构清晰,易于维护。模型负责处理业务逻辑,视图负责展示数据,控制器则作为两者之间的桥梁,实现了数据的交互。这种...

    商业源码-编程源码-PrestaShop v1.3.2.3.zip

    首先,让我们深入了解一下PrestaShop的核心特性: 1. **模块化架构**:PrestaShop基于模块化的架构设计,允许开发者轻松添加或移除功能。例如,可以通过安装支付网关模块来接受多种在线支付方式,或者通过安装物流...

    prestashop-vue:基于使用Vue.js进行渲染的Prestashop 1.7。*的主题。 自定义入门主题

    **Prestashop Vue 主题详解** Prestashop Vue 是一个创新的电子商务解决方案,...通过深入理解Prestashop Vue主题的结构和Vue.js的工作原理,开发者可以充分利用这个主题的优势,打造出更具吸引力和竞争力的在线商店。

    prestashop-retro:核心和产品团队的回顾

    本文将围绕“prestashop-retro”这一主题,深入探讨项目管理和团队协作的重要知识点,特别是针对核心团队和产品团队的回顾过程。 Prestashop是一款流行的开源电子商务解决方案,它为商家提供了构建在线商店的全面...

    PrestaShop-Canvas:PrestaShop的帆布

    PrestaShop-Canvas作为一款主题开发工具,它的核心价值在于提供一个模板框架,让开发者能够快速构建响应式、符合现代设计趋势的电商网站。Canvas提供了一系列预设的HTML、CSS和JavaScript文件,它们遵循PrestaShop的...

    Acumulus-for-PrestaShop:将您的PrestaShop网上商店连接到Acumulus的PrestaShop模块

    此模块的核心功能是实时同步PrestaShop的订单信息,包括产品、客户、地址和支付状态等,这些数据会被转换为Acumulus能识别的格式并发送。同步过程通常是自动的,也可以按需手动触发,以满足不同商家的需求。 5. **...

    ps-cli:PrestaShop的命令行界面

    **ps-cli:PrestaShop的命令行界面** 在PrestaShop的生态系统中,`ps-cli`扮演着一个至关重要的角色,它是一个强大的命令行工具,...对于希望深入PrestaShop开发的PHP程序员而言,掌握`ps-cli`是不可或缺的一项技能。

    prestashop-module-orders-export

    下面我们将深入探讨 PrestaShop、PHP 以及这个特定模块的相关知识点。 PrestaShop 是一个开源电子商务解决方案,它提供了丰富的功能来构建和管理在线商店。基于 PHP 开发,PrestaShop 具有用户友好的界面,易于安装...

    prestashop-978-1-8495-1172-8:PrestaShop 1.3主题-入门指南

    《PrestaShop 1.3主题-入门指南》是一本专为初学者设计的教程,旨在帮助读者深入了解和掌握PrestaShop电子商务平台的...随着学习的深入,你将具备开发专业级PrestaShop主题的能力,为你的电子商务业务增添竞争优势。

    prestashop1.7:ماژولپرستاشاپ1.7

    描述 "prestashop1.7:ماژولپرستاشاپ1.7" 与标题相呼应,暗示我们将深入探讨 PrestaShop 1.7 的模块系统。模块是 PrestaShop 中可添加的功能部件,可以增强商店的功能,如支付网关、配送选项、营销工具...

Global site tag (gtag.js) - Google Analytics