存档

文章标签 ‘PHP’

一个有意思的日期逻辑处理

2011年7月19日 3 条评论

今天处理了一个很小的问题。
需求是这样的,从周一到周日只能看到上周一到上周日的数据。
这里直接从数据库里根据 date 字段查询 范围即可。
但需要PHP生成 开始日期和结束日期。

最开始,我直接这么处理。

$start_date = date('Y-m-d' , strtotime("-2 week monday"));
$end_date = date('Y-m-d' , strtotime("$start_date +6 day"));

假如日期是 2011-07-19,$start_date= 2011-07-11 这样处理没有问题。
如果日期是 2011-07-18 ,$start_date 则会等于 2011-07-04,还活在上周。

于是换了种方法

$getWeekDay = date("w");
$startDay = date("Y-m-d", mktime(0, 0, 0, date("m"), date("d") - $getWeekDay + 1 - 7, date("Y")));
$endDay = date("Y-m-d", strtotime("+6 day $startDay"));

假如日期是 2011-07-19,$start_date= 2011-07-11 这样处理没有问题,和我们期望的一样。
如果日期是 2011-07-24,我们期望的 $start_date 是 2011-07-11,但实际返回的是 2011-07-18。

不得已,我再改了下方法

$getWeekDay = date("N") ;
$startDay = date("Y-m-d", mktime(0, 0, 0, date("m"), date("d") - $getWeekDay + 1 - 7, date("Y")));
$endDay = date("Y-m-d", strtotime("+6 day $startDay"));

这下就OK 了。

分类: PHP开发 标签:

PHP几个不常用但很有用的函数

2011年6月29日 没有评论
  • glob()

直接print_r(glob(‘*’)) 看看效果吧。

再  print_r(glob(‘*.PHP’)) 再看看效果吧。

———————————-

  • PHP Filter函数

PHP自带的filter函数。直接可以用来验证email,IP等。也可以用来验证 INPUT等。

具体见这里 http://php.net/manual/en/book.filter.php

———————————-

  • get_browser()

获得浏览器信息的。

———————————-

  • sys_getloadavg()

这个函数只针对linux系统有用。

可以用来监测系统的负载。 其值就是linux的 load average值。


分类: PHP开发 标签:

PHP CURL CURLOPT_HTTPHEADER设置HOST

2010年9月25日 没有评论

为了安全,我们的web服务主机往往不能上网。维护的时候,也是通过跳板机,ssh登录后去操作。

有时候我们的程序需要访问外网。比如需要调用外网其他程序的某个接口。这下该怎么办呢?

我们可以通过PHP的CURL函数的CURLOPT_HTTPHEADER来配置设置host访问。

在开发中,我遇到这样一个例子。

有一个活动程序,需要调用qzone那边的一个接口。

如下代码示例:

$host = array("Host: act.qzone.qq.com");
$data = 'user=xxx&qq=xxx&id=xxx&post=xxx';
$url = 'http://192.168.1.12/xxx/xxx/api/';
var_dump( $this->curl_post($host, $data,$url) );

/
* 提交请求
* @param $host array 需要配置的域名 array("Host: act.qzone.qq.com");
* @param $data string 需要提交的数据 'user=xxx&qq=xxx&id=xxx&post=xxx'....
* @param $url string 要提交的url 'http://192.168.1.12/xxx/xxx/api/';
*/
 function curl_post($host,$data,$url)
    {
       $ch = curl_init();
       $res= curl_setopt ($ch, CURLOPT_URL,$url);
       var_dump($res);
       curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
       curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
       curl_setopt ($ch, CURLOPT_HEADER, 0);
       curl_setopt($ch, CURLOPT_POST, 1);
       curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
       curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
       curl_setopt($ch,CURLOPT_HTTPHEADER,$host);
       $result = curl_exec ($ch);
       curl_close($ch);
       if ($result == NULL) {
           return 0;
       }
       TMDebugUtils::debugLog($result);
       return $result;
    }

