硅谷论坛's Archiver

蓝冰 发表于 2007-5-16 10:27

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

图片链接广告大概是最为常用的网络广告模式,但是多条广告的动态随机显示可不是那么简单的事情。PHP的文件上传函数提供了在这块468x60像素的区域(网页广告的标准尺寸)实现能够根据权值大小而随机显示广告的解决方案,从而避免了开发FTP程序或是ASP和Perl CAI中需要外挂扩展才能实现此项功能的弊端。 <BR><BR>  本例在PHP4+MySQL+Apache for Win9x/2000下调试通过,共包括两部分:用来增加新广告的程序AddNewAd.php3以及显示广告的程序ShowAd.php3,都存放在服务器PHP文件目录下的“test/guanggao/”目录中。在guanggao目录中建立一个存放广告链接图片的子目录“adbanner/”。下面我们按步骤进行分析。 <BR><BR>1.首先,建立MySQL数据库:guanggao <BR><BR>  在Windows环境下,建立一个MySQL空数据库很简单,因为每个数据库都是存在于mysql/data/目录下的一个子目录,所以只要在该目录下新建子目录guanggao就可以了,这时数据库内还没有任何表和数据。 <BR><BR>2.建立新增广告程序:AddNewAd.php3 <BR><BR>  设计思路:其中先用表单得到用户的新广告信息;然后用PHP函数copy()将链接图片(banner)文件上传到服务器adbanner目录下;最后将图片文件名、广告网址、说明、加权信息等写入建立的MySQL数据表ad中。该程序代码如下: <BR><BR>  # AddNewAd.php3??增添新的广告 # <BR>&lt;center&gt;&lt;h1&gt;增添新广告&lt;/h1&gt;&lt;/center&gt; <BR>//表单用来输入新增广告信息,并交给下面的PHP程序处理; <BR>//其中,加权值priority数字愈大,载入页面图片出现的机率就愈高,默认为1。 <BR>&lt;FORM ENCTYPE="multipart/form-data" ACTION="AddNewAd.php3" METHOD=POST&gt; <BR>广告 Banner: &lt;input name=banner TYPE="file"&gt;&lt;br&gt; <BR>广告网址URL: &lt;input name=url type=text size=30&gt;&lt;br&gt; <BR>图片链接说明ALT: &lt;input name=alt type=text size=30&gt;&lt;br&gt; <BR>显示加权: &lt;input name=priority type=text size=5 value=1&gt;&lt;br&gt; <BR>&lt;input type="submit" VALUE="提交"&gt; <BR>&lt;/FORM&gt; <BR>//处理表单数据的PHP程序; <BR>&lt;?php <BR>//图片banner名和链接地址不能为空; <BR>if (( banner!="") &amp; ( url!="")) { <BR>//若广告链接和图片名已被使用,必须另选; <BR>if (file_exists("adbanner/". banner_name)) { <BR>echo "广告图片. banner_name.已被使用,请另选!"; <BR>exit; <BR>}; <BR>//上传链接图片文件名到adbanner目录; <BR>copy( banner,"adbanner/". banner_name); <BR>//连接MySQL数据库; <BR>connection = mysql_connect(); <BR>//选择数据源guanggao,执行查询;; <BR>mysql_select_db("guanggao", ); <BR>query="SELECT * FROM ad"; <BR>result=mysql_query( query); <BR>//如果数据表ad不存在,则按以下结构创建新数据表ad; <BR>if(!result){ <BR>mysql_query(" <BR>create table ad( <BR>url varchar(100) not null, <BR>banner varchar(150) not null, <BR>alt varchar(100) null, <BR>priority tinyint(4) default 1 not null <BR>)") or die(mysql_error()); <BR>} <BR>//向数据表ad中插入来自于表单的新数据; <BR>query="insert into ad(url, banner, alt, priority) values( url, banner_name, <BR>alt, priority)"; <BR>//插入成功则显示以下信息; <BR>try=mysql_query( query); <BR>if( try){ <BR>echo "一条广告新增完成,详细信息: <BR>"; <BR>echo "&lt;a href=" url"&gt;&lt;img src="adbanner/ banner_name" alt=". alt." border=0&gt;&lt;/a&gt;&lt;br&gt;"; <BR>echo "广告网址: url&lt;br&gt;广告链接说明: alt&lt;br&gt;显示加权: priority "; <BR>} <BR>} <BR>?&gt; <BR><BR>3.建立显示广告程序:ShowAd.php3 <BR><BR>  设计思路:得到数据库表中所有各列信息分别存到相应的一维数组中,将所有广告的权值相加得到一个最大随机数,每次载入页面用srand() 产生一个随机树种子,再用rand()函数产生一个从1到最大随机数之间的一个随机数,然后按照一定的规则随机显示不同广告条,权值越大被显示的机会越大。 <BR><BR># ShowAd.php3??随机显示广告 # <BR>&lt;?php <BR>//连接选择数据库; <BR>connection = mysql_connect(); <BR>mysql_select_db("guanggao", connection); <BR>//执行查询得到广告条数; <BR>query="SELECT url, banner, alt, priority FROM ad where priority &gt; 0"; <BR>result=mysql_db_query("guanggao", query); <BR>numrows=mysql_num_rows( result); <BR>//使用mysql_fetch_object()函数获取有用的列信息并存到相应数组中; <BR>while( row = mysql_fetch_object( result)) { <BR>adurl[]= row-&gt;url; <BR>adbanner[]= row-&gt;banner; <BR>adalt[]= row-&gt;alt; <BR>adpriority[]= row-&gt;priority; <BR>} <BR>//初始化中间变量; <BR>numcheck= numrows; <BR>i= pricount=0; <BR>//得到最大随机数; <BR>while( numcheck) { <BR>pricount+= adpriority[ i]; <BR>i++; numcheck--; <BR>} <BR>//程序执行时的百万分之一秒产生随机数种子; <BR>srand((double)microtime()*1000000); <BR>//得到1到最大随机数之间的一个随机数; <BR>pri = rand(1, pricount); <BR>//中间变量清零; <BR>pricount=0; <BR>//按加权值不同,产生用来显示广告的、元素为字串的数组; <BR>for( i=0; i&lt; numrows-1; i++) { <BR>pricount += adpriority[ i]; <BR>if ( pri &lt;= pricount) { <BR>ad[]="&lt;a href=" adurl[ i]" target=new&gt;&lt;/a&gt;"; <BR>} <BR>} <BR>//显示广告,权值越大,显示机会越大; <BR>echo ad[0]; <BR>?&gt;

17616401 发表于 2008-1-3 10:57

好东西!!顶!!!!

页: [1]

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.