joomla 1.5 笔记
Joomla1.5 笔记
MVC结构
index.php?option=组件名&view=视图名&controller=控制器名&layout=视图分页名
index.php?option=com_test
模板和组件com_test的展示
index2.php?option=com_test
仅组件com_test的展示
组件开发需要在数据库添加记录,并以com_开头,组件分前台与后台,后台组件放在administrator/components下,前台组件放在components下。
Task是Controller下的分支,没有Task时用默认处理。
建立了View可以用 index.php?option=com_test&view=? 来显示,不需要写Controller,但必需有Controller存在
命名规则:
Controller
类名:控制器名Controller, 控制器名随时,但会影响View和Model的命名
文件名随时,由主文件调用
View
类名:控制器名View视图名
放在views目录下,以视图名作为目录名,主文件为view.html.php,模板页在tmpl下
Model
类名:控制器名Model视图名
放在models目录下,以视图名为文件名
Model:
继承JModel,所有以get开头的成员函数都作用参数。比如getXXX(), 从View中可以用$this->get('xxx')获取返回值
Controller:
JController成员名对应task名
常用功能
获得表单提交数据:
JRequest::getCmd( 'task' ); 过滤提交数据
JRequest::getInt('limit', 0); 取整型提交数据
JRequest::getVar('message', ''); 直接取提交数据
绑定模板数据:
view.html.php:
$this->assignRef('lists', 'value');
$mainframe (class JApplication):
$mainframe->getCfg('sitename'); 网站名
$mainframe->getCfg('mailfrom'); 管理员名
$mainframe->getCfg('fromname'); 邮箱
$mainframe->isSite() 判断是否前台
当前完整Url:
$uri = JFactory::getURI();
$uri->toString()
网站根地址:
JURI::base()
配置文件设置方法:
// Get the path of the configuration file
$fname = JPATH_CONFIGURATION.DS.'configuration.php';
// clear cache
$cache = JFactory::getCache();
$cache->clean();
// Update the credentials with the new settings
$config =& JFactory::getConfig();
$config->setValue('config.form_email', 'xxx');
// Get the config registry in PHP class format and write it to configuation.php
jimport('joomla.filesystem.file');
if (!JFile::write($fname, $config->toString('PHP', 'config', array('class' => 'JConfig')))) {
die(JText::_('ERRORCONFIGFILE'));
}
路由地址为HTML全地址:
JRoute::_( 'index.php?option=com_ccNewsletter' );
获得工厂对象:
$user =& JFactory::getUser(); 用户对象
$db =& JFactory::getDBO(); 数据操作对象
$document =& JFactory::getDocument(); 上下文对象
$lang =& JFactory::getLanguage(); 语言包对象
数据库对象操作:
$db =& JFactory::getDBO();
$db->setQuery($sql);
$db->loadObjectList(); 对象列表
$db->loadObject(); 一行对象
$db->loadResult(); 单个结果
$db->Quote(); 过滤敏感字
$db->query();
Document对象操作:
$document->addStyleSheet(url); 添加样式
$document->addScript(url); 添加脚本
语言对象操作:
$lang->_lang === 'en-GB' or $lang->_lang === 'zh-TW'
用户对象操作:
$user->get('guest') 是否登录,登录了返回false
$user->xxx 可以直接访问数据库中的字段,xxx为字段名
$user->setParam('xxx') 设置默认参数以外的参数
$user->getParam('xxx') 提取参数
获得组件的Menuid:
$menu = &JSite::getMenu();
$Items = $menu->getItems('link', 'index.php?option=com_idoblog&view=idoblog');
$Itemid=$Items[0]->id;
获得当前Menuid:
$menus = &JSite::getMenu();
$menu = $menus->getActive();
发送Email:
$sent = JUtility::sendMail(发送者邮箱, $contactname, 接收者邮箱, $subject, $body, true);
if (!$sent) {
$this->setError("Send email failed.");
}
Javascript弹出小窗口:
<a class="modal" href="/xx" rel="{handler: 'iframe', size: {x: 570, y: 350}}">xx</a>
JFolder用法:
JFolder::files($path, 'jpg|png|JPG|PNG', false, true); 指定目录下的文件列表
防止刷新提交:
view: <?php echo JHTML::_( 'form.token' ); ?>
controller: JRequest::checkToken() or jexit( 'Invalid Token' );
地址操作
给当前地址添加参数:
$uri = JFactory::getURI();
$uri->setQuery($uri->getQuery().'&lang=en');
$uri->toString()
JRoute::_("&limitstart=");
JHTML控件
日历:
JHTML::_('calendar', '1980-1-1', 'ielts_score_date', 'ielts_score_date', '%Y-%m-%d', array('class'=>'short', 'size'=>'25', 'maxlength'=>'19'))
日期显示:
JHTML::_('date', <data>, JText::_('DATE_FORMAT_LC2'));
载入脚本:
JHTML::script('upload.js', 'components/com_smipa/js/', false);
JTHML::Stylesheet('style.css', 'components/com_smipa/css/');
JHTML::_('behavior.mootools'); 载入mootools
JHTML::_('select.booleanlist', 'published','class="inputbox"', $item->published); //不能用于tinyint(1)类型
<input type="checkbox" name="custom_link" value="1" <?php echo $this->item->xxx?'checked="checked"':'' ?> /> //适用于tinyint(1)
JHTML::_('list.category', 'catid', $option, intval($item->catid));
JHTML::_('list.specificordering', $item, $item->id, $query,1);
JHTML::_('select.genericlist',$list,'postname',null,'id','title', 'default-value');
模块开发
$params->get("count", "0"); //在modules中获取参数
选择模板:
require JModuleHelper::getLayoutPath('mod_menu', 'default');
<jdoc:include type="head" /> //这句话引入了页面的header部分。
<jdoc:include type="modules" name="top" style="xhtml" /> //模块组位,name在xml文件上描述
<jdoc:include type="component" style="xhtml" /> //组件位
style是可选的,可选值定义在/templates/system/html/modules.php,能添加新的style
$this->countModules('left') //如果left有模块显示,则返回true
模块输出到任何位置:
$module = JModuleHelper::getModule('custom',$title);
echo JModuleHelper::renderModule($module);
模板位置:
----------------------------------
/templates/xxxx/index.php //模板页面,php和html描述
templateDetails.xml //模板结构描述
/element/template_thumbnail.png //140*90的截图
/element/css/template_css.css //模板CSS
---------------------------------
模板配置文件:
<files> 部分包含模板涉及到的重要文档
<images> 部分包含涉及到的图片文件
<css> 部分是css文件
<languages> 不用说是语言文件
<positions> 定义了模板中的模块位置
<params> 模板中的参数
<filename>params.ini</filename>
<folder>images/</folder>
$this->baseurl
$this->language;
$this->params->get('widthStyle') //在视图中获取参数
$this->template //当前模板名
$user= JFactory::getUser();
自定义模块style:
function modChrome_{style_name}($module, &$params, &$attribs)
{
$url = isset($attribs['url']) ? $attribs['url'] : '#'; //接收参数
if (!empty ($module->content)) : ?>
<div class="moduletable<?php echo $params->get('moduleclass_sfx'); ?>">
<?php if ($module->showtitle != 0) : ?>
<h3><?php echo $module->title; ?><a href="/<?php echo $url ?>">Read More</a></h3>
<?php endif; ?>
<?php echo $module->content; ?>
</div>
<?php endif;
}
插件开发
插件在plugins目录里以插件类型命名的目录下。每个类型都有个example.php的例子可以作为建立插件类与事件处理的参考。
XML参数
参数类型:
<param name="" type="text" default="" label="" description="" />
<param name="" type="radio" default="" label="" description="">
<option value=""></option>
</param>
<param name="" type="list" default="" label="" description="">
<option value="">Use Global</option>
</param>
<param name="description" type="textarea" default="" label="Description" description="" rows="5" cols="30" />
在非文章组件/模块内调用分类参数
<params addpath="libraries/joomla/html/parameter/element/category">
<param name="catid" type="category" label="Category" description="Choose a category..." />
...
</params>
组件参数取值方法:
global $mainframe;
$params =& $mainframe->getParams('com_xxx');
$params->get(key)
$cparams =& JComponentHelper::getParams('com_media');
Component参数(基于组件,即option的值):
位置: 组件后台根目录下的config.xml
后台设置点: 在menus里选中组件类型后可以设置
JToolBarHelper::preferences('com_xxx')
Basic参数(基于Menu,即Itemid的值):
位置: 安装包XML,写在<params>节点
前台view/tmpl下,与layout同名的XML,可参考con_content的XML
后台设置点: 在menus里选中组件类型后可以设置
后台组件功能开发
配置组件后台子级菜单:
-------------------------
安装组件包前,在后台组件的安装XML里修改submenu节点,安装后会自动在menu与组件节点添加对面的名称。安装组件包后如有修改需求,可以在#__component表中修改submenu
-------------------------
工具栏(ToolBar):
-----------------------------
JHTML::_('behavior.tooltip'); 启动toolbar
JToolBarHelper::title(JText::_('Newtech'), 'generic.png');
JToolBarHelper::save();
JToolBarHelper::custom('publish', 'publish', '', JText::_( 'CC_ENABLED' ), true);
JToolBarHelper::preferences('com_xxx'); 参数设置,对应config.xml
JToolBarHelper::customX(<task>, 'new.png', 'new.png', 'Create', false);
---------------------------
controller中:
------------------------
$this->setRedirect( 'index.php?option=com_ccNewsletter&controller=newsletter', $msg );// 页面跳转
JController->getModel(); // 得到对应的model实例,可以获得组件所有model
model中:
---------------------------
JModel->getTable 获得表实例,只可以获得对应的table
table中:
-------------------------------
$post = JRequest::get("post");
JTable->bind($post); //对应POST数据更新表
JTable->check(); //检查数据的正确性
JTable->store(); //把数据表写入到数据库
view中:
------------------------------
JView->getModel 只可以获得对应的model
JView->get("xxx") 调用对应model的方法
------------------------------
加在后台模板中的验证脚本:
<script type="text/javascript">
function submitbutton(pressbutton) {
var form = document.adminForm;
if (pressbutton == 'cancel') {
submitform( pressbutton );
return;
}
email = form.mail.value;
pattern = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/;
flag = pattern.test(email);
if(!flag)
{
alert("Invalid Email");
return;
}
submitform(pressbutton);
}
</script>
多语言 (language)
多语言包注意事项:
JText::_("")函数会把字串转成大写再搜索语言包中的字串,如果找不到对应的语言包,就会原样输出。
权限管理 (ACL)
添加权限
JAuthorization::addACL(访问资源节点(组件), 访问资源(具体权限), 访问对象节点(users), 访问对象(组))
验证权限
JUser::authorize(访问资源节点(组件), 访问资源(具体权限))
添加新的权限
61行: libraries/joomla/user/authorization.php
后台菜单权限验证
34行: administrator/modules/mod_menu/help.php
组件后台验证一般写在组件入口中,如admin.frontpage.php
组件前台验证一般写在view.html.php中
加载juqery.js
把jquery copy到media/system/js下
调用JHTML::script('jquery.js');
自定义事件 (event)
以VM插件为例
把插件安装包XML中group="vm"
插件代码:
jimport( 'joomla.plugin.plugin' );
$mainframe->registerEvent( 'onEventType', 'plgFunction' );
function plgFunction(){
// 处理过程
}
触发事件
JPluginHelper::importPlugin('vm');
$dispatcher =& JDispatcher::getInstance();
$dispatcher->trigger('onEventType'); // 触发onEventType事件
sh404sef
应该在页面和参数都调好后再开sh404sef,如果因为sh404sef生成错误地址所影响,可以在后台查询地址路径再修改。
h2:
sh404sef默认把h1标签改成h2,这个要在后台设置。
404:
sh404sef安装后会自动新建404的文章页,当找不到页面会自动跳到404文章页。但默认没有指定Itemid,可能页面会受影响,可以在后台高级设置页上修改以下参数:
$shDefaultParams['sh404SEF_PAGE_NOT_FOUND_FORCED_ITEMID'] = 0;
page title:
开了sh404sef后page title需要在sh404sef的配置中设置,比如首页的title,要在URL Manager中的Home page Meta处修改
局部关闭sef:
以virtuemart为例
components/com_sh404sef/sef_ext/com_virtuemart.php
在对应的case支点最下方(即break之上)加上 $dosef = false;
.号替换:
URL最尾带后缀会使rewrite不生效,所以404后台配置需要把.替换掉。例如: .|-
地址出现中文:
由于sh404sef默认使用title作为URL,对于中文网站也将使用中文title为URL,这样就会生成中文URL,解决方法是把Use Title Alias, Use category alias, Use section alias, Use menu alias全部选上。
VM 结构
vm的page是页面逻辑部分,template是视图部分,func是业务逻辑部分
可以通过URL的page参数找到对应的page程序,阅读代码可以找到template的准确位置
有关功能性程序,可以跟据页面代码中找到form中的func参数,之后利用后台List Modules功能找到代码。
比如:
1: 从页面的form找到参数,func = orderStatusSet
2: 到后台的List Modules找到与订单相关的order Module
3: 点击order Module的function list,找到记录如下:
Function Name: orderStatusSet
Class Name: ps_order
Class Method: order_status_update
4: 找到ps_order.php,这个是ps_order类的代码,里面能找到方法order_status_update,就是我们要修改的代码部分。
page的位置:
administrator/components/com_virtuemart/html/
template的位置:
com_virtuemart/themes/default/templates/
class的位置:
administrator/components/com_virtuemart/classes/
VM 设置问题
paypal接口调试模式:
后台 > Store > List Payment Methods > PayPal > Configuration
修改为:
$url = "https://www.sandbox.paypal.com/cgi-bin/webscr";
后台的List Modules可以针对几种用户进行功能设置,比如可以把帐户分成管理员与仓库管理员。
VM有子产品概念,可以实现不同属性不同价格。要添加子产品必须先Add Attribute。
VM 模板位置
Featured Products模板:
components/com_virtuemart/themes/default/templates/common/featuredProducts.tpl.php
分页模板:
administrator/components/com_virtuemart/classes/pageNavigation.class.php
产品列表页模板(可添加)
Category Browse Page:
components/com_virtuemart/themes/default/templates/browse/Browse_x.php
产品内容页模板(可添加)
Category Flypage:
components/com_virtuemart/themes/default/templates/product_details/flypage_x.php
components/com_virtuemart/themes/default/theme.php
输出附件缩略图片,不包含原图,flypage_images.tpl依赖于此函数
function vmlistAdditionalImages( $product_id, $images, $title='', $limit=1000 )
产品列表默认次序修改:
23行: administrator/components/com_virtuemart/html/shop_browse_queries.php
VM email
Ask a question about this product
咨询邮件内容(客户):
VM语言包common
VM_ENQUIRY_SHOPPER_EMAIL_MESSAGE
咨询邮件内容(店主):
VM语言包common
VM_ENQUIRY_VENDOR_EMAIL_MESSAGE
咨询邮件模板:
components/com_virtuemart/themes/default/templates/order_emails/enquiry_email.tpl.php
Checkout邮件:
components/com_virtuemart/themes/default/templates/order_emails/confirmation_email.tpl.php
订单更新状态邮件:
365行: administrator/components/com_virtuemart/classes/ps_order.php