分类 PHP 下的文章

利用php的imagick给gif图片加水印

尝试多次直接用GD库给gif图片加水印均未达到理想效果后,决定用imagick扩展给gif图片加水印,虽然帧数太多的情况下速度不太给力外,效果蛮理想。

开启imagick扩展,可参考http://www.vpser.net/manage/lnmp-lnmpa-imagemagick-install-tutorial.html

果断先上图:

再上代码:



$image_name = '01351346.gif';
//$image_name = 'Left_spinning_dancer.gif';
//$image_name = 'gifmerge.gif';

function createTextImagickDraw($fontSize=12, $fillColor='', $underColor='', $font='msyh.ttf'){
	$draw = new ImagickDraw();
	$draw->setFont($font);
	$draw->setFontSize($fontSize);
	//$draw->setGravity(Imagick::GRAVITY_SOUTHEAST);//设置水印位置
	if(!empty($underColor)) $draw->setTextUnderColor(new ImagickPixel($underColor));
	if(!empty($fillColor)) $draw->setFillColor(new ImagickPixel($fillColor));
	return $draw;
}

function createWaterImagickDraw($waterImg='water.png',$x=10,$y=85,$width=16,$height=16){
	$water = new Imagick($waterImg);
	//$second->setImageOpacity (0.4);//设置透明度
	$draw = new ImagickDraw();
	//$draw->setGravity(Imagick::GRAVITY_CENTER);//设置位置
	$draw->composite($water->getImageCompose(), $x, $y, $width, $height,$water);

	return $draw;

}
$image = new Imagick($image_name);
$animation = new Imagick();
$animation->setFormat( "gif" );
$image = $image->coalesceImages();
$unitl = $image->getNumberImages();

for ($i=0; $i<$unitl; $i++) {
	$image->setImageIndex($i);
	$thisimage = new Imagick();
	$thisimage->readImageBlob($image);
	$delay = $thisimage->getImageDelay();
	$thisimage->annotateImage(createTextImagickDraw(12, 'red'), 30, 100, 0, '阿维卡');
	$thisimage->annotateImage(createTextImagickDraw(12, 'green'), 10, 120, 0, 'http://kller.cn');
	$thisimage->annotateImage(createTextImagickDraw(12, 'blue'), 10, 140, 0, 'http://www.aweika.com');
	$thisimage->drawImage(createWaterImagickDraw('f.jpg'));
	$animation->addImage($thisimage);
	$animation->setImageDelay( $delay );
}
$animation->writeImages('new/'.$image_name, true);
header( "Content-Type: image/gif" );
echo $animation->getImagesBlob();

附件:(你们懂的)

imagick.zip

php对特定数组进行压缩

特定的数组形式如下:


$dataArr = array(
'0'=>array('c'=>'A','f'=>55,'t'=>60),
'1'=>array('c'=>'A','f'=>61,'t'=>70),
'2'=>array('c'=>'A','f'=>71,'t'=>80),
'3'=>array('c'=>'A','f'=>81,'t'=>90),
'4'=>array('c'=>'B','f'=>91,'t'=>100),
'5'=>array('c'=>'B','f'=>101,'t'=>110),
'6'=>array('c'=>'A','f'=>111,'t'=>120),
'7'=>array('c'=>'B','f'=>121,'t'=>130),
'8'=>array('c'=>'B','f'=>131,'t'=>140),
'9'=>array('c'=>'B','f'=>141,'t'=>150)
);

压缩方法:


function change($dataArr)
{
	$j=0;
	for ($i=0;$i<=count($dataArr);$i++)
	{
		if($dataArr[$i]['t']+1 == $dataArr[$i+1]['f'] && $dataArr[$i]['c'] == $dataArr[$i+1]['c'] && $i!=count($dataArr)-1)
		{
			$dataArr[$i]['t'] = $dataArr[$i+1]['t'];
			unset($dataArr[$i+1]);
			$j++;
		}
	}
	if($j != 0) $dataArr = change(array_values($dataArr));
	return $dataArr;
}

