ThinkPHP 分页中带入查询(搜索)条件

很多情况下,分页还会带入查询条件,而这时查询往往是不固定的。例如常见的搜索,需要根据用户查询的关键字来进行检索,在搜索结果太多时,就需要将搜索结果进行合理分页。

ThinkPHP 分页可以很容易的实现对不固定查询参数的支持。具体实现是给分页类的 parameter 属性赋值或者直接实例化分页类时传入查询参数。下面以例子来说明。

parameter 属性赋值
例如要检索用户表中状态为 1 (status=1) 并且电子包含 163 的用户,当提交表单时(注意表单是 GET 方式提交),形成的 URL 地址大致如下:

http://www.cnsecer.com/index.php/Index/search/status/1/email/163

在搜索操作(search)中主要代码如下

在页面的分页链接中,可以看到地址(如第 2 页)为:

http://www.cnsecer.com/index.php/Index/search/status/1/email/163?status=1&email=163&p=2

可以看见分页链接中已经包含了需要检索的 status=1&email=163 条件。当然,实际解析后的地址应该是:

http://www.cnsecer.com/index.php/Index/search/status/1/email/163/p/2/

这是因为 ThinkPHP 分页类对 URL 的处理还不够完美造成的。要对此进行改进,参看《ThinkPHP 定制分页风格及URL》。

传入 parameter 参数
带入查询条件的分页关键就是设置分页类的 parameter 属性值。除了上例中给 parameter 属性赋值外,也可以直接在实例化类的时候将 parameter 参数传入,两种方式结果是一致的:

提示
上述例子只是用于讲述分页中带入查询条件的使用,因此未对检索的关键字进行进行安全处理。实际使用中在进行查询之前,应对用户输入的关键词做安全性方面的处理。

ThinkPHP3.2.3通用后台–ThinkAdmin

经常用ThinkPHP开发项目,但是每次开发许多基本功能都要重新写,太浪费时间!索性就写了一个通用的后台,以后开发中可以直接拿来用!

温馨提示:不屏蔽广告就是对本项目最大的支持~

这个通用后台有以下特点

1.功能简洁,只有最基本的功能

2.代码通俗易懂,适合初学者学习

3.基于ThinkPHP最新版,后续会不断升级

4.代码托管至github,保证实时更新

5.内置微信第三方API和DEMO

6.内置第三方登陆API和DEMO(支持QQ,新浪微博、腾讯微博、淘宝、百度、360、人人、开心网等)

7.前后台入口文件分离,安全!

系统功能

1.系统基本功能如下,请根据实际需要来添加或者修改:

  • 用户管理
  • 用户登陆注册
  • 无限极分类
  • 文章管理
  • 单页管理
  • 链接管理

2.Application/Extend目录已内置微信第三方API,请根据实际情况调用

3.其他功能将在后续开发中慢慢完善,比如RBAC、插件扩展等…

后台截图

后台模板用的SBAdmin(好名字啊!),响应式的,基于bootstrap3,后台考虑兼容IE9以下浏览器的请绕道!

后台主页

1

分类列表

2

文章列表
3

添加文章
4

项目地址

Github:https://github.com/cnsecer/ThinkAdmin

OSChina:http://git.oschina.net/cnsecer/ThinkAdmin

更新历史

thinkphp延迟更新用法详解

用途

我们经常需要给某些数据表添加一些需要经常更新的统计字段,例如用户的积分、文件的下载次数等等,而当这些数据更新的频率比较频繁的时候,数据库的压力也随之增大不少,我们可以利用高级模型的延迟更新功能缓解。

要点

延迟更新必须继承高级模型,或者使用动态模型

高级模型:

动态模型

 

介绍

如果不用延迟更新的话,每执行一次都要往数据库里面更新下字段…流量大的话,数据库都受不了:

上面的操作更新了两次用户积分,并且都实时保存到数据库如果我们使用延迟更新方法,例如下面对用户的积分延迟更新60秒

那么60秒内执行的所有积分更新操作都会被延迟,实际会在60秒后统一更新积分到数据库,而不是每次都更新数据库。临时积分会被累积并缓存起来,最后到了延迟更新时间,再统一更新。相当于在60秒后执行了:

效果是等效。区别在于用户数据库中的积分不是实时的。同样,还可以使用setLazyDec进行延迟更新操作。

不懂的地方请留言,我看到后就会回复

ThinkPHP生成静态页面

ThinkPHP内置了一个静态生成静态页面的方法,这个方法位于Controller.class.php,代码如下

这个方法在2.X的手册中是有说明的,不过3.X的手册中把说明给去掉了!下面说下这个方法的用法

稍微说明下参数,有些朋友问我这个参数和具体如何使用。

