再现理想 发表于 2015-2-4 00:25:37

PHP网站制作之一个好用的UBB类!

从刚开始练习的PHP基础语法练习,到PHP语言在WEB中的应用,再到实际的项目开发,如留言版,相册系统,中小型公司网站系统,以及期间做过的有关团队合作的小游戏,让我受益匪浅,学到了很多。ubb   <?php
/*
若有转载,请注明作者

原作者: 何志强
改善:   SonyMusic
文件:   ubb.php
备注:   说是改善,其实中心函数parse()已完整重写了,并且思绪也是纷歧样的。
      不外还是受何志强的例子的启示,并且测试的例子还有URLCHECK等几个函数也是沿用的何志强的法式,感谢何志强。
      今朝还没有色彩的功效,但我会到场的。
      假如在法式上有甚么BUG或方便的中央,请给我MAIL。
      感谢!
改善功效:
    对字符串停止UBB编码,该类今朝只撑持以下几个复杂且适用的编码:
    1. URL裢接
       http://phpuser.com/
       http://头可以不需求
       如phpuser.com也是可以的。
    2. Email裢接
       sonymusic@163.net
    3. 图片裢接
      

       同URL链接一样,后面的http也能够不要。
    4. 文字方面
       粗体字
       斜体字
       加下划线
       1号题目字

... 6号题目字


      
      
      
      
       <strike></strike>
      
      
      
      
      
      
      
      
      
      
      
    注重以下几点:
    1. url,email,img等标签是不分巨细写的.
    2. 在标签中不答应有TAB键呈现,但空格答应。
    3. 该类要挪用htmlencode,htmlencode4textarea,emailcheck函数和urlcheck类.
    4. 修正后撑持嵌套,但url,email,img这三个标签不是答应嵌套的。
手艺材料:
    Ultimate Bulletin Board
      http://www.ultimatebb.com/
    What is UBB Code
      http://www.scriptkeeper.com/ubb/ubbcode.html
*/

include("urlcheck.php");
include("otherfunc.php"); //这两个文件的内容,附在最初。

//ubbcode类
class ubbcode{
    var $call_time=0;
   //可处置标签及处置函数对应表
   var $tags = array(//小写的标签 => 对应的处置函数
                     'url' => '$this->url',
                     'email' => '$this->email',
                     'img' => '$this->img',
                     'b' => '$this->simple',
                     'i' => '$this->simple',
                     'u' => '$this->simple',
                     'tt' => '$this->simple',
                     's' => '$this->simple',
                     'strike' => '$this->simple',
                     'h1' => '$this->simple',
                     'h2' => '$this->simple',
                     'h3' => '$this->simple',
                     'h4' => '$this->simple',
                     'h5' => '$this->simple',
                     'h6' => '$this->simple',
                     'sup' => '$this->simple',
                     'sub' => '$this->simple',
                     'em' => '$this->simple',
                     'strong' => '$this->simple',
                     'code' => '$this->simple',
                     'samp' => '$this->simple',
                     'kbd' => '$this->simple',
                     'var' => '$this->simple',
                     'dfn' => '$this->simple',
                     'cite' => '$this->simple',
                     'small' => '$this->simple',
                     'big' => '$this->simple',
                     'blink' => '$this->simple'
                  );
   //url裢接属性
   var $attr_url;
   //url正当性反省对象
   var $urlcheck;

   function ubbcode($attr_url){
      $this->attr_url = ''.$attr_url;
      $this->urlcheck = new urlcheck();
   }

   //对$str停止UBB编码解析
   function parse($str){
         $this->call_time++;
      $parse = ''.htmlencode($str);

      $ret = '';
      while(true){
          $eregi_ret=eregi("\[[#]{0,1}[[:alnum:]]{1,7}\]",$parse,$eregi_arr); //查找
      if(!$eregi_ret){
            $ret .= $parse;
            break;//假如没有,前往
         }
         $pos = @strpos($parse,$eregi_arr);
         $tag_len=strlen($eregi_arr)-2;//标志长度
      $tag_start=substr($eregi_arr,1,$tag_len);
      $tag=strtolower($tag_start);
      
         if((($tag=="url") or ($tag=="email") or ($tag=="img")) and ($this->call_time>1)){
             echo $this->call_time."<br>";
             return $parse;//假如不克不及是不克不及嵌套的标志,直接前往
      }
      
         $parse2 = substr($parse,0,$pos);//标志之前
         $parse = substr($parse,$pos+$tag_len+2);//标志以后
         if(!isset($this->tags[$tag])){
             echo "$tag_start<br>";
            $ret .= $parse2.'['.$tag_start.']';
            continue;//假如是不撑持的标志
         }
      
         //查找对对应的停止标志
         $eregi_ret=eregi("\[\/".$tag."\]",$parse,$eregi_arr);
         if(!$eregi_ret){
            $ret .= $parse2.'['.$tag_start.']';
            continue;//假如没有对应当的停止标志
         }
         $pos=strpos($parse,$eregi_arr);
         $value=substr($parse,0,$pos);//这是起止标志之间的内容
         $tag_end=substr($parse,$pos+2,$tag_len);
         $parse=substr($parse,$pos+$tag_len+3);//停止标志以后的内容
         
         if(($tag!="url") and ($tag!="email") and ($tag!="img")){
             $value=$this->parse($value);
      }

         $ret .= $parse2;
         eval('$ret .= '.$this->tags[$tag].'("'.$tag_start.'","'.$tag_end.'","'.$value.'");');
      }
      $this->call_time--;
      return $ret;
   }

