


PHP Master | OXID eSales - The E-Commerce Platform that Just Works! 2
Feb 24, 2025 am 10:25 AMThis article explores OXID eSales, a robust e-commerce platform, focusing on its theming system and customization capabilities. Part one introduced the platform; this part delves into theme creation and modification.
Key Concepts:
- OXID eSales is a high-quality, easily extensible e-commerce solution leveraging the Smarty template engine for theme development. This allows for PHP-like syntax within templates.
- Themes in OXID manage data from the business logic layer (core libraries, modules, extensions). They can be built from scratch or extended from existing themes like the default "Azure" theme.
- Customization options are extensive, ranging from logo changes and element removal to adding user profile content. This is achieved by modifying templates and interacting with OXID template objects.
- OXID's modular architecture, multi-language and currency support, and robust security features make it suitable for diverse businesses.
- A future installment will cover custom module creation for advanced customization.
Understanding OXID Themes:
OXID themes function similarly to those in other applications. They allow developers and designers to manipulate data accessed through core libraries, custom modules, and extensions. The Smarty engine enables PHP-like syntax and full PHP core access if needed.
The following header.tpl
snippet illustrates Smarty tags within HTML:
<code>[{assign var="slogoImg" value="logo.png"}] <a href="http://miracleart.cn/link/0b49b88c68f7ecbdb73f50496c084a1e" id="logo"> </a> <img src="/static/imghw/default1.png" data-src="https://img.php.cn/" class="lazy" alt="PHP Master | OXID eSales - The E-Commerce Platform that Just Works! 2">oxshops__oxtitleprefix->value}]"> [{oxid_include_widget cl="oxwCategoryTree" cnid=$oView->getCategoryId() sWidgetType="header" _parent=$oView->getClassName() nocookie=1}] [{if $oxcmp_basket->getProductsCount()}] [{assign var="blAnon" value=0}] [{assign var="force_sid" value=$oViewConf->getSessionId()}] [{else}] [{assign var="blAnon" value=1}] [{/if}] [{oxid_include_widget cl="oxwMiniBasket" nocookie=$blAnon force_sid=$force_sid}] [{include file="widget/header/search.tpl"}] [{if $oView->getClassName()=='start' && $oView->getBanners()|@count > 0 }] <div class="oxSlider"> [{include file="widget/promoslider.tpl" }] </div> [{/if}]</code>
OXID provides custom Smarty plugins under /core/smarty/plugins
. The example above demonstrates conditional logic, template inclusion, and widget usage (oxwCategoryTree
, oxwMiniBasket
). Database access is achieved via magic methods on OXID objects (e.g., $oxcmp_shop->oxshops__oxtitleprefix->value
).
Theme File Structure (CE 4.7 , PE/EE 5.0 ):
-
/application/views/<theme>/</theme>
: Templates, translations, configuration files. -
/out/<theme>/</theme>
: Public files (CSS, JavaScript, images).
Creating a Custom Theme ("sitepoint"):
We'll extend the "Azure" theme. Create application/views/sitepoint/theme.php
:
<code>[{assign var="slogoImg" value="logo.png"}] <a href="http://miracleart.cn/link/0b49b88c68f7ecbdb73f50496c084a1e" id="logo"> </a> <img src="/static/imghw/default1.png" data-src="https://img.php.cn/" class="lazy" alt="PHP Master | OXID eSales - The E-Commerce Platform that Just Works! 2">oxshops__oxtitleprefix->value}]"> [{oxid_include_widget cl="oxwCategoryTree" cnid=$oView->getCategoryId() sWidgetType="header" _parent=$oView->getClassName() nocookie=1}] [{if $oxcmp_basket->getProductsCount()}] [{assign var="blAnon" value=0}] [{assign var="force_sid" value=$oViewConf->getSessionId()}] [{else}] [{assign var="blAnon" value=1}] [{/if}] [{oxid_include_widget cl="oxwMiniBasket" nocookie=$blAnon force_sid=$force_sid}] [{include file="widget/header/search.tpl"}] [{if $oView->getClassName()=='start' && $oView->getBanners()|@count > 0 }] <div class="oxSlider"> [{include file="widget/promoslider.tpl" }] </div> [{/if}]</code>
Create /out/sitepoint/img
and /out/sitepoint/src
, adding theme.jpg
and a modified logo.png
. Activate the theme in the admin panel. Clear the /tmp
directory to clear OXID's cache.
Customization Examples:
-
Logo Change: Replacing
logo.png
updates the logo. -
Removing Image Scroller: Removing the relevant code block from
application/views/sitepoint/tpl/layout/header.tpl
(copied fromazure
). -
Adding User Profile Content: Modifying
application/views/sitepoint/tpl/page/account/dashboard.tpl
and adding translations inapplication/views/sitepoint/de/cust_lang.php
andapplication/views/sitepoint/en/cust_lang.php
.
Conclusion:
This guide demonstrates OXID's theming system, enabling straightforward customization. Part 3 will explore custom module development for advanced customization.
(Note: Image URLs are assumed to be correctly functional within the original context. They are retained in the output as requested.)
The above is the detailed content of PHP Master | OXID eSales - The E-Commerce Platform that Just Works! 2. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

