看到官方的文档,我觉得我头很大.非常大.无比的大.巨大.星球那么大...
好吧,我是弱智小孩.
我喜欢这样的顺序的快速开始
好吧.
action写在那个自动生成的lib下面的action目录中.通过继承Action来实现,其中可以写多个public的方法.然后就可以通过http://localhost/demo/index.php/news/index这样的奇怪的方式去访问了.news是那个action的名字,该action必须命名为NewsAction.class.php,而其中有一个index的方法.(开始写的是http://localhost/demo/news/index,我天真的以为和Zend一样.)
哦,还有就是下载的phped5.9.吼吼.蛮强大的,不过有些操作要适应下.
http://127.0.0.1/html/Myapp/index.php/模块/操作
http://127.0.0.1/html/Myapp/index.php/m/模块/a/操作
智能 PATHINFO 格式.貌似要支持.
项目配置目录 Conf ,里面有个 config.php 文件,该文件就是 ThinkPHP 系统配置文件
自己看看都明白
<?php
if (!defined('THINK_PATH')) exit();
return array(
//'配置项'
=> '配置值'
'DB_TYPE'
=> 'mysql',
//使用的数据库类型
'DB_HOST'
=> 'localhost',
'DB_NAME'
=> 'test',
'DB_USER'
=> 'root',
//访问数据库账号
'DB_PWD'
=>
'',
//访问数据库密码
'DB_PORT'
=> '3306',
'DB_PREFIX'
'APP_DEBUG'
//调试模式开关
'TOKEN_ON'
true,
//是否开启令牌验证
'URL_MODEL'
//URL模式:0普通模式 1PATHINFO 2REWRITE 3兼容模式
);
?>
还有一些其他设置
'URL_PATHINFO_DEPR'
=> '/', //PATHINFO URL 模式下,各参数之间的分割符号
'DEFAULT_THEME'
=> 'default', //默认模板主题
'URL_HTML_SUFFIX'
=> '.html',
'DEFAULT_CHARSET'
=>
'utf-8',
// 默认输出编码
'DEFAULT_TIMEZONE'
=> 'PRC', // 默认时区
'DEFAULT_AJAX_RETURN'
'JSON',
// 默认AJAX 数据返回格式,可选JSON XML ...
'APP_GROUP_LIST'
=> 'Home,Admin', //项目分组
'DEFAULT_GROUP'
=> 'Home', //默认分组
'COOKIE_EXPIRE'
=>
3600,
Coodie有效期
'COOKIE_DOMAIN'
=>
'',
// Cookie有效域名
'COOKIE_PATH'
=>
'/',
// Cookie路径
'COOKIE_PREFIX'
=>
'',
// Cookie前缀 避免冲突
'HTML_CACHE_ON'
=> false,
//默认关闭静态缓存
'HTML_CACHE_TIME'
=>
60,
//静态缓存有效期
'HTML_READ_TYPE'
=>
0,
//静态缓存读取方式 0 readfile 1 redirect
'HTML_FILE_SUFFIX'
=> '.shtml', //默认静态文件后缀
'ERROR_MESSAGE'
=> '您浏览的页面暂时发生了错误!请稍后再试~',//错误显示信息,非调试模式有效
'ERROR_PAGE'
=> '', // 错误定向页面
定义的模型类文件放在项目 Lib/Model 目录下,由系统自动加载
实例化基础模型类
$xx = new Model('xx');或者 $xx
实例化用户定义模
$User = D('User');
实例化空模型$Model = new Model();
模型名字貌似要对应数据库字段,所以会有偏差,有一个规范...
ThinkPHP
对数据库的表名和模型类的命名遵循一定的规范。首先数据库的表名和字段全部采用小写形式,模型类的命名规则是除去表前缀的数据表名称,并且首字母大写,然后加上模型类的后缀定义
当表前缀和系统设置的前缀(DB_PREFIX)一致而表名和模型名称不一致时,可设置此属性,例如表名称为 users
,而模型名称为 UserModel ,那么需要在模型类设置:
M方法和D方法的区别
ThinkPHP 中M方法和D方法都用于实例化一个模型类,M方法 用于高效实例化一个基础模型类,而
D方法用于实例化一个用户定义模型类。
class UserModel extends Model{
$tableName = 'users';
}
使用M方法
如果是如下情况,请考虑使用 M方法:
- 对数据表进行简单的 CURD 操作而无复杂的业务逻辑时
- 只有个别的表有较为复杂的业务逻辑时,将 M方法 与实例化 CommonModel 类进行结合使用
M方法 甚至可以简单看着就是对参数表名对应的数据表的操作:
$User = M('User');
使用D方法
如果是如下情况,请考虑使用 D方法:
- 需要使用 ThinkPHP 模型中一些高级功能如自动验证功能(create()方法中实现)、关联模型等
- 业务逻辑比较复杂,且涉及的表众多
- 将业务逻辑定义在了自定义的模型类里面(Lib/Model目录下),而想在操作中实现这些业务逻辑
另外 D方法 不支持跨项目调用,需要使用:
$User = D('User', 'Admin'); // 实例化 Admin 项目下面的 User 模型 $User = D('Admin.User'); // 启用了项目分组
如果表的前缀跟系统设定的不一致(表名和模型名可能一致)时,需要设定模型的 trueTableName 属性:
class UserModel extends Model{
$trueTableName = 'my_user';
}