处理代码:


$dataArr = change($dataArr);
var_dump($dataArr);

执行结果:


array
  0 => 
    array
      'c' => string 'A' (length=1)
      'f' => int 55
      't' => int 90
  1 => 
    array
      'c' => string 'B' (length=1)
      'f' => int 91
      't' => int 110
  2 => 
    array
      'c' => string 'A' (length=1)
      'f' => int 111
      't' => int 120
  3 => 
    array
      'c' => string 'B' (length=1)
      'f' => int 121
      't' => int 150

应用

这段代码印象比较深刻,当时我从那个纯真ip中导出ip数据库,做了n多步处理后只保留了城市,于是就变成了下面这个样子:

处理前

仔细看就会发现有好多同城市的ip上一条结束和下一条开始其实是连续的,也就是说完全可以组成一条数据。处理方法上面已给出。成功的从原表285739条数据处理成29251条。处理后的数据如下图:

处理后

好吧,就写到这。

php大数(浮点数)取余

一般我们进行取余运算第一个想到的就是用百分号%,但当除数是个很大的数值,超出了int范围时,这样取余就不准确了。

php大数(浮点数)取余函数


/**
 * php大数取余
 *
 * @param int or float $bn 除数
 * @param int $sn 被除数
 * @return int 余数
 */

//大数(浮点数)取余方法
function Kmod($bn, $sn)
{
	return intval(fmod(floatval($bn), $sn));
}

测试代码:


//大数(浮点数)取余方法
function Kmod($bn, $sn)
{
	return intval(fmod(floatval($bn), $sn));
}

//整数取余方法
function mod($bn, $sn)
{
	return $bn%$sn;
}

//最大的int整数
$bn = PHP_INT_MAX;
$sn = 11;

var_dump($bn);
var_dump(Kmod($bn, $sn));
var_dump(mod($bn, $sn));

//给最大的int整数加1
$bn = PHP_INT_MAX + 1;
var_dump($bn);
var_dump(Kmod($bn, $sn));
var_dump(mod($bn, $sn));

执行结果:


int 2147483647

int 1

int 1

float 2147483648

int 2

int -2

我们可以发现当给最大的整型数加1之后,得到的$bn已经变为了浮点型。

php自用分页类

很早以前写的了,现整理共享出来。:)

相关代码在下面,先发下效果图:

下拉列表分页PMA和NORMAL两种模式差别效果图:

PMA模式

NORMAL模式

分页类Page.class.php


/**
* 本类主要用于实现简单分页
* Page.class.php
*/

class Page
{
	private $page_num; //每页显示的信息条数
	private $page_all_no; //信息的总条数
	private $page_len; //显示多少个页码
	private $page; //当前的页数
	private $page_max; //页数最大值
	private $page_no_array; //页数的数组
	public $start_num; //查询语句limit的起始值
	private $page_change; //在第几个页码开始 页码递增
	private $URL; //获取当前页面的URL

	public function __construct($page_all_no, $page_num=5, $page_len=5)
	{
		$this->page_all_no       = intval($page_all_no);
		$this->page_num          = intval($page_num);
		$this->page_len          = intval($page_len);
		$this->URL               = $_SERVER['REQUEST_URI'];
		$this->max_page(); //得到页数的最大值
		$this->page_no(); //得到当前页数
		$this->page_no_array(); //页数数组
		$this->start_num(); //得到sql语句中limit的起始值
		$this->change_page(); //得到递增开始的页码$this->page_change
		$this->getURL(); //得到当前的URL并处理返回
	}

	private function isArray($str,$str_self)
	{
		if(!is_array($str)) throw new Exception("$str_self must be an Array type");
	}