   function simple($start,$end,$value){
      return '<'.$start.'>'.$value.'</'.$end.'>';
   }

   function url($start,$end,$value){
         $trim_value=trim($value);
      if (strtolower(substr($trim_value,0,7))!="http://")
            $trim_value="http://".$trim_value;
      if($this->urlcheck->check($trim_value)) return '<a href="'.$trim_value.'" '.$this->attr_url.'>'.$value.'</a>';
      else return '['.$start.']'.$value.'[/'.$end.']';
   }

   function email($start,$end,$value){
      if(emailcheck($value)) return '<a href="mailto:'.$value.'">'.$value.'</a>';
      else return '['.$start.']'.$value.'[/'.$end.']';
   }

   function img($start,$end,$value){
         $trim_value=trim($value);
      if ((strtolower(substr($trim_value,0,7))!="http://") or ($this->urlcheck->check($trim_value)))
               return '<img src="'.$trim_value.'"></img>';
      else return '['.$start.']'.$value.'[/'.$end.']';
   }
}

//测试
echo '<html>';
echo '<head><title>测试</title></head>';
echo '<body>';
echo '<form action="'.str2url($PATH_INFO).'" method="post">';
echo '<textarea cols="100" rows="10" name="ubb">'.htmlencode4textarea($ubb).'</textarea><br>';
echo '<input type="submit" value="转换">';
echo '</form>';

if(isset($ubb)){
   $ubbcode = new ubbcode('target="_blank"');
   echo '<hr>'.$ubbcode->parse($ubb);
}

echo '</body>';
echo '</html>';

?>

文件urlcheck.php的内容
<?php
//urlcheck.php
class urlcheck{
   var $regex = array(//协定名(注重在这里必需写成小写) => 对应的正则表达式
                      'ftp' => '$this->ftpurl',
                      'file' => '$this->fileurl',
                      'http' => '$this->httpurl',
                      'https' => '$this->httpurl',
                      'gopher' => '$this->gopherurl',
                      'news' => '$this->newsurl',
                      'nntp' => '$this->nntpurl',
                      'telnet' => '$this->telneturl',
                      'wais' => '$this->waisurl'
                     );

   var $lowalpha;
   var $hialpha;
   var $alpha;
   var $digit;
   var $safe;
   var $extra;
   var $national;
   var $punctuation;
   var $reserved;
   var $hex;
   var $escape;
   var $unreserved;
   var $uchar;
   var $xchar;
   var $digits;

   var $urlpath;
   var $password;
   var $user;
   var $port;
   var $hostnumber;
   var $alphadigit;
   var $toplabel;
   var $domainlabel;
   var $hostname;
   var $host;
   var $hostport;
   var $login;

   //ftp
   var $ftptype;
   var $fsegment;
   var $fpath;
   var $ftpurl;

   //file
   var $fileurl;

   //http,https
   var $search;
   var $hsegment;
   var $hpath;
   var $httpurl;

   //gopher
   var $gopher_string;
   var $selector;
   var $gtype;
   var $gopherurl;

   //news
   var $article;
   var $group;
   var $grouppart;
   var $newsurl;

   //nntp
   var $nntpurl;

   //telnet
   var $telneturl;

   //wais
   var $wpath;
   var $wtype;
   var $database;
   var $waisdoc;
   var $waisindex;
   var $waisdatabase;
   var $waisurl;

   function check($url){
      $pos = @strpos($url,':',1);
      if($pos<1) return false;
      $prot = substr($url,0,$pos);
      if(!isset($this->regex[$prot])) return false;
      eval('$regex = '.$this->regex[$prot].';');
      return ereg('^'.$regex.'$',$url);
   }

