1.获取系统常量信息的方法:在控制器DengLuController里面下写入下面的方法,然后调用该方法。
public function test() { //echo "这是测试的" //$this->assign("a","world"); //$this->show(); var_dump(get_defined_constants());//获取系统常量信息。里面加上参数true,就会按照类把所有的信息显示出来。 }
系统信息里面比较重要的是user里面的信息,有时候会用到这些信息。下面都是比较重要的信息。
//‘__ROOT__‘ => string ‘/thinkphp‘ (length=9) //整个tp框架根目录 //‘__INFO__‘ => string ‘Admin/DengLu/test‘ (length=17) //获取模块名/控制器名/方法名 //‘__SELF__‘ => string ‘/thinkphp/index.php/Admin/DengLu/test‘ (length=37) //代表自身的路径 //‘__APP__‘ => string ‘/thinkphp/index.php‘ (length=19) //代表入口文件地址 // ‘__MODULE__‘ => string ‘/thinkphp/index.php/Admin‘ (length=25) //模块文件夹路径 //‘__CONTROLLER__‘ => string ‘/thinkphp/index.php/Admin/DengLu‘ (length=32) //控制器文件夹路径 // ‘__ACTION__‘ => string ‘/thinkphp/index.php/Admin/DengLu/test‘ (length=37) //找到操作方法
2.跨控制器的调用
跨控制器调用就是在某一个控制器里面写了一个方法,要在每一个页面都拿来用。
例如:新建一个控制器MainController.class.php,控制器的内容如下,里面有一个方法,输出“大苹果商城”。
<?php namespace Admin\Controller; use Think\Controller; class MainController extends Controller { public function showList() { echo "大苹果商城"; } }
在MainController.class.php同一级目录下有一个控制器DengLuController.class.php,要在里面调用MainController.class.php里面的showList方法。调用方法如下:
<?php namespace Admin\Controller; use Think\Controller; class DengLuController extends Controller { public function test() { //1.造新对象 MainController,调用里面的showList方法。 //$m = new MainController(); //$m->showList(); //2.使用快捷函数A //$m = A("Main");//A方法用来实例化控制器对象,控制器前面不加模块名调用的是控制器同级目录下的其它控制器。 //$m->showList(); //$m = A("Home/Index");//控制器前面加上模块名,就是调取的其它模块下的控制器 //$m->test();//Index控制器里面有个test方法,调用此方法。 //3.使用快捷函数R //$m = R("Home/Index/test");//R实例化对象同时调用指定方法,直接写控制器和方法名。 } public function _empty()//当访问空方法时执行这个方法,输出一句话。 { echo "您输入的地址不对"; } }
3.生成路径的方法,可以在任意方法里面生成任何方法的路径,之遥前面加上模块名和控制器名即可。
<?php namespace Admin\Controller; use Think\Controller; class DengLuController extends Controller { public function test() { //快捷函数U方法 echo U("test");//生成test方法的完整路径。 echo U("Main/test");//生成Main控制器下test方法的完整路径。 echo U("Home/Main/test");//生成Home模块下的Main控制器下test方法的完整路径。 } public function _empty() { echo "您输入的地址不对"; } }
4.连接数据库配置及Model数据模型层
(1)修改配置
做配置要在自己的配置文件里面修改配置,这里是在D:\wamp\www\thinkphp\Application\Admin\Conf\config.php里面修改。将tp框架配置文件D:\wamp\www\thinkphp\ThinkPHP\Conf\convention.php文件里面讲需要修改的配置复制到config.php里面去修改。修改的内容大致如下,配置信息修改成自己的数据库的信息。由于该配置是在Admin模块下,所以只有该模块下的程序代码才可以访问数据库。
/* 数据库设置 */ ‘DB_TYPE‘ => ‘‘, // 数据库类型 ‘DB_HOST‘ => ‘‘, // 服务器地址 ‘DB_NAME‘ => ‘‘, // 数据库名 ‘DB_USER‘ => ‘‘, // 用户名 ‘DB_PWD‘ => ‘‘, // 密码 ‘DB_PORT‘ => ‘‘, // 端口 ‘DB_PREFIX‘ => ‘‘, // 数据库表前缀 ‘DB_PARAMS‘ => array(), // 数据库连接参数 ‘DB_DEBUG‘ => TRUE, // 数据库调试模式 开启后可以记录SQL日志 ‘DB_FIELDS_CACHE‘ => true, // 启用字段缓存 ‘DB_CHARSET‘ => ‘utf8‘, // 数据库编码默认采用utf8 ‘DB_DEPLOY_TYPE‘ => 0, // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器) ‘DB_RW_SEPARATE‘ => false, // 数据库读写是否分离 主从式有效 ‘DB_MASTER_NUM‘ => 1, // 读写分离后 主服务器数量 ‘DB_SLAVE_NO‘ => ‘‘, // 指定从服务器序号
(2)制作model模型
a.model本身就是一个类文件
b.数据库中的每个数据表都对应一个model模型文件。
c.建立model模型:
例如如果要访问数据库中的nation表,要现在Admin\Model目录下新建NationModel.class.php文件,文件的内容如下:
<?php namespace Admin\Model;//命名都要改成Model use Think\Model; class Nation extends Model//继承自父类Model { //如果有特殊需求可以在这里写上,正常的话不需要写需求。 }
下面是新建Nation类的三种方法
<?php namespace Admin\Controller; use Think\Controller; class DengLuController extends Controller { public function shuJu() { //1.new的方式 //$n = new \Admin\Model\NationModel();//这种方法造的是子类对象 //var_dump($n); //2.使用快捷方式D方法 //$n = D("Nation");//这种方法造的是父类的对象 //var_dump($n); //3.使用快捷方式M方法 $n = M("Nation");//这种方法造的是父类的对象 var_dump($n); } public function _empty() { echo "您输入的地址不对"; } }
5.命名空间
命名空间相当于虚拟的目录,意思是做一个虚拟的目录,本来A文件夹下放了一个文件aa,用程序写一个文件目录,把aa文件的上一级当成是B文件夹。(文件aa在A文件夹里面,用程序说aa文件在B文件夹里面)。
TP框架做虚拟空间是为了能够有一个统一的文件夹管理,比如说把类文件都放在同一个文件夹里面,在调用这些类文件时就不需要用include、require来加载这些类文件了,可以实现自动加载。同时,所有的文件命名规则都一样,同时目录都是定死的,就可以使用自动加载类了,就可以直接new 类了。由此可见,TP框架里面使用命名空间的目的主要是为了自动加载类。
TP框架下有一个初始命名空间(相当于根目录)
初始命名空间:ThinkPHP\Library。
在初始空间命名下又包含很多根命名空间。这些根命名空间主要分两类:
(1)TP核心类里面的根。在Library目录下所有的文件夹都是根。在写命名空间的时候要从根开始写。
(2)APP里面的根。APP里面的根是以模块名命名的。
写类时,用use引入命名空间,例如use Think\Controller,Think是根目录,Controller是父类也是文件名。而在namespace Admin\Controller;中,Controller是真是的文件夹