	private function page_no()
	{
		$this->page = isset($_GET['page']) ? $_GET['page'] : 1;
		if(isset($_GET['page']) && $_GET['page'] < 1) $this->page = 1;
		if(isset($_GET['page']) && $_GET['page'] > $this->page_max) $this->page = $this->page_max;
		return $this->page;
	}

	private function max_page()
	{
		return $this->page_max = $this->page_all_no <= 0 ? 1 : ceil($this->page_all_no/$this->page_num);
	}

	private function change_page()
	{
		return $this->page_change = ceil($this->page_len / 2);
	}

	private function page_no_array()
	{
		return $this->page_no_array = range(1, $this->page_max);
	}

	private function start_num()
	{
		return $this->start_num = $this->page_num * ($this->page - 1);
	}

	private function getURL()
	{
		if(!empty($_SERVER['argc']) ? $_SERVER['argc'] == 0 : strpos($_SERVER['REQUEST_URI'], '?') === false)
		{
			$this->URL = $this->URL.'?';
		}else{
			$url_a = "/\?page=[0-9]{1,}/";
			$url_b = "/&page=[0-9]{1,}/";
			ereg("\?page=[0-9]{1,}", $this->URL) ? $this->URL = preg_replace($url_a, "?", $this->URL):
			ereg("&page=[0-9]{1,}", $this->URL) ? $this->URL = preg_replace($url_b, "&", $this->URL):$this->URL = $this->URL.'&';
		}
		return $this->URL;
	}

	private function header_info($total_data_modifier='总数:', $total_page_modifier=' 总页数:', $current_page_modifier=' 当前页:', $header_info_modifier='', $header_data_color = 'red'){
		if($this->page_max != 1 && $this->page_all_no != 0)
		{
			$header_info = $total_data_modifier.''.$this->page_all_no.'';
			$header_info .= $total_page_modifier.''.$this->page_max.'';
			$header_info .= $current_page_modifier.''.$this->page.' '."\r\n";
			if(!empty($header_info_modifier)) $header_info = $header_info_modifier.$header_info;
			return $header_info;
		}else{
			return NULL;
		}
	}

	private function first($first_format = '第一页')
	{
		return $this->page == 1 ? $first_format."\r\n" : ''.$first_format.''."\r\n";
	}

	private function last($last_format = '上一页')
	{
		if($this->page == 1) return $last_format."\r\n";
		return $this->page-1 == 1 ? ''.$last_format.''."\r\n" : ''.$last_format.''."\r\n";
	}

	private function page_num_format($separator=' ', $left_modifier='[', $right_modifier=']', $both_sides=false, $current_page_color = 'red')
	{
		empty($separator) ? $separator = ' ' : $separator;
		$page_array = '';
		if($this->page_max <= $this->page_len)
		{
			for ($i=0; $i < $this->page_max; $i++)
			{
				if($this->page_no_array[$i] == $this->page)
				{
					$the[$i] = ''.$left_modifier.$this->page_no_array[$i].$right_modifier.''."\r\n";
				}else{
					if($i == 0)
					{
						$page_one = substr($this->URL,0,strlen($this->URL)-1);
						$the[$i] = ''.$left_modifier.$this->page_no_array[$i].$right_modifier.''."\r\n";
					}else{
						$the[$i] = ''.$left_modifier.$this->page_no_array[$i].$right_modifier.''."\r\n";
					}
				}
				$page_array .= $the[$i].$separator;
			}
			if($both_sides === false)
			{
				$page_array = substr($page_array,0,strrpos($page_array, $separator));
			}elseif ($both_sides === true){
				$page_array = $separator.$page_array;
			}else{
				throw new Exception('ERROR: $both_sides must be a boolean type.');
			}
		}else{
			if($this->page <= $this->page_change)
			{
				$i_start = 0;
			}else{
				$i_start = $this->page - $this->page_change;
				//如果最大的页码已显示,那么开始页就不会在递增
				if($i_start >= $this->page_max - $this->page_len){
					$i_start = $this->page_max - $this->page_len;
				}
			}
			$i_end = ($i_start+$this->page_len) - 1;
			for ($i = $i_start; $i <= $i_end; $i++)
			{
				if($this->page_no_array[$i] == $this->page)
				{
					$the[$i] = ''.$left_modifier.$this->page_no_array[$i].$right_modifier.''."\r\n";
				}else{
					if($i == 0)
					{
						$page_one = substr($this->URL,0,strlen($this->URL)-1);
						$the[$i] = ''.$left_modifier.$this->page_no_array[$i].$right_modifier.''."\r\n";
					}else{
						$the[$i] = ''.$left_modifier.$this->page_no_array[$i].$right_modifier.''."\r\n";
					}
				}
				$page_array .= $the[$i].$separator;
			}
			if($both_sides === false)
			{
				$page_array = substr($page_array,0,strrpos($page_array, $separator));
			}elseif ($both_sides === true){
				$page_array = $separator.$page_array;
			}else{
				throw new Exception('ERROR: $both_sides must be a boolean type.');
			}
		}
		return $page_array;
	}

