用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 相关文章推荐
PHP获取网站域名和地址的代码
Aug 17 PHP
简单的移动设备检测PHP脚本代码
Feb 19 PHP
写出高质量的PHP程序
Feb 04 PHP
PHP中应该避免使用同名变量(拆分临时变量)
Apr 03 PHP
php实现的操作excel类详解
Jan 15 PHP
php中通过eval实现字符串格式的计算公式
Mar 18 PHP
PHP 实现人民币小写转换成大写的方法及大小写转换函数
Nov 17 PHP
PHP 爬取网页的主要方法
Jul 13 PHP
PHP获取星期几的常用方法小结
Dec 18 PHP
PHP的mysqli_thread_id()函数讲解
Jan 24 PHP
PHP扩展Swoole实现实时异步任务队列示例
Apr 13 PHP
php解决crontab定时任务不能写入文件问题的方法分析
Sep 16 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.ini 中文版
2006/10/28 PHP
php 删除一个数组中的某个值.兼容多维数组!
2012/02/18 PHP
PHP中常用的转义函数
2014/02/28 PHP
php发送post请求函数分享
2014/03/06 PHP
CentOS下PHP安装Oracle扩展
2015/02/15 PHP
Yii2超好用的日期和时间组件(值得收藏)
2016/05/05 PHP
CI框架使用composer安装的依赖包步骤与方法分析
2016/11/21 PHP
js 表单验证方法(实用)
2009/04/28 Javascript
JS画线(实例代码)
2013/11/20 Javascript
javascript表单验证使用示例(javascript验证邮箱)
2014/01/07 Javascript
JS遍历Json字符串中键值对先转成JSON对象再遍历
2014/08/15 Javascript
javascript感应鼠标图片透明度显示的方法
2015/02/24 Javascript
JS组件系列之使用HTML标签的data属性初始化JS组件
2016/09/14 Javascript
sea.js常用的api简易文档
2016/11/15 Javascript
微信小程序 Nginx环境配置详细介绍
2017/02/14 Javascript
详解React 在服务端渲染的实现
2017/11/16 Javascript
3分钟了解vue数据劫持的原理实现
2019/05/01 Javascript
星球大战与Python之间的那些事
2016/01/07 Python
基于Python如何使用AIML搭建聊天机器人
2016/01/27 Python
Python在不同目录下导入模块的实现方法
2017/10/27 Python
python使用Plotly绘图工具绘制气泡图
2019/04/01 Python
python 类的继承 实例方法.静态方法.类方法的代码解析
2019/08/23 Python
Python爬虫图片懒加载技术 selenium和PhantomJS解析
2019/09/18 Python
python安装mysql的依赖包mysql-python操作
2021/01/01 Python
css3的@media属性实现页面响应式布局示例代码
2014/02/10 HTML / CSS
水芝澳美国官网:H2O Plus
2016/10/15 全球购物
软件测试笔试题
2012/10/25 面试题
初中三年学生的学习自我评价
2013/11/13 职场文书
新春文艺演出主持词
2014/03/27 职场文书
学生检讨书怎么写?
2014/10/10 职场文书
人民调解协议书范本
2014/10/11 职场文书
维稳工作承诺书
2015/01/20 职场文书
二手车转让协议书
2015/01/29 职场文书
礼貌问候语大全
2015/11/10 职场文书
JavaScript函数柯里化
2021/11/07 Javascript
MYSQL中文乱码问题的解决方案
2022/06/14 MySQL