   function urlcheck(){
      $this->lowalpha = '';
      $this->hialpha = '';
      $this->alpha = '('.$this->lowalpha.'|'.$this->hialpha.')';
      $this->digit = '';
      $this->safe = '[$.+_-]';
      $this->extra = '[*()\'!,]';
      $this->national = '([{}|\^~`]|\\[|\\])';
      $this->punctuation = '[<>#%"]';
      $this->reserved = '[?;/:@&=]';
      $this->hex = '('.$this->digit.'|)';
      $this->escape = '(%'.$this->hex.'{2})';
      $this->unreserved = '('.$this->alpha.'|'.$this->digit.'|'.$this->safe.'|'.$this->extra.')';
      $this->uchar = '('.$this->unreserved.'|'.$this->escape.')';
      $this->xchar = '('.$this->unreserved.'|'.$this->reserved.'|'.$this->escape.')';
      $this->digits = '('.$this->digit.'+)';

      $this->urlpath = '('.$this->xchar.'*)';
      $this->password = '(('.$this->uchar.'|[?;&=]'.')*)';
      $this->user = '(('.$this->uchar.'|[?;&=]'.')*)';
      $this->port = $this->digits;
      $this->hostnumber = '('.$this->digits.'.'.$this->digits.'.'.$this->digits.'.'.$this->digits.')';
      $this->alphadigit = '('.$this->alpha.'|'.$this->digit.')';
      $this->toplabel = '('.$this->alpha.'|('.$this->alpha.'('.$this->alphadigit.'|-)*'.$this->alphadigit.'))';
      $this->domainlabel = '('.$this->alphadigit.'|('.$this->alphadigit.'('.$this->alphadigit.'|-)*'.$this->alphadigit.'))';
      $this->hostname = '(('.$this->domainlabel.'\\.)*'.$this->toplabel.')';
      $this->host = '('.$this->hostname.'|'.$this->hostnumber.')';
      $this->hostport = '('.$this->host.'(:'.$this->port.')?)';
      $this->login = '(('.$this->user.'(:'.$this->password.')?@)?'.$this->hostport.')';

      $this->ftptype = '';
      $this->fsegment = '(('.$this->uchar.'|[?:@&=])*)';
      $this->fpath = '('.$this->fsegment.'(/'.$this->fsegment.')*)';
      $this->ftpurl = '(://'.$this->login.'(/'.$this->fpath.'(;='.$this->ftptype.')?)?)';

      $this->fileurl = '(://('.$this->host.'|)?/'.$this->fpath.')';

      $this->search = '(('.$this->uchar.'|[;:@&=])*)';
      $this->hsegment = '(('.$this->uchar.'|[;:@&=])*)';
      $this->hpath = '('.$this->hsegment.'(/'.$this->hsegment.')*)';
      $this->httpurl = '(?://'.$this->hostport.'(/'.$this->hpath.'([?]'.$this->search.')?)?)';

      $this->gopher_string = '('.$this->xchar.'*)';
      $this->selector = '('.$this->xchar.'*)';
      $this->gtype = $this->xchar;
      $this->gopherurl = '(://'.$this->hostport.'(/('.$this->gtype.'('.$this->selector.'(%09'.$this->search.'(%09'.$this->gopher_string.')?)?)?)?)?)';

      $this->article = '(('.$this->uchar.'|[;/?:&=])+@'.$this->host.')';
      $this->group = '('.$this->alpha.'('.$this->alpha.'|'.$this->digit.'|[-.+_])*)';
      $this->grouppart = '(
[*]|'.$this->group.'|'.$this->article.')';
      $this->newsurl = '(:'.$this->grouppart.')';

      $this->nntpurl = '(://'.$this->hostport.'/'.$this->group.'(/'.$this->digits.')?)';

      $this->telneturl = '(://'.$this->login.'/?)';

      $this->wpath = '('.$this->uchar.'*)';
      $this->wtype = '('.$this->uchar.'*)';
      $this->database = '('.$this->uchar.'*)';
      $this->waisdoc = '(://'.$this->hostport.'/'.$this->database.'/'.$this->wtype.'/'.$this->wpath.')';
      $this->waisindex = '(://'.$this->hostport.'/'.$this->database.'[?]'.$this->search.')';
      $this->waisdatabase = '(://'.$this->hostport.'/'.$this->database.')';
      $this->waisurl = '('.$this->waisdatabase.'|'.$this->waisindex.'|'.$this->waisdoc.')';
   }
}

?>