通过PHP CURL CURLOPT_HTTPHEADER设置HOST很方便的解决了访问外网接口的问题。

分类: PHP开发 标签: , ,

php pdo insert, pdo insertId – pdo笔记四

2010年4月7日 2 条评论

php pdo insert 和 update 数据 都可以通过

execute(); 函数来操作。

如果操作成功,则返回true,否则为false。

pdo要获得最后插入的id,可以通过 lastInsertId() 函数来获得。

示例代码:

$dbconn = array(
	'dns'=>"mysql:host=localhost;dbname=soa",
	'dbuser'=>'root',
	'dbpwd'=>'123456'
);
try{
	$db = new PDO($dbconn['dns'],$dbconn['dbuser'],$dbconn['dbpwd']);
	$db->query("set names utf8");
	$update = "update wp_links set link_url = 'www.163.com' where link_id=1";
	$insert = "insert into wp_links (link_url,link_name) values('www.gosoa.com.cn','scofield博客')";
 	$db->exec($insert);
	echo $db->lastInsertId();

}catch(PDOException  $e)
{
	echo $e->getMessage();
}

exec() 函数就是来执行 insert update delete 这些操作的。
而很常用的select操作 大多用 query函数。 php pdo mysql query

pdo fetch,pdo fetchAll,pdo query,pdo prepare使用 – pdo笔记三

2010年4月7日 1 条评论

通过pdo来从数据库中调取数据。
其中主要涉及到 pdo fetch,pdo fetchAll,pdo query,pdo prepare使用 。
可以通过以下几种方式。
第一、

$dbconn = array(
	'dns'=>"mysql:host=localhost;dbname=gosoa",
	'dbuser'=>'root',
	'dbpwd'=>'123456'
);
try{
	$db = new PDO($dbconn['dns'],$dbconn['dbuser'],$dbconn['dbpwd']);
	$db->query("set names utf8");
	$sql = "SELECT * FROM wp_posts  ";
	$query = $db->query($sql);
	foreach($query as $rs)
	{
		print_r($rs);
	}
}catch(PDOException  $e)
{
	echo $e->getMessage();
}

第二种、

try{
	$db = new PDO($dbconn['dns'],$dbconn['dbuser'],$dbconn['dbpwd']);
	$db->query("set names utf8");
	$sql = "SELECT * FROM wp_posts limit 2";
	$query = $db->query($sql);
	$result = $query->fetchAll();
	print_r($result);

}catch(PDOException  $e)
{
	echo $e->getMessage();
}

第三种

try{
	$db = new PDO($dbconn['dns'],$dbconn['dbuser'],$dbconn['dbpwd']);
	$db->query("set names utf8");
	$sql = "SELECT * FROM wp_posts limit 2";
	$query = $db->query($sql);
	$result = $query->fetch();
	foreach($query as $rs)
	{
		print_r($rs);
	}

}catch(PDOException  $e)
{
	echo $e->getMessage();
}

第四种

try{
	$db = new PDO($dbconn['dns'],$dbconn['dbuser'],$dbconn['dbpwd']);
	$db->query("set names utf8");
	$sql = "SELECT * FROM wp_posts where ID = :id ";
	$sth = $db->prepare($sql);
	$sth->execute(array(':id'=>'12'));
	$rs = $sth->fetchAll();
	print_r($rs);

}catch(PDOException  $e)
{
	echo $e->getMessage();
}

pdo fetch,pdo fetchAll,pdo query,pdo prepare使用 基本的就这些。

其他很详细的信息,去查 php手册吧。

呵呵。

pdo 编码 pdo乱码 问题 解决方法 – pdo笔记二

2010年4月7日 没有评论

在php pdo 查询中文的时候,出现了乱码。
郁闷了老半天不知道什么原因。
让 php文件的编码 数据库的编码 都保持一致。(我的是UTF8)
但查询出来的还是乱码

后来想起了 mysql_query()函数可以设置编码
mysql_query(“set names utf8″);

于是,就采用同上的方法。
解决pdo中文乱码问题。

