Magento模块开发 第一部分

1.模块配置文件
基本的模块配置文件有2个,一个是etc下面的config.xml, 还有一个在app/etc/modules下面,以YourPackageName_ YourModuleName.xml命名。
Magento里面的模块都属于不同的包(Package), 每个包又分属于不同的代码池中(Code Pool)。Magento 中的 代码池有core, community和local三个,一般开发的模块放在local代码池中。 也就是在local下的以包名字命名的文件夹中。local/PackageName/ModuleName。

先看下YourPackageName_ YourModuleName.xml。这个配置文件内容很少,主要说明模块所在的代码池和依赖的模块信息。以下PackgeName 用P简写, MouldeName 用 M来简写。

<?xml version="1.0"?>
<config>
    <modules>
        <P_M>
            <active>true</active>
            <codePool>local</codePool>
        </P_M>
    </modules>
</config>


将这个xml配置文件保存到app/etc/modules目录下,文件名为P_M.xml。

进入Magento的管理后台,刷新缓存,然后在 System/Configuration/Advanced下面应该可以看到刚才创建的模块P_M, 并且为Enable, 虽然这时候模块所在的文件夹还没有创建。
我们要创建一个名为HelloWorld的模块,包名为Fox。配置文件名为Fox_HelloWorld.xml。(注意文件名的大小写,在不同的配置文件里一定要一致,否则在linux主机下会出现问题)。

<?xml version="1.0"?>
<config>
    <modules>
        <Fox_HelloWorld>
            <active>true</active>
            <codePool>local</codePool>
        </Fox_HelloWorld>
    </modules>
</config>


2.新建模块
2.1 创建模块文件夹结构
在app/code/local下面,完整的模块包括以下文件夹, 以HelloWorld模块为例:
--Fox
	--HelloWorld
		+Block
 		+controllers
		+etc
		+Helper
		+Model
		+sql


每个文件夹下面可能还会根据需要创建子文件夹,后面会详细说明。
2.2 模块基本配置文件config.xml
config.xml是Magento模块的核心,里面配置了块(Block)、控制器( Controllers)、模型(Model)等模块部件,同时也体现的Magento MVC的思想。先看一下 config文件的基本结构。

<?xml version="1.0"?>
<config>
	<modules>
		<Fox_HelloWorld>   <!--模块的完整名称,和配置文件一致 -->
			<version>0.1.0</version>  
		</Fox_HelloWorld>
	</modules>
	<global>
		<blocks>
			<!-- 块声明 -->
		</blocks>
		<helpers>
			<!--帮助类声明 -->
		</helpers>
	</global>
	<frontend> <!--前台路由配置 -->
		<routers>
			<helloworld> <!—模块路由的标签名 -->
				<use>standard</use> 
				<args>
					<module> Fox_HelloWorld </module>
					<frontName>helloworld</frontName> <!—前台请求的名称 -->
				</args>
			</helloworld>
		</routers>
</config>

确保上面的config.xml保存在etc目录下。

3. 创建控制器类
3.1 控制器类
控制器类用于处理请求,并调用Block对象通过模板文件phtml产生最终的结果。简单起见,我们的第一个例子没有使用template, 而是仅仅简单的输出helloworld。

class Fox_HelloWorld_IndexController extends Mage_Core_Controller_Front_Action
{
	public function indexAction(){
		echo ‘hello world!’;
	}
}

将上面的文件命名为IndexController.php并保存在controllers目录下。

现在访问 http://localhost/helloworld/index/index,将会看到输出hello world。

URL分别对应 http://localhost/{frontName}/{controllerName}/{actionName}

如果直接访问 http://localhost/{frontName} 则访问默认的IndexController 和 IndexAction

所以也可以访问 http://localhost/helloworld, 也会输出相同的结果。

所有的前端控制器都继承自Mage_Core_Controller_Front_Action, 有2个很重要的方法preDispatch和postDispatch分别在请求分发前和分发后调用。
--未完待续--

你可能感兴趣的:(mvc,linux,xml,PHP,配置管理)