用PHP实现小型站点广告管理


Posted in PHP onOctober 09, 2006

图片链接广告大概是最为常用的网络广告模式,但是多条广告的动态随机显示可不是那么简单的事情。PHP的文件上传函数提供了在这块468x60像素的区域(网页广告的标准尺寸)实现能够根据权值大小而随机显示广告的解决方案,从而避免了开发FTP程序或是ASP和Perl CAI中需要外挂扩展才能实现此项功能的弊端。

本例在PHP4+MySQL+Apache for Win9x/2000下调试通过,共包括两部分:用来增加新广告的程序AddNewAd.php3以及显示广告的程序ShowAd.php3,都存放在服务器PHP文件目录下的“test/guanggao/”目录中。在guanggao目录中建立一个存放广告链接图片的子目录“adbanner/”。下面我们按步骤进行分析。

1.首先,建立MySQL数据库:guanggao

在Windows环境下,建立一个MySQL空数据库很简单,因为每个数据库都是存在于mysql/data/目录下的一个子目录,所以只要在该目录下新建子目录guanggao就可以了,这时数据库内还没有任何表和数据。

2.建立新增广告程序:AddNewAd.php3

设计思路:其中先用表单得到用户的新广告信息;然后用PHP函数copy()将链接图片(banner)文件上传到服务器adbanner目录下;最后将图片文件名、广告网址、说明、加权信息等写入建立的MySQL数据表ad中。该程序代码如下:

# AddNewAd.php3——增添新的广告 #

