PHP - 广告轮播

PHP - 广告轮播,第1张

PHP - 广告轮播
广告轮播

网络广告,变成了 Internet 上的热门学问。而 468x60 更变成了广告人员绞尽脑汁的尺寸。

在处理广告时,若能直接使用浏览器将广告的 468x60 图文件送到处理广告的服务器中,相信是件很舒服的事,不用再开 FTP 程序,搞大半天只为了 upload。

这个问题,是所有 Web CGI 程序的痛,包括 ASP、Prel....等等,都需要再经过系统元件的增加才能达成。号称最强的 Web CGI 程序: PHP,在这方面的表现没有令人失望,甚至傲视其它的 CGI 工具。

File Upload 功能在 RFC 1867 文件有有详细的说明,是利用特殊的文件格式 (content-type) multipart/form-data。值得注意的是浏览器一定要用 Netscape 3.0 以上或 MS Internet Explorer 4.0 以上的版本才能将文件上传。

先看下面的 HTML 源代码


在 form 的标签中,要加入 enctype="multipart/form-data" 的字符串,表示用户输入的资料上有文件上传,同时 method 一定要用 POST 而不能用 GET。

在上面的码中,若用户姓名填入 Wilson Peng,并选 c:myphoto.gif 的文件,在用户按下送出键后,浏览器则传送出下面的 POST 资料。


Content-type: multipart/form-data, boundary=AaB03x

--AaB03x
content-disposition: form-data; name="user"

Wilson Peng
--AaB03x
content-disposition: form-data; name="myfile"
Content-type: multipart/mixed, boundary=BbC04y

--BbC04y
Content-disposition: attachment; filename="myphoto.gif"
Content-type: image/gif
Content-Transfer-Encoding: binary

  ...myphoto.gif 内容略...
--BbC04y--
--AaB03x--

看到上面的资料中,boundary=AaB03x 即为分开不同字段资料的信息,其中的 AaB03x 编码方法,视浏览器的版本不同而异,通常是浏览器哈稀产生的。之后就可以看到用 --AaB03x 来隔开不同的字段。

以上面为例,处理 form 的 action 程序 next.php,会主动产生四个变量,见下表

变量名说明 $myfile即上传的文件内容 $myfile_name上传文件在用户端的名称 $myfile_size上传文件的大小 $myfile_type上传文件的格式,如 "image/gif"

在 next.php 程序要做的最重要步骤,就是好好的使用这四个变量,否则程序一结束,用户上传的文件就消失了。因此,要先将 $myfile 复制到存放广告图的目录中

copy($banner,"/home1/biglobe3/ad/".$banner_name);

这行程序就是将文件存在 /home/htdocs/ad 的目录中,就上面的例子而言,就将文件存到 /home/htdocs/ad/myphoto.gif。重要的是,存放的目录不能是 Web Server 无法读到的目录,而应放在网站的 Homepage 所在目录中,才可以在网络上看到。

或许程序要更详细的处理,例如比对取得的文件大小与系统回报的是否相同....等等,就可以用 $myfile_size 变量了。

若在 form 中配置 input file 的名称改掉,则在 Upload 的变量也一起改,如

则变量就改成 $upfile、$upfile_name、$upfile_size、与 $upfile_type。

因此,下面的例子就利用 File Upload 及 Oracle 7.x 后端数据库,将文件放在 Web Homepage 目录中,相关信息则存在 Oracle 中。当然,加上用户认证,让有帐号的用户才能上传图片,可避免刽客 (cracker) 等将不雅或不适当的广告上传。例中有关数据库的配置和 5.4 留言板的配置相同。