文件otherfunc.php的内容
<?php
//otherfunc.php
function htmlencode($str){
   $str = (string)$str;

   $ret = '';
   $len = strlen($str);
   $nl = false;
   for($i=0;$i<$len;$i++){
      $chr = $str[$i];
      switch($chr){
         case '<':
            $ret .= '<';
            $nl = false;
            break;
         case '>':
            $ret .= '>';
            $nl = false;
            break;
         case '"':
            $ret .= '"';
            $nl = false;
            break;
         case '&':
            $ret .= '&';
            $nl = false;
            break;
/*
         case ' ':
            $ret .= ' ';
            $nl = false;
            break;
*/      
         case chr(9):
            $ret .= '    ';
            $nl = false;
            break;
         case chr(10):
            if($nl) $nl = false;
            else{
               $ret .= '<br>';
               $nl = true;
            }
            break;
         case chr(13):
            if($nl) $nl = false;
            else{
               $ret .= '<br>';
               $nl = true;
            }
            break;
         default:
            $ret .= $chr;
            $nl = false;
            break;
      }
   }

   return $ret;
}


function htmlencode4textarea($str){
   $str = (string)$str;

   $ret = '';
   $len = strlen($str);
   for($i=0;$i<$len;$i++){
      $chr = $str[$i];
      switch($chr){
         case '<':
            $ret .= '<';
            break;
         case '>':
            $ret .= '>';
            break;
         case '"':
            $ret .= '"';
            break;
         case '&':
            $ret .= '&';
            break;
         case ' ':
            $ret .= ' ';
            break;
         case chr(9):
            $ret .= '    ';
            break;
         default:
            $ret .= $chr;
            break;
      }
   }

   return $ret;
}

function emailcheck($email){
   $ret=false;
   if(strstr($email, '@') && strstr($email, '.')){
      if(eregi("^(+([\\._a-z0-9-]+)*)@({2,}(\\.{2,})*\\.{2,3})$", $email)){
         $ret=true;
      }
   }
   return $ret;
}

function str2url($path){
   return eregi_replace("%2f","/",urlencode($path));
}
?>在学习中,我也一直这样要求着自己。

透明 发表于 2015-2-4 13:06:33

不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。

老尸 发表于 2015-2-9 22:56:59

再就是混迹于论坛啦,咱们的phpchina的论坛就很强大,提出的问题一般都是有达人去解答的,以前的帖子也要多看看也能学到不少前辈们的经验。别的不错的论坛例如php100,javaeye也是很不错的。

柔情似水 发表于 2015-2-19 00:27:04

学好程序语言,多些才是王道,写两个小时代码的作用绝对超过看一天书,这个我是深有体会(顺便还能练打字速度)。

爱飞 发表于 2015-2-25 18:30:12

不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。

蒙在股里 发表于 2015-2-28 15:30:06

写js我最烦的就是 ie 和 firefox下同样的代码 结果显示的结果千差万别,还是就是最好不要用遨游去调试,因为有时候遨游是禁用js的,有可能代码是争取结果被遨游折腾的认为是代码写错。

深爱那片海 发表于 2015-3-6 17:12:43

首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。

冷月葬花魂 发表于 2015-3-7 21:05:53

首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。

小女巫 发表于 2015-3-10 23:52:13

实践是检验自己会不会的真理。

小妖女 发表于 2015-3-17 16:10:11

其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。

海妖 发表于 2015-3-18 15:35:56

首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。

飘灵儿 发表于 2015-3-20 02:31:09

我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。

小魔女 发表于 2015-3-27 07:09:19

装在C盘下面可以利用windows的ghost功能可以还原回来(顺便当做是重转啦),当然啦我的编译目录要放在别的盘下,不然自己的劳动成果就悲剧啦。

不帅 发表于 2015-3-28 21:06:48

php里的数组为空的时候是不能拿来遍历的;(这个有点低级啊,不过我刚被这个边界问题墨迹了好长一会)

谁可相欹 发表于 2015-4-6 09:35:07

找到的的资料很多都是在论坛里的,需要注册,所以我一般没到一个论坛都注册一个id,所有的id都注册成一样的,这样下次再进来的时候就不用重复注册啦。当然有些论坛的某些资料是需要的付费的。

精灵巫婆 发表于 2015-4-25 09:28:59

学好程序语言,多些才是王道,写两个小时代码的作用绝对超过看一天书,这个我是深有体会(顺便还能练打字速度)。

第二个灵魂 发表于 2015-4-26 13:09:00

刚开始安装php的时候,我图了个省事,把php的扩展全都打开啦(就是把php.ini 那一片 extension 前面的冒号全去掉啦),这样自然有好处,以后不用再需要什么功能再来打开。

兰色精灵 发表于 2015-4-27 00:33:31

你很难利用原理去编写自己的代码。对于php来说,系统的学习我认为还是很重要的,当你有一定理解后,你可你针对某种效果研究,我想那时你不会只是复制代码的水平了。

莫相离 发表于 2015-4-27 08:01:06

首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。

灵魂腐蚀 发表于 2015-4-29 10:26:01

使用 jquery 等js框架的时候,要随时注意浏览器的更新情况,不然很容易发生框架不能使用。
页: [1] 2
查看完整版本: PHP网站制作之一个好用的UBB类!