为了安全,也要兼顾编辑器切换管理 开发时不必管目录名称的事, 只是在部署的时候,才修改应用目录和tp目录的名字就行了.
为了提高tp的加载效率, 始终给app和tp以绝对路径.就是以 realpath来定位
realpath返回的就是 一个绝对路径, 在lx中是以 斜杠 根树开始的. 参数可以是文件名, 也可以是目录名称. 返回结果: 如果是文件的话, 末尾会带文件名, 如果是目录的话,即使参数末尾带斜杠, 也会删除结尾的斜杠.
所以, 如果定义 THINK_PATH的话, 末尾要加上/ define('THINK_PATH', realpath('./Think').'/');
vim的f 和 t键的区别: f是正好调到指定的字符 上, 而t: to 是跳转到指定字符的前面
0和^的区别: 0是第一个字符,不管是不是空白字符; ^是跳转到第一个非空白字符. 跳到行的最后 就只有一个符号了$
在vim中, 除了对行的操作外, 将 操作命令 y,d,c,x 等和 跳转条件 f, t等 相结合, 操作就不只是以行为单位了, 可以想到哪里就操作到哪里. 比如 dt)
...
vim中,字的含义, 一个英文单词是一个字, 连续的多个汉字也只能算一个字. 文本的单位 有 字w, 行j k等这些, 既是文本 的单位, 同时 也是vim的跳转命令.
所以, 像 操作命令 d, c,y, x 等 和 文本内容的单位比如 w j k 等符号之间的位置关系: 应该是: 操作命令+倍数+单位: 比如: d2w, d4j, y2w等等,
而不是: 倍数+单位+操作命令, 比如 : 4wd: 因为如前所说, 4w它是已经是一个命令了, 会向后跳转4个字, 这时命令就已经执行了, 再到d的时候, 其实也就只有一个 单字符 d命令了, 这个肯定就不是原来的本意了.
非常重要的一个思维就是, html中的结构, 尽量不要用手工符号 比如 br等 去调整, 而是要用 "语义化的标签" 去组织 内容. 比如p, span, div, 字体大小等方面,尽量不要用 font size之类的, 而是用 h1, h2...
chmod的格式: chmod [who] [+-=] [mode] 文件1 文件2...
一般来说, 文件/目录的创建者, 自动成为所有者, 自动具有 "读写执行" 的权限
- chmod默认只是对当前文件或目录(只一层目录), 修改访问mode. 要对目录下的子目录递归修改权限, 要使用 -R或 --recursive
- 可以一次性的 修改多个文件或目录, 而不必使用多个相同的命令来修改,这样更快 chmod +x file1 file2 dir1
- who可以是多个用户的组合,比如: ug+x
- 可以在一个命令中设置多个不同用户的权限, 中间用逗号分隔, 比如: g+w, o+x
- 访问模式还可以用 除了加号减号外, 还可以用等号.
=u =g
, 等, 表示跟所有者, 组的权限相同.
[root@localhost html]# chmod o+w Honda Public -R
一般来说, 文件在本地(控制台) 访问, 读写, 编辑 都是以 owner的身份进行的, 只是在以 网络/web/localhost的 方式 访问时是以other(比如apache)身份访问的.
要让apche能够访问web根站点以下所有目录(解决linux写权限问题), 只是要求从 html目录(localhost网站根) 开始->到其下 所有子目录的访问权限 能被apache所 "读 + 写"就行了, 不必要求从/var/www/ 的所有逐级目录都被apache所读写.
- 父目录下, 可以存放 和父目录所有者不同的 其他所有者的文件或子目录.
==================================
查看apache httpd载入了哪些模块, 使用httpd -M
命令
查看到已经载入了 rewrite_module
然后在 html根目录设置: AllowOverride All.
在tp的入口文件设置 define('DIR_SECURE_FILENAME', 'deny.htm')
以及deny内容的时候, 并不会自动 关闭apache的目录列表显示功能, 这个设置 只是在目录下生成对应的deny.htm文件和写入内容. 要禁止显示目录列表, 还的要自己在httpd.conf中设置:
两种设置方法:
-
是设置
<IfModule dir_module> DirectoryIndex index.php index.html (在这里加入deny.htm文件, 当访问目录时,如果下面没有其他index文件, 就会显示这个deny.htm文件的内容 Access Denied)</IfModule>
这个对于 所有的目录都适用 是最简单有效的方法 -
另一种方式就是设置 某个目录的Options, 去掉Indexes索引(显示功能): 不写Indexes, 或者在前面加减号-Indexes.
<Directory '/var/www/html/Foo'>
Options FollowSymLinks
</Directory>
// 默认情况下, 上面的Foo下面的子目录都不能索引列表显示了, 比如: html/Foo/Bar/ . 但是如果你又显式的 规定了其他子目录的Indexes权限, 那么根据权限重写, 覆盖的原理, 下面的这个Common目录又可以列表显示了.
<Directory '/var/www/html/Foo/Common'>
Options Indexes FollowSymLinks
</Directory>
注意 jk 等 "行" 的倍数和 w b等 "字"的倍数的不同, 因为 j k本身就要向上/下一行了,所以, 如果 2j, y2j 将会 复制 3行...
关于分页类的使用
分页类, 页码的显示, 是一个包含链接的字符串, 这个页码字符串要用 $page->show()
方法生成并传递到模板
页码中的字符串, 可以用类的 setConfig方法去设置
分页类的作用有两个: 一个是生成(通常在显示内容下方)的页码链接字符串; 二个是 根据limit决定 传递到模板的数据记录范围.
主要有三步: 初始化类new ThinkPage($count, 10);
写分页字符串; 写limit连贯方法. 其中 limit的参数不能写死了, 因为这个要被修改的.$limit=$page->firstRow . ',' . $page->listRow
这两个page对象的两个属性.
page类用到了类似ajax的思想: 将单击 产生的 页码号传递到php后台的操作方法中, 操作方法根据页号($_GET['page']), 从数据库中查询对应的内容, 在返回给前段的ajax程序, 最后显示.
在 模板中 的函数 U方法 生成url地址时 中, 要使用 原生的php语法, 不能再用模板语法了, 比如数组只能使用中括号, 不能使用点号语法, 和模板输出. 又比如: success和error方法的 跳转 地址就是用 U方法生成的
通常在实际开发中, 除非特别需要, 都要尽量保持系统的默认值. 不必去费不必要的精力去改一些不必要的默认值.
mysql中, 无法删除test数据库?
- 如果是非事务型的还是MyISAM执行效率好,对于一般的项目,那还是MyISAM比较给力了。
- 摘抄自: http://www.wo81.com/tec/db/mysql/2014-05-12/214.html
别的数据库的frm,myd,myi文件直接拷贝过来即可打开,数据也都有,这意味着只要这些文件在,数据就不会丢失。(其中frm是表的结构信息, myd是表的数据记录信息, myi是表的索引信息. 因此, 要移植/导入数据库, 就将这三个文件拷过来. )不过貌似只有frm文件的表拷贝过来是打不开的。
请不要在数据库文件夹下面创建文件或者目录。否则会 删除数据库失败.
.empty文件时wampserver安装时自动创建的,可能是为了让用户不要删除test库才创建的吧。
#### 数据库中的db.opt是记录数据库所用的 默认字符集和校验规则.
在mysql的数据库中, 只有一个单词使用 下划线,就是 auto_increment, 其他都不使用下划线,比如 primary key.
单独使用命令来设置主键: alter table foo_table add constraint pk_foo primary key(id, name);
url编码?
根据rfc的规定, 在url中只能包含字母数字,和一些特殊符号(包括 .-_'$?&*等,只有单引号没有双引号), 但是这些特殊符号只能是在网址中,不是说在 查询字符串(传参中), 如果这些特殊符号在query string中, 就要对它们进行编码处理
rfc没有对编码做统一的规定, 而是让浏览器自己来做决定,所以就比较混乱. 比如ie和ff就有很多不一样的地方.
可以通过js脚本来对url做统一的处理, 即: 不让浏览器有插手的机会, 让js来处理(汉字和特殊字符). 主要包括两个函数:
encodeURI() 和 decodeURI()
使用模板包含include需要注意的事项?
-
被包含的模板文件本身, 并不会自动调用对应的控制器方法, 也就是说, 被包含的其他模板文件中的变量赋值需要在当前操作中完成. 比如: 在foo1.html中包含foo2.html
<include file="action/foo2" />
如果要在foo2.html中输出变量 {$bar}, 那么这个$bar变量需要在foo1对应的操作中去完成。 -
模板包含的时候, 还可以传递变量, 在被包含的模板中使用 传参变量时, 用 [title] 中括号的方式。 是不是只能传递title和keywords参数,其他任意参数都可以吗?
-
由于模板解析的特点, 总是从入口模板开始解析的, 如果被包含的 外部模板有所更新 , 这种更新并不会自动表现在入口模板中, 入口模板引擎并不会重新编译, 除非你在调试模式下, 或者缓存已经过期. 所以, 如果在部署模式下, 修改了被包含的 外部模板文件后, 要把模块的缓存目录清空, 否则改变不会生效.
杂项
trim不但能过滤(去掉 空白字符), 而且还可以在 第二个参数 $charlist 中指定要 过滤 / 去除掉的 其他字符列表. 注意这些字符列表 表示的字符 只能是 两边 靠边的字符或字符组合, 对中间的字符没有影响,比如: echo trim('hello world', 'hld'
将输出 "ello wor" 中间的ll不会被删除. 这个用法在删除字符串两端的{} 符号比较有效
guid和uuid的区别?
uuid是osf "软件基金会"统一规定的标准,而guid是ms对uuid的一种实现
uuid是用 4个横线对 32个字节(32个16进制字符)的分隔得到的 36个字节.
php的date函数的特殊用法?
-
date是一种时间格式函数, 本身并没有时间. 是把时间戳格式化为更易读的日期和时间.
-
通常date函数, 需要传入 一个时间戳 作为第二个参数 比如
date('ymd', $time);
. 但是它 的格式是:date('日期时间格式', [时间戳]);
所以, 这个时间戳是一个 可选参数, 是可以省略的. 如果省略,就是代表的 当前时刻的时间戳. 而在很多时候, 我们处理的就是 当前时刻的时间戳. 所以, 可以看到 date('Y-m-d')的用法. -
更重要的是, 日期格式, 不一定是我们常用的 y-m-d, 有的时候, 我们只需要 当前的年份, 月份,或日期中的一个数字, 这就要使用 date的单字符, 单字母(没有数字)格式, 比如: date('Y'),date(m,和d都是两位数字,比如05 月份, 08日期. 表示星期, date('w')返回星期几的数, 而date('l') (注意是L的小写, 不是数字1)则返回星期的英文单词比如Wednesday.
-
再比如 自动版权年份:
@ 2010-<?php echo date('Y') ?>
===========================================
编写Page类进行分页的实例:
mysql中的信息显示用show命令, 后面 要跟 关键字 , 不能跟函数, 如果要用函数, 需要用 select语句
- select version();
- show engines; 可以看出默认的是innoDB引擎
- show errors;
- show warnings; 显示最后一条执行的sql语句的错误或警告, 注意都要用复数.
显示错误和警告? - show variables;
- show status;
auto_increment的int, 你不想输入, 那么就用null. 但是你不能用 '', 因为这两个数据类型都不一样. 空''字符串是string, 用来给int类型
的主键赋值, 肯定会产生warning.
这个警告是发生在 mysql 5.X以上的版本.
null可以给任何数据类型的 字段, 比如 int, 比如 char... ,任何类型的 变量赋值! 比如表示一个字段不为空, 就是 not null.
**可以同时插入多个记录, 但是在多个values 之间 要用 逗号进行分割! **
生成xhtml类型的网页, emmet使用的缩略词是 html:xt, 注意是 xt, 表示 是html向xml过渡的类型, 即xml -trans, 所以是xt, 但不是xh, 要生成html5的网页, 可以写 html:5, 或者直接写一个! 都可以.
-
表格本身也有一些有用的/ 直接的 属性, 包括: 颜色 bgcolor, bordercolor, cellspacing, cellpadding (单元格的外边距和内边距).
-
page类的show方法, 返回的是, 分页字符串:
return "<div>{$page_str}</div>
public function page(){
header('Content-type: text/html; charset=utf8');
$count= M('user')->count();
$rowPerPage=4;
$page = new ThinkPage($count, $rowPerPage);
$limit= $page->firstRow .','.$page->listRows;
$data = M('user') -> order('id desc') -> limit($limit) ->select();
$page->setConfig('first', 'fff');
$page->setConfig('last', 'eeee');
$page->setConfig('theme', '%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END% , <font color="red"> %HEADER%,
共 %TOTAL_PAGE%页 </font>');
$p = $page->show();
$this->assign('data', $data);
$this->assign('page', $p);
$this->display();
}
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => '127.0.0.1', // 服务器地址
'DB_NAME' => 'test', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => '', // 密码
'DB_PORT' => '3306', // 端口
'DB_PREFIX' => 'think_', // 数据库表前缀
'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' => '', // 指定从服务器序号
{__NOLAYOUT__}
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
<title>page分页</title>
</head>
<body>
<table width="80%" border="1" cellspacing="0" bgcolor="#eff" align="center">
<tr>
<th>id</th>
<th>username</th>
<th>age</th>
<th>addr</th>
</tr>
<foreach name="data" item="u">
<tr>
<td>{$u.id}</td>
<td>{$u.username}</td>
<td>{$u['age']}</td>
<td>{$u.addr}</td>
</tr>
</foreach>
</table>
{$page}
</body>
</html>