$db = new PDO($dbconn['dns'],$dbconn['dbuser'],$dbconn['dbpwd']);
$db->query(“set names utf8″);

这样,便解决了 pdo 编码问题。

总结下,php中文乱码问题,pdo中文乱码问题 ,mysql中文乱码等都因为这些东东不是我们中国人搞的,最开始都基本不支持中文。以后中文强大了,可以搞个中文编程工具。
比如 : 如果(1==1)
{
执行。。。
}
哈哈。

分类: PHP开发 标签: , , , ,

php pdo mysql query – pdo笔记一

2010年4月7日 没有评论

最近想把php pdo 一些相关函数再温习一遍。

php pdo 链接mysql 如下

$dbconn = array(
	'dns'=>"mysql:host=localhost;dbname=gosoa",
	'dbuser'=>'root',
	'dbpwd'=>'123456'
);
try{
$db = new PDO($dbconn['dns'],$dbconn['dbuser'],$dbconn['dbpwd']);
$sql = "SELECT * FROM yourtable limit 0,2";
	$query = $db->query($sql);
	foreach($query as $rs)
	{
		print_r($rs);
	}
}catch(PDOException  $e)
{
	echo $e->getMessage();
}

上面的代码就是 php pdo 链接mysql的代码。
$db = new PDO($dbconn['dns'],$dbconn['dbuser'],$dbconn['dbpwd']);
这句话也就是调用了 PDO的__construct函数。
PDO::__construct
( string dsn [, string username [, string password [, array driver_options]]] )

如果要通过PHP POD 链接 DOBC , 则 可以这样 odbc:DSN=SAMPLE;UID=john;PWD=mypass .

更多的 PHP PDO 详细信息,去查阅 php手册吧。

分类: PHP开发 标签: , , ,

十个PHP开发技巧

2010年4月7日 1 条评论

1、如何正确的创建一个网站的Index页面

创建每一个网站时,建立网站的index页面是首要做的事情之一。如果你是一个PHP新手,在编写index页面时典型的做法是只对index页面 所需的内容进行编程,其它链接创建另一个页面。不过,如果想学习一种更高效的方式来实现PHP编程,可以采用“index.php?page=home” 模式,许多网站都在采用这种模式。

2、使用Request Global Array抓取数据

实际上我们没有任何理由使用$_GET和$_POST数组来抓取数值。$_REQUEST这个全局数组能够让你获取一个get或form请求。因 此,多数情况下解析数据的更高效代码大体如下:

$action = isset($_REQUEST['action']) ? $_REQUEST['action'] : 0;

3、利用var_dump进行PHP代码调试

如果你在寻找php调试技术,我必须说var_dump应该是你要找的目标。在显示php信息方面这个命令可以满足你的所有需要。而调试代码的多数 情况与得到PHP中的数值有关。

4、PHP处理代码逻辑,Smarty处理展现层

Smarty是一个使用PHP写出来的模板PHP模板引擎,是目前业界最著名的PHP模板引擎之一。它分离了逻辑代码和外在的内容,提供了一种易于 管理和使用的方法,用来将原本与HTML代码混杂在一起PHP代码逻辑分离。简单的讲,目的就是要使PHP程序员同前端人员分离,使程序员改变程序的逻辑 内容不会影响到前端人员的页面设计,前端人员重新修改页面不会影响到程序的程序逻辑,这在多人合作的项目中显的尤为重要。

5、的确需要使用全局数值时,创建一个Config文件

动辄创建全局数值是一种糟糕的做法,不过有时候实际情况的确又需要这么做。对于数据库表或数据库连接信息使用全局数值是一个不错的想法,但不要在你 的PHP代码中频繁使用全局数值。另外,更好的一种做法是把你的全局变量存放在一个config.php文件中。

6、如果未定义,禁止访问!

如果你正确的创建了页面,那么任何其他人没有理由访问index.php或home.php之外的index.php页面。一旦index.php 被访问后,你可以通过获得变量的方式来打开需要的页面。你的index页面应该包含类似的以下代码:

define(‘yourPage’,1);

