标签归档:php

PHP写的发送邮件(测试无问题)

<?php
function send_mail($to, $subject = ‘No subject’, $body) {
$loc_host = “test”;                 //发信计算机名,可随意
$smtp_acc = “xxx@qq.com”;        //Smtp认证的用户名,类似fuweng@im286.com,或者fuweng
$smtp_pass=”*******”;              //Smtp认证的密码,一般等同pop3密码
$smtp_host=”smtp.qq.com”;    //SMTP服务器地址,类似 smtp.tom.com
$from=”xxxx@qq.com”;              //发信人Email地址,你的发信信箱地址
$headers = “Content-Type: text/plain; charset=”utf-8″
Content-Transfer-Encoding: base64″;
$lb=”
“;                         //linebreak

$hdr = explode($lb,$headers);     //解析后的hdr
if($body) {
$bdy = preg_replace(“/^./”,”..”,explode($lb,$body));   //解析后的Body
}

$smtp = array(
//1、EHLO(是客户端向对方邮件服务器发出的标识自己身份的命令),期待返回220或者250
array(“EHLO “.$loc_host.$lb,”220,250”,”HELO error: “),
//2、发送Auth Login,期待返回334
array(“AUTH LOGIN”.$lb,”334″,”AUTH error:”),
//3、发送经过Base64编码的用户名,期待返回334
array(base64_encode($smtp_acc).$lb,”334″,”AUTHENTIFICATION error : “),
//4、发送经过Base64编码的密码,期待返回235
array(base64_encode($smtp_pass).$lb,”235”,”AUTHENTIFICATION error : “)
);
//5、发送Mail From,期待返回250
$smtp[] = array(“MAIL FROM: <“.$from.”>”.$lb,”250″,”MAIL FROM error: “);
//6、发送Rcpt To。期待返回250(0K)
$smtp[] = array(“RCPT TO: <“.$to.”>”.$lb,”250″,”RCPT TO error: “);
//7、发送DATA,期待返回354
$smtp[] = array(“DATA”.$lb,”354″,”DATA error: “);
//8.0、发送From
$smtp[] = array(“From: “.$from.$lb,””,””);
//8.2、发送To
$smtp[] = array(“To: “.$to.$lb,””,””);
//8.1、发送标题
$smtp[] = array(“Subject: “.$subject.$lb,””,””);
//8.3、发送其他Header内容
foreach($hdr as $h) {$smtp[] = array($h.$lb,””,””);}
//8.4、发送一个空行,结束Header发送
$smtp[] = array($lb,””,””);
//8.5、发送信件主体
if($bdy) {foreach($bdy as $b) {$smtp[] = array(base64_encode($b.$lb).$lb,””,””);}}
//9、发送“.”表示信件结束,期待返回250
$smtp[] = array(“.”.$lb,”250″,”DATA(end)error: “);
//10、发送Quit,退出,期待返回221
$smtp[] = array(“QUIT”.$lb,”221″,”QUIT error: “);

//打开smtp服务器端口
$fp = @fsockopen($smtp_host, 25);
if (!$fp) echo “Error: Cannot conect to “.$smtp_host.””;
while($result = @fgets($fp, 1024)){
if(substr($result,3,1) == ” “) { break; }
}

$result_str=””;
//发送smtp数组中的命令/数据
foreach($smtp as $req){
//发送信息
@fputs($fp, $req[0]);// fputs(字符串,文件指针)
//如果需要接收服务器返回信息,则
if($req[1]){
//接收信息
while($result = @fgets($fp, 1024)){
if(substr($result,3,1) == ” “) { break; }
};
if (!strstr($req[1],substr($result,0,3))){
$result_str.=$req[2].$result.””;
}
}
}
//关闭连接
@fclose($fp);
return $result_str;
}
if(@$_POST[‘sub’])
{
$email_from=@$_POST[’email_from’];
$email_title=@$_POST[’email_title’];
$email_content=@$_POST[’email_content’];

echo  send_mail($email_from,$email_title,$email_content);
}
?>
<!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 4.01 Transitional//ENhttp://www.w3.org/TR/html4/loose.dtd”>
<html lang=”en”>
<head>
<meta http-equiv=”Content-Type” content=”text/html;charset=UTF-8″>
<title></title>
</head>
<body>
<form method=”post”>
收件人邮箱<input type=”text” name=”email_from” onkeyup=”this.value.replace(^[w-]+(.[w-]+)*@[w-]+(.[w-]+)+$)”>
标题<input type=”text” name=”email_title”>
内容<input type=”text” name=”email_content”>
<input type=”submit” name=”sub” value=”发送右键”>
</form>
</body>
</html>

PHP写无限分类菜单

/**

* find_child,对于数组$arr,给定一个id,获取其子节点构成的一维数组

* @param $arr array 要遍历的数组

* @param $id int 该条记录的id,默认值为0

* @return array 返回$id记录对应的子节点数组

*/

function find_child($arr,$id=0){

$child = array();

foreach ($arr as $v) {

if($v[‘pid’] == $id){

$child[] = $v;

}

}

return $child;

}

/**

* get_tree,对于数组$arr,给定一个根,获取其子孙节点构成的多维数组

* @param $arr array 要遍历的数组

* @param $root_id int 根节点 id,默认为0

* @return array 返回$root_id节点对应的子孙节点构成的多维数组

*/

function get_tree($arr,$root_id=0){

$child = find_child($arr,$root_id);

if(empty($child)){

return null;

}

foreach ($child as $k => $v) {

$current_tree = get_tree($arr,$v[‘id’]);

if ($current_tree != null) {

$child[$k][‘child’] = $current_tree;

}

}

return $child;

}

PHP二分查找(必须掌握)

<?php
/*
*  二分查找(必须是有顺序数)必须掌握
*  @arr 要被查找的数组
*  @findvl  要查找的数
*  @right   右边的数组
*  @left    左边数组
*  @middle  中间的数
*/
$arr=array(-1,0,40,90);
function binarysearch(&$arr,$findval,$left,$right)
{
if($right<$left)
{
echo “找不到此数”;
return ;
}
$middle=round(($right+$left)/2);
if($findval>$arr[$middle])
{
binarysearch($arr,$findval,$middle+1,$right);
}else if($findval<$arr[$middle])
{
binarysearch($arr,$findval,$left,$middle-1);
}else
{
echo $middle;
}
}
binarysearch($arr,0,0,count($arr));