当前位置: 首页 > 数据库 > MSSQL内嵌式的语言php应用技巧七则

MSSQL内嵌式的语言php应用技巧七则

MSSQL内嵌式的语言php应用技巧七则内容导读: php(hypertextpreprocessor)是一种html内嵌式的语言,也是目前比较流行的网页编程语言。它支持的后端数据库种类凡多,几乎含盖了当前的所有数据库系统。同时它包含了一般语言有的数学运算、时间处理、文件系统、字符串处理、行程处理等功能,再加上它是免费...

  php(hypertextpreprocessor)是一种html内嵌式的语言,也是目前比较流行的网页编程语言。它支持的后端数据库种类凡多,几乎含盖了当前的所有数据库系统。同时它包含了一般语言有的数学运算、时间处理、文件系统、字符串处理、行程处理等功能,再加上它是免费的系统,使得成本与效益比,几乎等于无限大。

  下面是我在用php做网站时,总结出一些小技巧,拿出来飨以大家。

  1、判断某个函数是否被支持

  由于在php中我们可以灵活的使用增加或者减少php支持的模块,所以有的时候我们在使用php之前,总是会首先确定某个模块是否被加载,比如,看看gd图形模块是否被支持,可以用下面的这段代码:

  if(!function_exists(imagecreate))

  ?>

  同样的道理,我们可以利用类似的代码,测试mssql,oci等模块是否被支持。

  2、在字符串中把网址改成超级链接

  在网页中提交表单时,经常在提交的说明文本中出现一些网址,比如个人主页等信息,如果在显示时自动将其转为超级链接,那将是一件很惬意的事,就像用word编辑文档时自动出现超级链接一样。下面这段代码就很好的实现了其功能。

  $string="连接赛迪网站点";

  //注意:连接后需要有个空格或回车。

  $string=eregi_replace("http://([^,rn])","<ahref=tarrget=_blank></a>",$string);

  $string=eregi_replace("ftp://([^,rn])","<ahref=target=_blank></a>",$string);

  print$string;

  ?>

  3、用php处理多个同名复选框

  如果一个表单中有多个同名复选框,在提交到php时却只有一个值,而并不像asp那样是一串用逗号分割的值。解决的方法是利用数组。将复选框的name后面加上[],例如:改为:。这样php将得到一个叫pp的阵列。在提交的表单中先用count(pp)来判断数组的个数即选中的个数,然后对数组进行分别处理就行了。

  同样的道理也适应于处理下拉框的多选问题。

  4、利用static实现表格的颜色隔行显示

  我们用php从数据库查询数据,并将结果输出到浏览器上,如果结果有很多行,表格的bgcolor(背景色)如果全是单色的,浏览者会感觉不太舒服。那么怎样做使表格各行的颜色不同呢?请看下面代码:

  functiongetcolor()

  {

  static$colorvalue;//定义一个静态变量

  if($colorvalue=="#eeeeee")

  $colorvalue="#f5f5f5";

  else$colorvalue="#eeeeee";

  return($colorvalue);

  }

  print("<tableborder=1>n");//下面输出10行

  for($i=0;$i<10;$i++)

  {

  $bcolor=getcolor();//换背景颜色

  print("<trbgcolor=$bcolor>n");

  print("<td>$i</td>n");

  print("</tr>");

  }

  print("</table>n");

  ?>

  说明:

  此程序中定义了一个静态变量static$colorvalue意思是在函数调用结束后,此变量$colorvalue还保留值,没有消失。当再次调用getcolor()函数时,变量$colorvalue的值是上次函数调用结束时$colorvalue的值。

  5、在php中避免重复引用的办法

  大家知道,在c语言中,我们可以用#define来定义一个macro名字,通过检查是否该macro名字定义过来决定该头文件是否被引用。在php中也有同样的问题,比如:a引用b,c,b引用c,如果不采取措施,c将被引用2次。这样可能会导致一些奇怪的问题。解决办法:定义一个全局变量,并且通过检查该变量是否定义过来解决这个问题.办法很简单,类似c。只是这个全局变量我建议都用[user_packages][headfilename]的命名规则。

  if(!empty($globals[foodtails][globaldefine]))return;

  $globals[foodtails][globaldefine]=true;

  classfoodtails;

  ?>

  另外,在主程序中尽量采用require_once"headfiles.php";以避免重复引用。

  6、如何避免表单的重复提交

  我们在做网站时,常常为一些灌水文章而烦恼。有时,由于网络状况等原因用户不知道提交是否成功,也会再次提交同一份表单,这就造成了表单的重复提交不起。有一个简单的方法可以避免同一表单的重复提交。首先,先定义一个session变量用来保存一个表单的提交序列号。这里我定义为“$userlastaction”。然后在表单里加入一个hidden变量,把值设为$userlastaction+1:>最后,在处理提交之前判断表单是否已被提交过。

  if($lastaction>$userlastaction){

  $userlastaction++;//序列号加1

  //处理表单数据

  }

  ?>

  这个技巧的主要原理是不允许用户回退后再次提交,也就是说回退后修改再提交也是不允许的,但是还是不能避免ctrl-c/ctrl-v的灌水办法。

  7、下载文件的下载次数回填

  我们在下载软件时,经常会看到此软件的下载统计次数,而这些统计数给网站管理员分析软件的受欢迎程度带来了方便。其实现原理是:在后端数据库中存放软件的唯一标识和下载数,在用户下载软件时,首先更新对应软件的下载次数即下载次数加1,然后再到下载文件上正式开始下载。请看下面的实现代码:

  a、先建一数据表download(后端用mysql)

  download表中含有下列两个字段:

  id下载的文件的唯一标识

  MSSQLdownnum下载次数,默认值为0

  b、实现

  假设已经从数据库取出:描述文件名五笔字型;下载文件名:wbzx.zip;标识号id值为2

  处理后生成的超级链接代码为:

  五笔字型

  下面的代码download.php处理下载次数累计及根据传递的文件名定位下载文件。

  //连接mysql数据库代码略

  $res=mysql_query("updatedownloadsetdownnum=(downnum+1)whereid=$id",$db);

  header("location:$filename");

  ?>

关于MSSQL内嵌式的语言php应用技巧七则,其他人还感兴趣的是:
  ·jsp实际开发中,用哪种数据库多一些?mssql还
  ·access的跨库查询(图)
  ·access数据库转换为mssql数据库?
  ·测试你对技术的掌握度:jsp程序员成长之路
  ·新手讲堂:十个步骤打造安全的个人web服务器
  ·mssql存储过程解秘过程全析

如果觉得此内容不错,那就推荐给好友看看吧:
  本文标题:MSSQL内嵌式的语言php应用技巧七则
  本文地址:http://www.zxbc.cn/shujuku/0903811.html
------分隔线----------------------------