用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 将excel导入mysql
Nov 09 PHP
PHP has encountered an Access Violation 错误的解决方法
Jan 17 PHP
php获取后台Job管理的实现代码
Jun 10 PHP
php计算程序运行时间的简单例子分享
May 10 PHP
2014年10个最佳的PHP图像操作库
Jul 14 PHP
php读取csc文件并输出
May 21 PHP
学习php设计模式 php实现命令模式(command)
Dec 08 PHP
yii2.0实现创建简单widgets示例
Jul 18 PHP
Yii框架表单提交验证功能分析
Jan 07 PHP
PHP多线程模拟实现秒杀抢单
Feb 07 PHP
php过滤htmlspecialchars() 函数实现把预定义的字符转换为 HTML 实体用法分析
Jun 25 PHP
基于laravel-admin 后台 列表标签背景的使用方法
Oct 03 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编程开发怎么提高编程效率 提高PHP编程技术
2015/11/09 PHP
深入理解JavaScript定时机制
2010/10/29 Javascript
javascript时间函数基础介绍
2013/03/28 Javascript
利用NodeJS和PhantomJS抓取网站页面信息以及网站截图
2013/11/18 NodeJs
JavaScript中创建类/对象的几种方法总结
2013/11/29 Javascript
浅析JavaScript中的类型和对象
2013/11/29 Javascript
解决JS中乘法的浮点错误的方法
2014/01/03 Javascript
js图片预加载示例
2014/04/30 Javascript
javascript运动框架用法实例分析(实现放大与缩小效果)
2016/01/08 Javascript
JavaScript中的Number数字类型学习笔记
2016/05/26 Javascript
Javascript实现图片不间断滚动的代码
2016/06/22 Javascript
微信QQ的二维码登录原理js代码解析
2016/06/23 Javascript
AngularJS基础 ng-srcset 指令简单示例
2016/08/03 Javascript
js 递归和定时器的实例解析
2017/02/03 Javascript
JS+html5制作简单音乐播放器
2020/09/13 Javascript
JavaScript canvas实现围绕旋转动画
2017/11/18 Javascript
基于Vue插入视频的2种方法小结
2019/04/02 Javascript
javascript原型链学习记录之继承实现方式分析
2019/05/01 Javascript
通过javascript实现段落的收缩与展开
2019/06/26 Javascript
微信小程序request请求封装,验签代码实例
2019/12/04 Javascript
浅谈vue 二级路由嵌套和二级路由高亮问题
2020/08/06 Javascript
Python实现简单HTML表格解析的方法
2015/06/15 Python
python如何让类支持比较运算
2018/03/20 Python
pyqt5之将textBrowser的内容写入txt文档的方法
2019/06/21 Python
解决Pyinstaller打包软件失败的一个坑
2021/03/04 Python
高清安全摄像头系统:Lorex Technology
2018/07/20 全球购物
会计助理的岗位职责
2013/11/29 职场文书
告诉你怎样写创业计划书
2014/01/27 职场文书
毕业生求职信的经典写法
2014/01/31 职场文书
优秀护士获奖感言
2014/02/20 职场文书
计算机专业毕业生自荐信范文
2014/03/06 职场文书
2014年会计主管工作总结
2014/12/20 职场文书
教师个人年度总结
2015/02/11 职场文书
魂断蓝桥观后感
2015/06/10 职场文书
趣味运动会加油词
2015/07/18 职场文书
如何利用map实现Nginx允许多个域名跨域
2021/03/31 Servers