	private function next($next_format = '下一页')
	{
		if($this->page >= $this->page_max) return $next_format."\r\n";
		return ''.$next_format.''."\r\n";
	}

	private function end($end_format = '最后一页')
	{
		return $this->page >= $this->page_max ? $end_format."\r\n" : ''.$end_format.''."\r\n";
	}

	public function select_page($target='self', $select_page_mode='PMA', $value_left_modifier='', $value_right_modifier='')
	{
		if($this->page_max != 1 && $this->page_all_no != 0)
		{
			if($select_page_mode === 'NORMAL')
			{
				$page_no_array = $this->page_no_array;
			}elseif($select_page_mode === 'PMA'){
				$page_no_array = $this->PMA_page_no_array();
			}else{
				throw new Exception('$select_page_mode is unknown mode');
			}
			$select_page = '';
			$select_page .= ''. "\n";
			return $select_page;
		}else{
			return NULL;
		}
	}

	private function PMA_page_no_array()
	{
		$showAll = 200;
		$sliceStart = 5;
		$sliceEnd = 5;
		$percent = 20;
		$range = 10;

		if ($this->page_max < $showAll)	{
			$this->PMA_page_no_array = range(1, $this->page_max);
		} else {
			$this->PMA_page_no_array = array();
			for ($i = 1; $i <= $sliceStart; $i++) {
				$this->PMA_page_no_array[] = $i;
			}
			for ($i = $this->page_max - $sliceEnd; $i <= $this->page_max; $i++) {
				$this->PMA_page_no_array[] = $i;
			}
			$i = $sliceStart;
			$x = $this->page_max - $sliceEnd;
			$met_boundary = false;
			while ($i <= $x) {
				if ($i >= ($this->page - $range) && $i <= ($this->page + $range)) {
					$i++;
					$met_boundary = true;
				} else {
					$i = $i + floor($this->page_max / $percent);
					if ($i > ($this->page - $range) && !$met_boundary) {
						$i = $this->page - $range;
					}
				}
				if ($i > 0 && $i <= $x) {
					$this->PMA_page_no_array[] = $i;
				}
			}
			sort($this->PMA_page_no_array);
			$this->PMA_page_no_array = array_unique($this->PMA_page_no_array);
		}
		return $this->PMA_page_no_array;
	}

	public function key_change_page(){
		echo '';
	}

	public function eshow()
	{
		return $this->last().$this->next();
	}

	public function showForHelp()
	{
		return $this->first('首页', '').$this->last('上一页', '').$this->page_num_format('', '', '', false, '#FF8500').$this->next('下一页', '').$this->end('尾页', '');
	}

	public function show()
	{
		return $this->header_info().$this->first('首页', '').$this->last('上一页', '').$this->page_num_format('', '', '', false, '#FF8500').$this->next('下一页', '').$this->end('尾页', '');
	}
}