参数一:静态文件,是指生成后的静态文件名,文件保存路径完整的就是:静态路径/静态文件。例如静态文件设置a/index.那么保存的路径就是项
目路径/Html/a/index.html(默认的静态路径在项目路径的Html文件夹下,没有可以自己创建)

参数二:静态路径,上面已经说明了默认的路径,3.0中可以在入口文件里加入参数来更改静态路径。
define(‘HTML_PATH’, ‘./’);(将静态路径义为网站根目录)

参数三:模板文件,我感觉官方这个描述是不正确的,准确的来说应该是目标模块,就是需要生成静态文件的模块。格式:模块名:操作。比如要生成Index下的a方法为静态文件,那就是Index:a。如果为空则默认生成当前操作的静态文件。
例子:

其实

可以在当前模块下加入语句,那么只要运行该模块就会产生指定的目录下的”模块.html”文件,通常的做法就是站点建设好以后,专门写一个方法,然后让其执行,使整个站点一次性生成静态文件,注意:如果站点有编辑或调整那么必须清理缓存一次,就是项目下的Runtime文件夹必须清空。

 

thinkphp 3.2的插件机制

thinkphp 3.2的里面多了个Hook类,也就是钩子。有了这个类,然后再实现插件就很简单了。这个类位于 ThinkPHP/Library/Think目录下

thinkphp

 

具体用法

1.为插件注册新的命名空间。在config.php添加如下代码

2.创建如下目录结构

02

3.TestAddon.class.php的代码如下

4.在模板里添加{:hook('test')} 这样就可以输出了,

详细查看:

http://www.thinkphp.cn/topic/10198.html

http://document.thinkphp.cn/manual_3_2.html#behavior_extend

thinkphp获取上一篇和下一篇文章的思路

上一篇和下一篇这个功能这每个网站都很常见,其实思路很简单的。直接上代码吧

就是这么简单…. Continue reading “thinkphp获取上一篇和下一篇文章的思路”

实用的正则表达式

实用:

转自:http://www.php-baike.com/php-regular-expressions.html

基础:

 

转自:http://m.poorren.com/php-zhengze-huizong/

ThinkPHP的自动验证常用的正则

ThinkPHP的自动验证机制是为了进行表单数据验证,验证可以支持function、 callback、confirm、equal、unique和regex,这里要讲的是使用正则表达式进行验证。

一般我们见的比较多的是设置规则为require、email之类的,其实这些本身也是属于正则表达式验证方式,只是系统内置定义了一些常用的正则表达式而已。这些内置的正则表达式的定义可以参考model类的regex方法,内置支持的正则定义包括:
require 字段必须、email 邮箱、url URL地址、currency 货币、number 数字、zip 邮编、integer 整数、double 浮点数、english 英文字母,但是并不局限于这些正则规则的,我们完全可以直接在验证规则里面使用正则表达式进行定义,这样我们可以凭借强大的正则表达式来进行表单字段验 证,例如:

附上一些表单验证中比较常用的正则表达式写法:

匹配特定字符串:

thinkphp视图模型不能使用where查询

视图模型代码如下

 

我使用如下代码查询

结果没有返回值….为什么呢?因为两张表里面都有一个id,TP不知道你要查询哪个id啊….

正确的查询方法

ThinkPHP中文乱码解决方案

介绍

我的情况是这样的:mysql数据库和表的编码全部设置为utf8,thinkphp编码也设置为utf8,页面编码也设置为utf-8,也就是说数据库 、php、页面的编码都是统一的,注册、登陆、后台读取都正常,但只有用Navicat for MySQL或者phpmyadmin查看的时候乱码

具体原因如下:

用Navicat for MySQL查看的时候中文乱码,如图:

下面的是使用PHP在后台读取的,正常..没乱码

解决方案

这里我设置统一编码为utf8

你可以用如下命令先看下:

[code]show variables like  "character_set_%"; [/code]

mysql

如果你的结果和上图的不一样,在my.ini添加如下代码:

[code]

[client]
default-character-set=utf8

[mysqld]
default-storage-engine=INNODB
character-set-server=utf8
collation-server=utf8_general_ci

[/code]

然后重启mysql即可…

另外建立数据库的时候一定要设置编码,比如

[code]

create database  cnsecer default character set utf8 collate utf8_general_ci;

[/code]

ThinkPHP3.2 F方法序列化解决方案

介绍

thinkphp 3.2里面用F方法储存的数据都被序列化了..假设你用F方法把数据储存到配置文件,储存后的数据都是序列化之后的,这样你就不能像3.1那样用C方法读取配置文件的数据了。我的解决方法就是自己定义一个储存数据的方法。

方法

在/Application/Common/Common创建function.php,然后添加以下代码: