当前位置:  编程技术>php
本页文章导读:
    ▪php 用sock技术发送邮件的函数       使用sock技术发邮件,无需服务器支持。速度快!!  代码如下:function send_mail($to,$subject,$body)   {   /////////////Smtp信息,可以修改成你的,//////////      $loc_host = "longbill";        //.........
    ▪php中ob(Output Buffer 输出缓冲)函数使用方法       来自:http://bbs.phome.net/ShowThread/?threadid=9247&forumid=2  在PHP编程中,  我们经常会遇到一些直接产生输出的函数,  如passthru(),readfile(),  var_dump()  等.  但有时我们想把这些函数的输出导入.........
    ▪在普通HTTP上安全地传输密码       1。理论      在普通HTTP上,一般表单中的密码都是以明文方式传到服务器进行处理的。这无疑给了坏人以可乘之机!这里我们就说说怎么传输密码才是安全的!      与其传输密码本.........

[1]php 用sock技术发送邮件的函数
    来源: 互联网  发布时间: 2013-11-30
使用sock技术发邮件,无需服务器支持。速度快!! 

代码如下:

function send_mail($to,$subject,$body)  
{  
/////////////Smtp信息,可以修改成你的,//////////  
   $loc_host = "longbill";        //发信计算机名,可随意  
  $smtp_acc = "longbill.mail";   //Smtp认证的用户名,  
  $smtp_pass = "longbill";         //Smtp认证的密码,  
  $smtp_host = "smtp.163.com";     //SMTP服务器地址,  
  $from = "longbill.mail@163.com"; //要与smtp信息对应 ,否则会失败  
/////////////Smtp信息完//////////////////////////////////   
  $headers = "Content-Type: text/plain; charset=\"gb2312\"\r\nContent-Transfer-Encoding: base64";  
  $lb="\r\n";                    //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  
 $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 "<b>Error:</b> Cannot conect to ".$smtp_host."<br>";  
 while($result = @fgets($fp, 1024))  
 {  
    if(substr($result,3,1) == " ") { break; }  
 }  
 $result_str="";  
 //发送smtp数组中的命令/数据  
 foreach($smtp as $req)  
 {  
  //发送信息  
  @fputs($fp, $req[0]);  
  //如果需要接收服务器返回信息,则  
  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."<br>";  
    }  
   }  
 }  
 //关闭连接  
 @fclose($fp);  
 if ($result_str==""){return "发送成功!!";}else {return $result_str;}  
}

    
[2]php中ob(Output Buffer 输出缓冲)函数使用方法
    来源: 互联网  发布时间: 2013-11-30
来自:http://bbs.phome.net/ShowThread/?threadid=9247&forumid=2 
在PHP编程中,  我们经常会遇到一些直接产生输出的函数,  如passthru(),readfile(),  var_dump()  等.  但有时我们想把这些函数的输出导入到文件中,或者先经过处理再输出,  或者把这些函数的输出作为字符串来处理.   
这时我们就要用到  Output  Buffer(输出缓冲)  函数了.   

处理输出缓冲的函数主要有这么几个:   
ob_start()  开始输出缓冲,  这时PHP停止输出,  在这以后的输出都被转到一个内部的缓冲里.   

ob_get_contents()  这个函数返回内部缓冲的内容.  这就等于把这些输出都变成了字符串.   

ob_get_  length()  返回内部缓冲的长度.   

ob_end_flush()  结束输出缓冲,  并输出缓冲里的内容.  在这以后的输出都是正常输出.   

ob_end_clean()  结束输出缓冲,  并扔掉缓冲里的内容.   

举个例子,  var_dump()函数输出一个变量的结构和内容,  这在调试的时候很有用.   
但如果变量的内容里有  <  ,  >  等HTML的特殊字符,  输出到网页里就看不见了.  怎么办呢?   
用输出缓冲函数能很容易的解决这个问题.   