然后,其它页面应该包含:

if (!defined(‘yourPage’)) die(‘Access Denied’);

这么做的目的是防止直接访问你的其它php页面。这样,任何试图不通过index.php访问其它网页的人,将得到“访问被拒绝”的消息。

7、创建一个数据库类

如果你正在进行数据库编程(在PHP中非常常见的任务),一个不错的想法是创建一个数据库类来处理任何数据库管理功能。示例代码如下:

public function dbExec($query)
{
	$result = $this->db->exec($query);
	if (PEAR::isError($result))
	errorRedirect($result->getMessage(), true);
	else
	return $result;
}

这个函数仅接收一个查询语句并对其执行。它还处理可能出现的任何错误。你还可以在这儿包含审核代码,不过我更喜欢使用一个类似的审核函数:

function sanitizeInput()
{
	$numargs = func_num_args();
	$arg_list = func_get_args();
	for ($i = 0; $i < $numargs; $i++)
	{
		if (!is_numeric($arg_list[$i]) || $arg_list[$i] < 0)
		errorRedirect("Unexpected variable value", true);
	}

}

8、一个php文件处理输入,一个class.php文件处理具体功能

不让代码变得混乱的一个重要方法是:获取用户输入后,将其重定向到其它函数来进行处理。原理非常简单,php文件获得我们需要的任何输入,然后将其 执行重定向到类文件中的一个函数。举例来讲,假设有一个类似“index.php?page=profile&action=display”的 URL。由profile.php来检索该网址并得到操作是“display”。然后使用一个简单的switch函数,我们来执行真正的显示函数:

require_once PROJECTROOT.'libs/messages.class.php';
$message = new Message();
switch ($action)
{
	case 'display':
	$message->display();
	break;
   ...

如上所示,我使用了一个消息类,然后开始进行switch检查。$message只是被类中的调用函数使用的一个对象。

9、了解你的SQL语句,并总是对其审查(Sanitize)

正如我以前所提到的,任何php网站中最重要的部分有99%的可能是数据库。因此,你需要非常熟悉如何正确的使用sql。学会关联表和更多高级技 术。下面我将展示一个使用MySQL的函数示例,并使用本文第7条函数进行审查。

private function getSentMessages($id)
{
	$this->util->sanitizeInput($id);
	$pm_table = $GLOBALS['config']['privateMsg'];
	$users = $GLOBALS['config']['users'];
	$sql = "SELECT PM.*, USR.username as name_sender FROM $pm_table PM, $users USR
	WHERE id_sender = '$id' AND sender_purge = FALSE AND USR.id = PM.id_receiver AND is_read = TRUE
	ORDER BY date_sent DESC";
	$result = $this->dbQueryAll($sql);
	return $result;
}

首先,我们对用户输入进行检查(通过一个GET变量传递消息id),然后我们执行我们的SQL命令。注意这儿SQL的用法。你需要了解如何使用别名 和关联表。

10、当你只需要一个对象时,使用单例模式

在PHP中相当常见的一种情形时,我们只需要创建一个对象一次,然后在我们的整个程序中使用它。一个很好的例子就是smarty变量,一旦被初始化 后就可以在任何地方使用。这种情形的一个很好实现方案就是单例模式。示例代码如下:

functionsmartyObject()
{
	if($GLOBALS['config']['SmartyObj']==0)
	{
		$smarty=newSmartyGame();
		$GLOBALS['config']['SmartyObj']=$smarty;
	}
	else
	$smarty=$GLOBALS['config']['SmartyObj'];
	return$smarty;
}

注意,我们拥有一个全局smarty变量(该示例中它在config.php中被初始化),如果它的值为0,我们将创建一个新smarty对象。否则,它意味着该对象已经被创建,我们只需要返回它。

分类: PHP开发 标签: ,

php上传文件代码示例

2010年4月2日 没有评论

php上传文件也很容易。

看下面代码

if($_POST['action']=='upload'){
	$InputName=$_POST['InputName'];
	$fileType=array('jpg','gif','png','JPG','GIF','PNG');//允许上传的文件类型
	$upfileDir='../../photo/myPhoto/';
	$smallupfileDir='../../photo/myPhoto/smallPhoto/';
	$maxSize=400; //单位:KB

	if(!in_array(substr($_FILES['file1']['name'],-3,3),$fileType))
		die("");

	 if(strpos($_FILES['file1']['type'],'image')===false)
		die("");

	if($_FILES['file1']['size'] > $maxSize*1024)
		die("");
	if($_FILES['file1']['error'] !=0)
		die("");
	$targetDir=dirname(__FILE__).'/'.$upfileDir;
	$targetFile=date('Ymd').time().substr($_FILES['file1']['name'],-4,4);
	$realFile=$targetDir.$targetFile;

	echo dirname(__FILE__)."
";
	echo $targetDir."
";
	echo $targetFile."
";
	echo $realFile."
";
    echo $_FILES['file1']['tmp_name'];

 if(function_exists('move_uploaded_file')){
		  //test('jpg',$_FILES['file1']['tmp_name'],$smallupfileDir.$targetFile);
		    MakeBuild($_FILES['file1']['tmp_name'],$smallupfileDir.$targetFile,150,90);
		  move_uploaded_file($_FILES['file1']['tmp_name'],$realFile) && die("");

	}
	else{
		@copy($_FILES['file1']['tmp_name'],$realFile) && die("");
	}

}

通过这个函数便可实现PHP上传。

在php上传图片的时候,我们可能还需要生成缩略图。

看下面的函数

function MakeBuild($BuildFile,$newFile,$File_width,$File_height=0,$rate=100)
{
   if(!is_file($BuildFile)){
    $this->msg("文件 ".$BuildFile." 不是一个有效的图形文件!\n\n系统无法生成该文件的缩略图!");
    return false;
   }
   $data = GetImageSize($BuildFile);
   switch($data[2]){
   case 1:
    $im = @ImageCreateFromGIF($BuildFile);
    break;
   case 2:
    $im = @ImageCreateFromJPEG($BuildFile);
    break;
   case 3:
    $im = @ImageCreateFromPNG($BuildFile);
    break;
   }
   if(!$im){
    return false;
   }
   else{
    $srcW=ImageSX($im);  # 取得原图宽度;
    $srcH=ImageSY($im); # 取得原图高度;

    $dstX=0;
    $dstY=0;

    if($File_height==0){
     $File_height = $File_width/$srcW*$srcH;
    }

    if ($srcW*$File_height>$srcH*$File_width){
     $fFile_height = round($srcH*$File_width/$srcW);
     $dstY = floor(($File_height-$fFile_height)/2);
     $fFile_width = $File_width;
    }
    else {
     $fFile_width = round($srcW*$File_height/$srcH);
     $dstX = floor(($File_width-$fFile_width)/2);
     $fFile_height = $File_height;
    }
    $ni = ImageCreateTrueColor($File_width,$File_height);
    $dstX = ($dstX<0)?0:$dstX;
    $dstY = ($dstX<0)?0:$dstY;      $dstX = ($dstX>($File_width/2))?floor($File_width/2):$dstX;
    $dstY = ($dstY>($File_height/2))?floor($File_height/s):$dstY;
    ImageCopyResized($ni,$im,$dstX,$dstY,0,0,$fFile_width,$fFile_height,$srcW,$srcH);

    ImageJpeg($ni,$newFile,$rate); # 生成缩略图;
    imagedestroy($im);     # imagedestroy(resource) 释放image关联的内存
   }
}

这样,php 上传便很容易的实现了。

本段php上传代码,也作为备份。以备哪天用到。

分类: PHP开发 标签: ,

Google Syntax Highlighter 与WordPress – tinyMCE 的兼容性

2010年3月24日 1 条评论

Google Syntax Highlighter 与WordPress的兼容性

Google Syntax Highlighter 与 tinyMCE  的兼容性

当我们在WordPress中写日志,要插入一段php代码的时候,在HTML视图下,可以如下

<pre name="code" class="php">

code....

</pre>

但当我们恢复到可视化的时候,代码就会变成

<pre  class="php">

code....

</pre>

此时, Google Syntax Highlighter 便识别不出来了。

因为 Google Syntax Highlighter 是通过 pre的 name 熟悉来识别的。

出现这样的情况,是因为 WordPress 采用的 tinyMCE 编辑器。而 tinyMCE编辑器默认 给 pre 没有添加 name 属性。

所以,我们只需要更改下 tinyMCE的初始化部分的代码即可。

在 wp-admin/includes/post.php 里面

找到如下代码

$initArray = array (
		'mode' => 'specific_textareas',
		'editor_selector' => 'theEditor',
		'width' => '100%',
		'theme' => 'advanced',
		'skin' => 'wp_theme',
		'theme_advanced_buttons1' => "$mce_buttons",
		'theme_advanced_buttons2' => "$mce_buttons_2",
		'theme_advanced_buttons3' => "$mce_buttons_3",
		'theme_advanced_buttons4' => "$mce_buttons_4",
		'language' => "$mce_locale",
		'spellchecker_languages' => "$mce_spellchecker_languages",
		'theme_advanced_toolbar_location' => 'top',
		'theme_advanced_toolbar_align' => 'left',
		'theme_advanced_statusbar_location' => 'bottom',
		'theme_advanced_resizing' => true,
		'theme_advanced_resize_horizontal' => false,
		'dialog_type' => 'modal',
		'relative_urls' => false,
		'remove_script_host' => false,
		'convert_urls' => false,
		'apply_source_formatting' => false,
		'remove_linebreaks' => true,
		'gecko_spellcheck' => true,
		'entities' => '38,amp,60,lt,62,gt',
		'accessibility_focus' => true,
		'tabfocus_elements' => 'major-publishing-actions',
		'media_strict' => false,
		'paste_remove_styles' => true,
		'paste_remove_spans' => true,
		'paste_strip_class_attributes' => 'all',
		'wpeditimage_disable_captions' => $no_captions,
		'plugins' => "$plugins"
	);

这个 $initArray 变量就是用来初始化 tinyMCE的。我们只需要给其添加上一个变量 即可:

‘extended_valid_elements’ => “pre[name|class]”

添加后 的完整代码如下:

$initArray = array (
		'mode' => 'specific_textareas',
		'editor_selector' => 'theEditor',
		'width' => '100%',
		'theme' => 'advanced',
		'skin' => 'wp_theme',
		'theme_advanced_buttons1' => "$mce_buttons",
		'theme_advanced_buttons2' => "$mce_buttons_2",
		'theme_advanced_buttons3' => "$mce_buttons_3",
		'theme_advanced_buttons4' => "$mce_buttons_4",
		'language' => "$mce_locale",
		'spellchecker_languages' => "$mce_spellchecker_languages",
		'theme_advanced_toolbar_location' => 'top',
		'theme_advanced_toolbar_align' => 'left',
		'theme_advanced_statusbar_location' => 'bottom',
		'theme_advanced_resizing' => true,
		'theme_advanced_resize_horizontal' => false,
		'dialog_type' => 'modal',
		'relative_urls' => false,
		'remove_script_host' => false,
		'convert_urls' => false,
		'apply_source_formatting' => false,
		'remove_linebreaks' => true,
		'gecko_spellcheck' => true,
		'entities' => '38,amp,60,lt,62,gt',
		'accessibility_focus' => true,
		'tabfocus_elements' => 'major-publishing-actions',
		'media_strict' => false,
		'paste_remove_styles' => true,
		'paste_remove_spans' => true,
		'paste_strip_class_attributes' => 'all',
		'wpeditimage_disable_captions' => $no_captions,
		'plugins' => "$plugins",
		'extended_valid_elements' => "pre[name|class]"
	);

保存后 再试试吧。
Google Syntax Highlighter 就与WordPress完美兼容了。
Google Syntax Highlighter 就与tinyMCE完美兼容了。