ToversionaPHP-basedAPIeffectively,useURL-basedversioningforclarityandeaseofrouting,separateversionedcodetoavoidconflicts,deprecateoldversionswithclearcommunication,andconsidercustomheadersonlywhennecessary.StartbyplacingtheversionintheURL(e.g.,/api/v

TosecurelyhandleauthenticationandauthorizationinPHP,followthesesteps:1.Alwayshashpasswordswithpassword_hash()andverifyusingpassword_verify(),usepreparedstatementstopreventSQLinjection,andstoreuserdatain$_SESSIONafterlogin.2.Implementrole-basedaccessc

PHPdoesnothaveabuilt-inWeakMapbutoffersWeakReferenceforsimilarfunctionality.1.WeakReferenceallowsholdingreferenceswithoutpreventinggarbagecollection.2.Itisusefulforcaching,eventlisteners,andmetadatawithoutaffectingobjectlifecycles.3.YoucansimulateaWe

Proceduralandobject-orientedprogramming(OOP)inPHPdiffersignificantlyinstructure,reusability,anddatahandling.1.Proceduralprogrammingusesfunctionsorganizedsequentially,suitableforsmallscripts.2.OOPorganizescodeintoclassesandobjects,modelingreal-worlden

To safely handle file uploads in PHP, the core is to verify file types, rename files, and restrict permissions. 1. Use finfo_file() to check the real MIME type, and only specific types such as image/jpeg are allowed; 2. Use uniqid() to generate random file names and store them in non-Web root directory; 3. Limit file size through php.ini and HTML forms, and set directory permissions to 0755; 4. Use ClamAV to scan malware to enhance security. These steps effectively prevent security vulnerabilities and ensure that the file upload process is safe and reliable.

Yes, PHP can interact with NoSQL databases like MongoDB and Redis through specific extensions or libraries. First, use the MongoDBPHP driver (installed through PECL or Composer) to create client instances and operate databases and collections, supporting insertion, query, aggregation and other operations; second, use the Predis library or phpredis extension to connect to Redis, perform key-value settings and acquisitions, and recommend phpredis for high-performance scenarios, while Predis is convenient for rapid deployment; both are suitable for production environments and are well-documented.

In PHP, the main difference between == and == is the strictness of type checking. ==Type conversion will be performed before comparison, for example, 5=="5" returns true, and ===Request that the value and type are the same before true will be returned, for example, 5==="5" returns false. In usage scenarios, === is more secure and should be used first, and == is only used when type conversion is required.

TostaycurrentwithPHPdevelopmentsandbestpractices,followkeynewssourceslikePHP.netandPHPWeekly,engagewithcommunitiesonforumsandconferences,keeptoolingupdatedandgraduallyadoptnewfeatures,andreadorcontributetoopensourceprojects.First,followreliablesource
