用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 相关文章推荐
PHP6 先修班 JSON实例代码
Aug 23 PHP
PHP 编程安全性小结
Jan 08 PHP
PHP遍历数组的几种方法
Mar 22 PHP
PHPMYADMIN导入数据最大为2M的解决方法
Apr 23 PHP
php引用传值实例详解学习
Nov 06 PHP
Linux操作系统安装LAMP环境
Jun 26 PHP
简单介绍PHP非阻塞模式
Mar 03 PHP
PHP生成静态HTML文档实现代码
Jun 23 PHP
分析PHP中单双引号的误区和双引号小隐患
Jul 19 PHP
[原创]php实现数组按拼音顺序排序的方法
May 03 PHP
Laravel框架中自定义模板指令总结
Dec 17 PHP
PHP判断是否是json字符串
Apr 01 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高级对象构建 多个构造函数的使用
2012/02/05 PHP
PHP cURL获取微信公众号access_token的实例
2018/04/28 PHP
php微信开发之谷歌测距
2018/06/14 PHP
ThinkPHP3.1.2 使用cli命令行模式运行的方法
2020/04/14 PHP
Ext.get() 和 Ext.query()组合使用实现最灵活的取元素方式
2011/09/26 Javascript
javascript创建数组之联合数组的使用方法示例
2013/12/26 Javascript
jQuery 3 中的新增功能汇总介绍
2016/06/12 Javascript
js简单获取表单中单选按钮值的方法
2016/08/23 Javascript
解析jquery easyui tree异步加载子节点问题
2017/03/08 Javascript
Angular2 组件通信的实例代码
2017/06/23 Javascript
LayUi中接口传数据成功,表格不显示数据的解决方法
2018/08/19 Javascript
Vue CLI3 开启gzip压缩文件的方式
2018/09/30 Javascript
jquery轻量级数字动画插件countUp.js使用详解
2019/10/17 jQuery
js new Date()实例测试
2019/10/31 Javascript
JavaScript中while循环的基础使用教程
2020/08/11 Javascript
在js文件中引入(调用)另一个js文件的三种方法
2020/09/11 Javascript
[40:29]2018DOTA2亚洲邀请赛 4.7总决赛 LGD vs Mineski 第一场
2018/04/10 DOTA
Python中多线程及程序锁浅析
2015/01/21 Python
在Python中操作时间之tzset()方法的使用教程
2015/05/22 Python
python开发之thread实现布朗运动的方法
2015/11/11 Python
获取python的list中含有重复值的index方法
2018/06/27 Python
在django中实现页面倒数几秒后自动跳转的例子
2019/08/16 Python
用 Python 制作地球仪的方法
2020/04/24 Python
德国著名廉价网上药店:Shop-Apotheke
2017/07/23 全球购物
加拿大户外探险购物网站:SAIL
2020/06/27 全球购物
什么是Assembly(程序集)
2014/09/14 面试题
应用心理学个人的求职信
2013/12/08 职场文书
怎样写演讲稿
2014/01/04 职场文书
给酒店员工的表扬信
2014/01/11 职场文书
个人投资计划书
2014/05/01 职场文书
纪检监察建议书
2014/05/19 职场文书
开展党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
重阳节演讲稿:尊敬帮助老人 弘扬传统美德
2014/09/25 职场文书
自查自纠工作总结
2014/10/15 职场文书
导游词之蜀山胜景瓦屋山
2019/11/29 职场文书
Node.js实现爬取网站图片的示例代码
2022/04/04 NodeJs