增添新广告

    //表单用来输入新增广告信息,并交给下面的PHP程序处理;
    //其中,加权值priority数字愈大,载入页面图片出现的机率就愈高,默认为1。

    广告 Banner:  

    广告网址URL:  

    图片链接说明ALT:  

    显示加权:  

     

    //处理表单数据的PHP程序;
         //图片banner名和链接地址不能为空;
    if (( banner!="") & ( url!="")) {
    //若广告链接和图片名已被使用,必须另选;
    if (file_exists("adbanner/". banner_name)) {
    echo "广告图片. banner_name.已被使用,请另选!";
    exit;
    };
    //上传链接图片文件名到adbanner目录;
    copy( banner,"adbanner/". banner_name);
   //连接MySQL数据库;
     connection = mysql_connect();  
   //选择数据源guanggao,执行查询;;
   mysql_select_db("guanggao", );  
    query="SELECT * FROM ad";
    result=mysql_query( query);
   //如果数据表ad不存在,则按以下结构创建新数据表ad;
   if(!result){
   mysql_query("
   create table ad(
   url varchar(100) not null,
   banner varchar(150) not null,
   alt varchar(100) null,
   priority  tinyint(4) default '1' not null  
   )") or die(mysql_error());  
   }
   //向数据表ad中插入来自于表单的新数据;
    query="insert into ad(url, banner, alt, priority) values(' url', ' banner_name', '
  alt', ' priority')";
   //插入成功则显示以下信息;
    try=mysql_query( query);
   if( try){
   echo "一条广告新增完成,详细信息:
";
   echo "
";
   echo "广告网址:  url
广告链接说明:  alt
显示加权:  priority ";
    }
    }
    ?>

3.建立显示广告程序:ShowAd.php3

设计思路:得到数据库表中所有各列信息分别存到相应的一维数组中,将所有广告的权值相加得到一个最大随机数,每次载入页面用srand() 产生一个随机树种子,再用rand()函数产生一个从1到最大随机数之间的一个随机数,然后按照一定的规则随机显示不同广告条,权值越大被显示的机会越大。

    # ShowAd.php3——随机显示广告 #
         //连接选择数据库;
     connection = mysql_connect();  
    mysql_select_db("guanggao",  connection);
    //执行查询得到广告条数;
     query="SELECT url, banner, alt, priority FROM ad where priority > 0";
     result=mysql_db_query("guanggao",  query);
     numrows=mysql_num_rows( result);
   //使用mysql_fetch_object()函数获取有用的列信息并存到相应数组中;
    while( row = mysql_fetch_object( result)) {
     adurl[]= row->url;
     adbanner[]= row->banner;
     adalt[]= row->alt;
     adpriority[]= row->priority;
    }
    //初始化中间变量;
     numcheck= numrows;
     i= pricount=0;
    //得到最大随机数;
    while( numcheck) {
     pricount+= adpriority[ i];
     i++; numcheck--;
   }
   //程序执行时的百万分之一秒产生随机数种子;
   srand((double)microtime()*1000000);
   //得到1到最大随机数之间的一个随机数;
    pri = rand(1, pricount);
   //中间变量清零;
     pricount=0;
    //按加权值不同,产生用来显示广告的、元素为字串的数组;
    for(  i=0;  i< numrows-1;  i++) {
     pricount +=  adpriority[ i];
    if ( pri <=  pricount) {
     ad[]="";
    }
    }
    //显示广告,权值越大,显示机会越大;
    echo  ad[0];
    ?> 

PHP 相关文章推荐
PHP5/ZendEngine2的改进
Oct 09 PHP
PHP 面向对象详解
Sep 13 PHP
解析使用ThinkPHP应该掌握的调试手段
Jun 20 PHP
解析PHP中的file_get_contents获取远程页面乱码的问题
Jun 25 PHP
ThinkPHP实现事务回滚示例代码
Jun 23 PHP
PHP集成百度Ueditor 1.4.3
Nov 23 PHP
UTF-8正则表达式如何匹配汉字
Aug 03 PHP
PHP使用GD库输出汉字的方法【测试可用】
Nov 10 PHP
一个实用的php验证码类
Jul 06 PHP
thinkPHP3.2.3结合Laypage实现的分页功能示例
May 28 PHP
PDO::lastInsertId讲解
Jan 29 PHP
PHP封装XML和JSON格式数据接口操作示例
Mar 06 PHP
一个域名查询的程序
Oct 09 #PHP
PHP脚本的10个技巧(7)
Oct 09 #PHP
PHP脚本的10个技巧(6)
Oct 09 #PHP
复杂检索数据并分页显示的处理方法
Oct 09 #PHP
PHP脚本的10个技巧(5)
Oct 09 #PHP
打造计数器DIY三步曲(中)
Oct 09 #PHP
打造计数器DIY三步曲(下)
Oct 09 #PHP
You might like
PHP 使用MySQL管理Session的回调函数详解
2013/06/21 PHP
JS异常处理try..catch语句的作用和实例
2014/05/05 PHP
谷歌浏览器 insertCell与appendChild的区别
2009/02/12 Javascript
javascript 选择文件夹对话框(web)
2009/07/07 Javascript
jquery.lazyload  实现图片延迟加载jquery插件
2010/02/06 Javascript
javascript 折半查找字符在数组中的位置(有序列表)
2010/12/09 Javascript
了解一点js的Eval函数
2012/07/26 Javascript
JS+CSS制作DIV层可(最小化/拖拽/排序)功能实现代码
2013/02/25 Javascript
js验证输入是否为手机号码或电话号码示例
2013/12/30 Javascript
javascript常用函数归纳整理
2014/10/31 Javascript
JavaScript搜索字符串并将搜索结果返回到字符串的方法
2015/04/06 Javascript
九种原生js动画效果
2015/11/11 Javascript
基于jquery实现下拉框美化特效
2016/02/02 Javascript
jQuery中的siblings()是什么意思(推荐)
2016/12/29 Javascript
Angular.Js中ng-include指令的使用与实现
2017/05/07 Javascript
详解使用Typescript开发node.js项目(简单的环境配置)
2017/10/09 Javascript
详解如何去除vue项目中的#——History模式
2017/10/13 Javascript
js实现rem自动匹配计算font-size的示例
2017/11/18 Javascript
vue页面切换过渡transition效果
2018/10/08 Javascript
vue.js实现三级菜单效果
2019/10/19 Javascript
原生JS实现顶部导航栏显示按钮+搜索框功能
2019/12/25 Javascript
vue 在methods中调用mounted的实现操作
2020/08/07 Javascript
JavaScript 实现拖拽效果组件功能(兼容移动端)
2020/11/11 Javascript
Vue 列表页带参数进详情页的操作(router-link)
2020/11/13 Javascript
python常用web框架简单性能测试结果分享(包含django、flask、bottle、tornado)
2014/08/25 Python
详解Python中映射类型(字典)操作符的概念和使用
2015/08/19 Python
实例讲解Python3中abs()函数
2019/02/19 Python
关于python3.9安装wordcloud出错的问题及解决办法
2020/11/02 Python
python 利用matplotlib在3D空间中绘制平面的案例
2021/02/06 Python
如何实现一个自定义类的序列化
2012/05/22 面试题
EJB面试题
2015/07/28 面试题
西安夏日科技有限公司Java笔试题
2013/01/11 面试题
林肯就职演讲稿
2014/05/19 职场文书
入党转正介绍人意见
2015/06/03 职场文书
2015年小学远程教育工作总结
2015/07/28 职场文书
朋友圈早安励志语录!
2019/07/08 职场文书