使用方法:


header('content-type:text/html;charset=utf-8');
include('Page.class.php');
$page_all_no = 12000; //数据的总条数
$page_num = 25; //设置每页显示的条数
$page_len = 7; //最多显示的页码数
$page = new Page($page_all_no, $page_num, $page_len);
$start_num = $page->start_num;
$sql = "select * from table limit {$start_num}, {$page_num}";
$page->key_change_page(); //方向键翻页
var_dump($sql);
//自带三种分页形式,可再按需要添加新方法,像下面那样调用
echo '

'.$page->select_page('self', 'NORMAL').'

'; //这里的第二个参数默认为PMA模式,两种模式差别在上面已给出 echo '

'.$page->eshow().'

'; echo '

'.$page->show().'

';

[Laravel4] 短网址之统计每日点击数

使用redis计数,laravel4里面默认使用的是predis,这里我使用的是phpredis库,首先注释掉app/config/app.php里面的Redis的alias

// 'Redis'           => 'Illuminate\Support\Facades\Redis',

实现代码

使用redis的sorted set储存每日的每个链接的点击次数

$config = Config::get('database.redis.default');
with($redis = new Redis)->connect($config['host'], $config['port']);
$redis->zIncrBy(date('Ym:d'), 1, $link->id);

统计数据,取出当天点击数最多的10个链接的id

$redis->zRevRange(date('Ym:d'), 0, 9);

[Laravel4] 短网址之API

我们提供三种格式的API, txt json jsonp

代码

路由

Route::get('short.txt', 'ShortController@txt');
Route::get('short.json', 'ShortController@json');
Route::get('short.jsonp', 'ShortController@jsonp');

控制器

public function txt() {
	$validator = Validator::make(Input::all(), [
				'url' => 'required|max:255|url',
			]);
	if ($validator->fails()) {
		return implode(PHP_EOL, $validator->errors()->all());
	}
	$url = Input::get('url');
	$hash = md5($url);
	$link = Link::whereHash($hash)->first();
	if (!$link)
		$link = Link::create(compact('url', 'hash'));
	$shorten = \Lib\Base62::encode($link->id);
	return 'http://usr.im/' . $shorten;
}

public function json() {
	$resp = [];
	$validator = Validator::make(Input::all(), [
				'url' => 'required|max:255|url',
			]);
	if ($validator->fails()) {
		return ['status' => 'failed', 'message' => $validator->errors()->all()];
	}
	$url = Input::get('url');
	$hash = md5($url);
	$link = Link::whereHash($hash)->first();
	if (!$link)
		$link = Link::create(compact('url', 'hash'));
	$shorten = \Lib\Base62::encode($link->id);
	return ['status' => 'success', 'content' => 'http://usr.im/' . $shorten];
}

public function jsonp() {
	$resp = [];
	Validator::extend('callback', function($attribute, $value, $parameters) {
		return preg_match('/^[A-z_]\w*$/i', $value);
	});
	$validator = Validator::make(Input::all(), [
				'url' => 'required|max:255|url',
				'callback' => 'required|max:255|callback',
			]);
	if ($validator->fails()) {
		return Response::json(['status' => 'failed', 'message' => $validator->errors()->all()])
						->setCallback(Input::get('callback'));
	}
	$url = Input::get('url');
	$hash = md5($url);
	$link = Link::whereHash($hash)->first();
	if (!$link)
		$link = Link::create(compact('url', 'hash'));
	$shorten = \Lib\Base62::encode($link->id);
	return Response::json(['status' => 'success', 'content' => 'http://usr.im/' . $shorten])
					->setCallback(Input::get('callback'));
}

[Laravel4] 实战之短网址

数据库表结构