// adadd.php
if (($banner=="") and ($url=="")) {
?>
新增广告


加权值数字愈大,图片出现的机率就愈高,默认值为 1。

} else {
  if (
file_exists("/home/htdocs/ad/".$banner_name)) {
    
CommonHeader("文件 ".$banner_name." 已存在");
    echo 
"



广告文件已经存在n



"
;
    exit;
  };

  
copy($banner,"/home1/biglobe3/ad/".$banner_name);

  
putenv("ORACLE_SID=WWW");
  
putenv("NLS_LANG=american_taiwan.zht16big5");
  
putenv("ORACLE_HOME=/home/oracle/product/7.3.2");
  
putenv("LD_LIBRARY_PATH=/home/oracle/product/7.3.2/lib");
  
putenv("ORA_NLS=/home/oracle/product/7.3.2/ocommon/nls/admin/data");
  
putenv("ORA_NLS32=/home/oracle/product/7.3.2/ocommon/nls/admin/data");

  
$handle=ora_logon("user38@WWW","iam3849") or die;
  
$cursor=ora_open($handle);
  
ora_commitoff($handle);

  
$query="insert into ad(url, banner, alt, descript, priority) values('$url', '$banner_name', '$alt', '$descript', $priority)";
  
ora_parse($cursor$query) or die;
  
ora_exec($cursor);
  
ora_close($cursor);
  
ora_logoff($handle);

  echo 
"广告新增完成";
  echo 
"";
  echo 
"";
  echo 
".$url.">.$banner_name." alt="".$alt."" border=0>

";
  echo 
"";
  echo 
"

  • 广告网址: ".$url;
      echo 
    "
  • 辅助字符串: ".$alt;
      echo 
    "
  • 广告说明: ".$descript
      echo 
    "
  • 显示加权: ".$priority;
      echo 
    "";
    }

    ?>


    当然要使用上面的程序之前别忘了先增加 ad 资料表,SQL 及字段如下

    CREATE TABLE ad (
      url       varchar2(1024) not null,
      banner    varchar2(1024) not null,
      alt       varchar2(255)  null,
      descript  varchar2(255)  null,
      priority  number(4) not null default 1
    );
    

    序号字段名称资料类型资料长度字段说明 0广告网址urlvarchar21024 1图片路径bannervarchar21024 2字符串显示altvarchar2255 3广告说明descriptvarchar2255 4显示加权prioritynumber41 为默认值,0 表停用

    值得一提的是在这加入了加权的功能,若一个广告要提升曝光率,则可以将显示加权的字段数字加大,例如 5,它的出现机率就会比只设为 1 的高五倍。

    // ad.php
    putenv("ORACLE_SID=WWW");
    putenv("NLS_LANG=american_taiwan.zht16big5");
    putenv("ORACLE_HOME=/home/oracle/product/7.3.2");
    putenv("LD_LIBRARY_PATH=/home/oracle/product/7.3.2/lib");
    putenv("ORA_NLS=/home/oracle/product/7.3.2/ocommon/nls/admin/data");
    putenv("ORA_NLS32=/home/oracle/product/7.3.2/ocommon/nls/admin/data");

    $handle=ora_logon("user38@WWW","iam3849") or die;
    $cursor=ora_open($handle);
    ora_commitoff($handle);

    $query="SELECt url, banner, alt, priority FROM ad where priority > 0";
    ora_parse($cursor$query) or die;
    ora_exec($cursor);
    $i=$pricount=0;
    while(
    ora_fetch($cursor)) {
      
    $ad[$i][0] = ora_getcolumn($cursor,0);
      
    $ad[$i][1] = ora_getcolumn($cursor,1);
      
    $ad[$i][2] = ora_getcolumn($cursor,2);
      
    $ad[$i][3] = ora_getcolumn($cursor,3);
      
    $pricount += $ad[$i][3];
      
    $i++;
    };

    ora_close($cursor);
    ora_logoff($handle);

    srand((double)microtime()*1000000);
    $pri rand(1,$pricount);
    $pricount=0;
    for(
    $i=0$i<count($ad); $i++) {
      
    $pricount += $ad[$i][3];
      if (
    $pri <= $pricount) {
        
    $ad1[]=".$ad[$i][0]." target=new>.$ad[$i][1]." width=468 height=60 border=0 alt="".$ad[$i][2]."">";
      }
    }
    echo 
    $ad1[0];

    ?>

    上面的程序为公用的广告显示程序,其中的 $pricount 变量为所有广告 priority 加起来的和。程序先将所有的广告信息读到数组变量 $ad 中,随即关上数据库。再依时间取随机数种子,之后再从 1 到 $pricount 间随机取一个数字。

    网页中要用广告程序,只要在需要广告的地方加上 include("ad.php"); ?> 就可以了,当然 Include 的路径 (在 httpd.conf 中) 要先设好才行。

    上面的程序还有改进空间,可以加入广告的 Click Log 功能,或是显示的 Log 功能,改动显示加权的程序....等等,就不做范例了,毕竟在这儿是要介绍 PHP 的实际应用及程序开发,而不是套件开发。真的需要现成的广告套件,不妨到 http://www.phpwizard.net/phpAds,这是一套用 PHP 开发出来的广告程序。



    欢迎分享,转载请注明来源:内存溢出

    原文地址: http://outofmemory.cn/zaji/3004916.html

  • (0)
    打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
    上一篇 2022-09-27
    下一篇 2022-09-27

    发表评论

    登录后才能评论

    评论列表(0条)