首页 > 数据库 > MySQL > 正文

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

2024-07-24 12:56:36
字体:
来源:转载
供稿:网友
  • 网站运营seo文章大全
  • 提供全面的站长运营经验及seo技术!
  • 图片链接广告大概是最为常用的网络广告模式,但是多条广告的动态随机显示可不是那么简单的事情。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——增添新的广告 #
      <center><h1>增添新广告</h1></center>
      //表单用来输入新增广告信息,并交给下面的php程序处理;
      //其中,加权值priority数字愈大,载入页面图片出现的机率就愈高,默认为1。
      <form enctype="multipart/form-data" action="addnewad.php3" method=post>
      广告 banner: <input name=banner type="file"><br>
      广告网址url: <input name=url type=text size=30><br>
      图片链接说明alt: <input name=alt type=text size=30><br>
      显示加权: <input name=priority type=text size=5 value=1><br>
      <input type="submit" value="提交">
      </form>
      //处理表单数据的php程序;
      <?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 "<a href=" url"><img src="adbanner/ banner_name" alt=". alt." border=0></a><br>";
      echo "广告网址: url<br>广告链接说明: alt<br>显示加权: priority ";
      }
      }
      ?>
      
      3.建立显示广告程序:showad.php3
      设计思路:得到数据库表中所有各列信息分别存到相应的一维数组中,将所有广告的权值相加得到一个最大随机数,每次载入页面用srand() 产生一个随机树种子,再用rand()函数产生一个从1到最大随机数之间的一个随机数,然后按照一定的规则随机显示不同广告条,权值越大被显示的机会越大。
      
      # showad.php3——随机显示广告 #
      <?php
      //连接选择数据库;
      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[]="<a href=" adurl[ i]" target=new></a>";
      }
      }
      //显示广告,权值越大,显示机会越大;
      echo ad[0];
      ?>
    发表评论 共有条评论
    用户名: 密码:
    验证码: 匿名发表