ob_start();   
var_dump($var);   
$out  =  ob_get_contents();   
ob_end_clean();   


这时var_dump()的输出已经存在  $out  里了.  你可以现在就输出:   

echo  '<pre>'  .  htmlspecialchars($out)  .  '</pre>'  ;   

或者等到将来,  再或者把这个字符串送到模板(Template)里再输出.  

    
[3]在普通HTTP上安全地传输密码
    来源: 互联网  发布时间: 2013-11-30
1。理论 
    在普通HTTP上,一般表单中的密码都是以明文方式传到服务器进行处理的。这无疑给了坏人以可乘之机!这里我们就说说怎么传输密码才是安全的! 
    与其传输密码本身,到不如传输其加密后的形式。MD5是个不错的选择。第一,不同的资源几乎不可能生成相同的MD5摘要,第二,MD5的编码方式是不可逆推的。有了这些特性,我们就可以让MD5摘要公开的在Internet上传输,而不必担心密码被坏人知道。然后在服务端也将密码通过同样的方式加密,最后比较这两个字符串。 
    然而,我们不能为了登陆而将密码md5后直接通过Internet传输,因为坏人虽然不会知道我们的密码,但肯定会知道这个特殊的字符串可以授权他们访问我们的网站! 
    这就是公匙和私匙要解决的问题,首先由服务器提供一个随机字符串,然后客户端将这个随机字符串和密码相加后再加密! 
    每次登陆时,服务器会产生不同的随机字符串,这样你的密码没有变,但是通过上面的方法加密后的MD5摘要却完全不同。这样就算坏人得到了这些MD5摘要,他们也不可能分析出你的密码! 
    这种方法中,服务器提供的随机字符串叫做"公匙",寿命很短,并可以被任何人利用;你的密码叫做"私匙",寿命很长,而且永远也不会被人知道。 
    2。实现 
    客户端Javascript并没有提供现成的md5算法,但我们在 google 上用 "md5 javascript" 搜索,就可以得到很多md5在Javascript上实现的例子。 
    在PHP中我就不用多说了,直接用md5()这个函数就可以搞定!随机字符串我们可以用session来存储(PHP就是强啊~~) 
    3。注意 
    在JS中,中文都是UTF-8格式的,所以如果你的密码是中文,而且存储在服务端的密码的编码方式是GB2312,那么两个密码加密后的字符串是完全不同的!

    
最新技术文章:
▪PHP函数microtime()时间戳的定义与用法
▪PHP单一入口之apache配置内容
▪PHP数组排序方法总结(收藏)
▪php数组排序方法大全(脚本学堂整理奉献)
▪php数组排序的几个函数(附实例)
▪php二维数组排序(实例)
▪php根据键值对二维数组排序的小例子
▪php验证码(附截图)
▪php数组长度的获取方法(三个实例)
▪php获取数组长度的方法举例
▪判断php数组维度(php数组长度)的方法
▪php获取图片的exif信息的示例代码
▪PHP 数组key长度对性能的影响实例分析
▪php函数指定默认值的方法示例
▪php提交表单到当前页面、提交表单后页面重定...
▪php四舍五入的三种实现方法
▪php获得数组长度(元素个数)的方法
▪php日期函数的简单示例代码
▪php数学函数的简单示例代码
▪php字符串函数的简单示例代码
▪php文件下载代码(多浏览器兼容、支持中文文...
▪php文件下载(防止中文文件名乱码)的示例代码 iis7站长之家
▪php文件下载(防止中文文件名乱码)的示例代码
▪解决PHP文件下载时中文文件名乱码的问题
▪php数组去重(一维、二维数组去重)的简单示例
▪php小数点后取两位的三种实现方法
▪php Redis 队列服务的简单示例
▪PHP导出excel时数字变为科学计数的解决方法
▪PHP数组根据值获取Key的简单示例
▪php数组去重的函数代码示例
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3