CREATE TABLE `u_links` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `url` varchar(255) NOT NULL DEFAULT '',
  `hash` varchar(32) NOT NULL,
  `hits` int(10) unsigned NOT NULL DEFAULT '0',
  `created_at` datetime NOT NULL,
  `updated_at` datetime NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `hash` (`hash`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

虽然理论上url可以很长,但是这里约束一下255

目录结构

这里仅列出需要动到的目录和文件

app/config             配置文件目录
app/controllers        控制器
app/models             模型
app/views              视图
app/lib                自己建的,方便放一些公用库
app/routes.php         路由

代码

对于短网址的算法不再说明,网上很多,这里使用base62来处理

配置文件

app/config/app.php

  1. 打开debug
  2. 修改时区为'Asia/Shanghai'
  3. 修改key,可使用artisan生成php artisan key:generate

app/config/database.php

  1. 修改mysql的配置

定路由

// 显示首页
Route::get('/', 'HomeController@index');
// 网址转向
Route::get('{shorten}', 'HomeController@redirect')
	->where('shorten', '[0-9A-z]+');
// 网址点击统计
Route::get('{shorten}!', 'HomeController@show')
	->where('shorten', '[0-9A-z]+');

控制器

由于HomeController本身就存在,所以我们不需要生成或新建。 这里我们会用到base62的库,附件中会给出QQ20130519-2.png

贴代码:

public function index() {
	$shorten = '';
	$url = Input::get('url');
	if (!is_null($url)) {
		$validator = Validator::make(compact('url'), [
				'url' => 'required|max:255|url',
			]);
		if ($validator->fails())
			return Redirect::to('/')->withInput()->withErrors($validator->errors());
		$hash = md5($url);
		$link = Link::whereHash($hash)->first();
		if (!$link)
			$link = Link::create(compact('url', 'hash'));
		$shorten = \Lib\Base62::encode($link->id);
	}
	return View::make('home.index')
				->with(compact('url', 'shorten'));
}
public function redirect($shorten) {
	$id = \Lib\Base62::decode($shorten);
	$link = Link::find($id);
	if ($link) {
		$link->increment('hits');
		return Redirect::to($link->url, 301);
	}
	App::abort(404);
}
public function show($shorten) {
	$id = \Lib\Base62::decode($shorten);
	$link = Link::find($id);
	if ($link) {
		return View::make('home.show')
					->with($link->toArray());
	}
	App::abort(404);
}

Base62.zip

[Laravel4] 安装

安装composer

# 由于使用的MAMP,指定php
export PATH=/Applications/MAMP/bin/php/php5.4.10/bin:$PATH

mkdir /Applications/composer
cd /Applications/composer

curl -sS https://getcomposer.org/installer | php
mv composer{.phar,}
# PATH加路径
vi ~/.zshrc
# :/Applications/composer
. ~/.zshrc

安装laravel4

# 用git://没成功,可能是公司端口的原因
git clone -b develop https://github.com/laravel/laravel.git l4
cd l4
composer install

2013/06/22 22:37更新

不加--prefer-dist的话安装下来有100多M

composer create-project laravel/laravel . --prefer-dist

获取wav时长

duration = filesize / byterate

获取wav文件的byterate

wav-sound-format.gif

图片来自:WAVE PCM soundfile format

<?php

function ascii2hex($ascii) {
    $ascii = strrev($ascii);
    $hex = '';
    for ($i = 0; $i < strlen($ascii); $i++) {
        $byte = dechex(ord($ascii{$i}));
        $byte = str_pad($byte, 2, '0', STR_PAD_LEFT);
        $hex .= $byte;
    }
    return $hex;
}

$file = fopen('test.wav', 'rb');
fseek($file, 28);
$byterate = fread($file, 4);
fclose($file);

$byterate = hexdec(ascii2hex($byterate));

echo filesize('test.wav') / $byterate / 60 . PHP_EOL;

php拾遗

php中的三目运算

// 可省略第一个,写了这么长时间的php,还真不知道,以前只知道C#的双问号,还特地搜过php是否有类似的操作符的
// laravel uri.php 56行
trim($uri, '/') ?: '/';

array_diff

两个单元仅在 (string) $elem1 === (string) $elem2 时被认为是相同的。

不直接使用 array_filter,是因为它默认根据元素的bool值来的

<?php
if(0) {
    var_dump((string)true); // "1"
    var_dump((string)false); // ""
}
// laravel uri.php 102行
array_diff($segments, array(''));</code></pre><h3>php对象链</h3><pre class="prettyprint"><code class="language-php">// php5.3会出错, 5.4正常:(new A())->a();
// laravel helpers.php 499行
function with($object) {
    return $object;
}

with(new A()) -> a();

php中正确获取程序路径

首先说说$_SERVER['DOCUMENT_ROOT']这个变量,这个变量是由apache的配置文件里面的documentroot决定的(当然你要是用的不是apache,那就是由其他服务器决定的),一般情况之下还是可靠的,近日,用到了apache中的alias,然后alias的目录不在virtualhost的documentroot中,于是alias的目录中用$_SERVER['DOCUMENT_ROOT']来计算文件的引入路径就出错了。

看看几个较流行的框架

Slim

public function root() {
        return rtrim($_SERVER['DOCUMENT_ROOT'], '/') . rtrim($this->request->getRootUri(), '/') . '/';
    }

Laravel

if ( ! defined('DS')) {
	define('DS', DIRECTORY_SEPARATOR);
}

$GLOBALS['laravel_paths']['base'] = __DIR__.DS;

于是slim嗝屁之,laravel依然风骚。由于laravel要求最低是php5.3,而__DIR__是5.3才有的,那在php之前的版本下使用dirname(__FILE__)就好了。

discuzx模块数据调用

后台 > 门户 > 模块管理 > 数据调用

语法

DIY模块模板语法详解

[loop]...[/loop]标签来循环显示模块中的数据;如果要在模板中多处循环可以使用[loop1]...[/loop1]的方式扩展(只能扩展1-9个)

[order=N]...[/order]标签来替代默认loop中的第N个位置数据的展示,你可以使用[order1=N]...[/order1]的方式来扩展(对应[loop1],只能扩展1-9个)

其中:[order=odd]为奇数行,[order=even]为偶数行
[index=N]...[/index]的方式来指定第N条数据的展示方式,由该语法指定的数据不再在loop循环中出现,可以通过[index1]...[/index1]的方式来扩展(只能扩展1-9个)以实现同一条数据多处展示

实例

[index=1]

{title}

{summary} [详细]

[/index]

YII修改CGridView默认排序

CSort里面是有一个defaultOrder的属性,但是GII自动生成的CURD不能这么来;后来找到个帖子(Model Search - Merging in a default start criteria),里面写的比较详细。但是他在Controller里面的条件判断需要改下。

$merge = new CDbCriteria;
if(empty($_GET['Depart_sort'])) {
	$merge->order = 'displayorder DESC';
}

主要的流程就是:

  1. 在控制器里面判断用户是否有指定排序字段,若没有则加上默认排序字段
  2. 传变量到模版里,由用户浏览页面,执行search
  3. model里面合并criteria的order条件

php杂记2

glob函数

// 获取所有php和txt文件,必须指定第二个参数为GLOB_BRACE才能使用{}
$files = glob('*.{php,txt}', GLOB_BRACE);

// 按照文件的修改时间排序
usort($files, create_function('$a,$b', 'return filemtime($a) - filemtime($b);'));

RecursiveDirectoryIterator

// 深度遍历文件夹
$path = realpath('/etc');

$objects = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path), RecursiveIteratorIterator::SELF_FIRST);
foreach($objects as $name => $object){
    echo $name . PHP_EOL;
}

PHP5.3下SQLSTATE[HY000] [2002] 非法的参数解决方案

将localhost改成127.0.0.1

来自:链接