php下过滤HTML代码的函数

 更新时间:2016年11月25日 16:11  点击:1677

*----------------------
过滤HTML代码的函数
-----------------------*/
function htmlEncode($string) {
    $string=trim($string);
    $string=str_replace("&","&",$string);
    $string=str_replace("''","''",$string);
    $string=str_replace("&","&",$string);
    $string=str_replace(""",""",$string);
    $string=str_replace(""",""",$string);
    $string=str_replace("&lt;","<",$string);
    $string=str_replace("<","<",$string);
    $string=str_replace("&gt;",">",$string);
    $string=str_replace(">",">",$string);
    $string=str_replace("&nbsp;"," ",$string);
    $string=nl2br($string);
    return $string;
}

 

数字验证码



 <? 
   
/* 
    *   Filename: authpage.php 
    
*/ 
session_start();
     
//   srand((double)microtime()*1000000); 
        $authnum = $_SESSION[''authnum''];
        
//验证用户输入是否和验证码一致 
        if(isset($_POST[''authinput'']))  
        { 
                
if(strcmp($_POST[''authinput''],$_SESSION[''authnum''])==0
                        
echo "验证成功!"
                
else 
                        
echo "验证失败!"
        } 
    
        
//生成新的四位整数验证码 

    //    while(($authnum=rand()%10000)<1000);  

    ?> 
        
<form action=test4.php method=post> 
        
<table> 
                请输入验证码:
<input type=text name=authinput style="width: 80px"><br> 
                
<input type=submit name="验证" value="提交验证码"> 
                
<input type=hidden name=authnum value=<? echo $authnum?>> 
                
<img src=authimg.php?authnum=<? echo $authnum?>> 
        
</table> 
        
</form> 

 

 

 authimg.php



<?php 
//生成验证码图片 
Header("Content-type: image/PNG");  
srand((double)microtime()*1000000);//播下一个生成随机数字的种子,以方便下面随机数生成的使用

session_start();//将随机数存入session中
$_SESSION[''authnum'']="";
$im = imagecreate(62,20); //制定图片背景大小

$black = ImageColorAllocate($im, 0,0,0); //设定三种颜色
$white = ImageColorAllocate($im, 255,255,255); 
$gray = ImageColorAllocate($im, 200,200,200); 

imagefill(
$im,0,0,$gray); //采用区域填充法,设定(0,0)

while(($authnum=rand()%100000)<10000);
//将四位整数验证码绘入图片 
$_SESSION[''authnum'']=$authnum;
imagestring(
$im, 5, 10, 3, $authnum, $black);
// 用 col 颜色将字符串 s 画到 image 所代表的图像的 x,y 座标处像的左上角为 0, 0)。
//如果 font 是 1,2,3,4 或 5,则使用内置字体


for($i=0;$i<200;$i++)    //加入干扰象素 

     
$randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
     imagesetpixel(
$im, rand()%70 , rand()%30 , $randcolor); 
}
ImagePNG(
$im); 
ImageDestroy(
$im); 
?>


<

sprintf

将字串格式化。

语法: string sprintf(string format, mixed [args]...);

传回值: 字串

函式种类: 资料处理

内容说明

本函式用来将字串格式化。参数 format 是转换的格式,以百分比符号 % 开始到转换字符为止。而在转换的格式间依序包括了

1. 填空字元。0 的话表示空格填 0;空格是内定值,表示空格就放着。

2. 对齐方式。内定值为向右对齐,负号表向左对齐。

3. 栏位宽度。为最小宽度。

4. 精确度。指在小数点后的浮点数位数。

型态,见下表

=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
转换字符
=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
% 印出百分比符号,不转换。
b 整数转成二进位。
c 整数转成对应的 ASCII 字元。
d 整数转成十进位。
f 倍精确度数字转成浮点数。
o 整数转成八进位。
s 整数转成字串。
x 整数转成小写十六进位。
X 整数转成大写十六进位。

例子

=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-

使用范例

<?
$money1 = 68.75;
$money2 = 54.35;
$money = $money1 + $money2;
// 此时变数 $money 值为 "123.1";
$formatted = sprintf ("%01.2f", $money);
// 此时变数 $ formatted 值为 "123.10"
?>

=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-

这个 %01.2f 是什么意思呢?

首先 这个 % 符号是开始的意思,他写在最前面表示指定格式要开始了。 也就是 "起始字符", 直到出现 "转换字符" 为止,就算格式终止。

然后 跟在 % 符号 后面的是 0 这个零是 "填空字元" 表示,如果位置空着 就用0来填满。
在 0 后面的是 1 这个 1 是规定,小数点前面的数字占位要有1位以上。

如果把 1 改成 2 如果 $money 的值为 1.23 ,则 $formatted 的值将为 01.23
因为,在小数点前面的数字只占了1位,按照上面所规定的格式,小数点前数字应该占2位,现在只有1位,所以,用0来填满。

到目前,在 %01 后面的 .2 (点2) 就很好理解了,它的意思是,规定,小数点后的数字,必需占2位. 如果这时候,$money 的值为 1.234,则 $formatted 的值将为 1.23。
为什么 4 不见了呢? 因为,在小数点后面 按照上面的规定,必需且仅能占2位。 可是 $money 的值中,小数点占了3位,所以,4 被去掉了,只剩下 23。

最后,以 f "转换字符" 结尾,其他转换字符请自行参考上面的转换字符列表。

关于对齐

如果在 % 起始符号后面 加上 - (负号) 则,将会把数字以向右对齐的方式进行处理。

列子


<?
$money = 1.4;

$formatted = sprintf ("%-02.2f", $money);

echo $formatted;
?>

这时候,$formatted 将不会再是 01.40 而是 1.400

 

<


AddSlashes:    字符串加入斜线。
bin2hex:    二进位转成十六进位。
Chop:    去除连续空白。
Chr:    返回序数值的字符。
chunk_split:    将字符串分成小段。
convert_cyr_string:    转换古斯拉夫字符串成其它字符串。
crypt:    将字符串用 DES 编码加密。
echo:    输出字符串。
explode:    切开字符串。
flush:    清出输出缓冲区。
get_meta_tags:    抽出文件所有 meta 标记的资料。
htmlspecialchars:    将特殊字符转成 HTML 格式。
htmlentities:    将所有的字符都转成 HTML 字符串。
implode:    将数组变成字符串。
join:    将数组变成字符串。
ltrim:    去除连续空白。
md5:    计算字符串的 MD5 哈稀。
nl2br:    将换行字符转成 <br>。
Ord:    返回字符的序数值。
parse_str:    解析 query 字符串成变量。
print:    输出字符串。
printf:    输出格式化字符串。
quoted_printable_decode:    将 qp 编码字符串转成 8 位字符串。
QuoteMeta:    加入引用符号。
rawurldecode:    从 URL 专用格式字符串还原成普通字符串。
rawurlencode:    将字符串编码成 URL 专用格式。
setlocale:    配置地域化信息。
similar_text:    计算字符串相似度。
soundex:    计算字符串的读音值
sprintf:    将字符串格式化。
strchr:    寻找第一个出现的字符。
strcmp:    字符串比较。
strcspn:    不同字符串的长度。
strip_tags:    去掉 HTML 及 PHP 的标记。
StripSlashes:    去掉反斜线字符。
strlen:    取得字符串长度。
strrpos:    寻找字符串中某字符最后出现处。
strpos:    寻找字符串中某字符最先出现处。
strrchr:    取得某字符最后出现处起的字符串。
strrev:    颠倒字符串。
strspn:    找出某字符串落在另一字符串遮罩的数目。
strstr:    返回字符串中某字符串开始处至结束的字符串。
strtok:    切开字符串。
strtolower:    字符串全转为小写。
strtoupper:    字符串全转为大写。
str_replace:    字符串取代。
strtr:    转换某些字符。
substr:    取部份字符串。
trim:    截去字符串首尾的空格。
ucfirst:    将字符串第一个字符改大写。
ucwords:    将字符串每个字第一个字母改大写

htmlspecialchars

将特殊字符转成 HTML 格式。

语法: string htmlspecialchars(string string);

返回值: 字符串

函数种类: 资料处理

 

 
内容说明

本函数将特殊字符转成 HTML 的字符串格式 ( &....; )。最常用到的场合可能就是处理客户留言的留言版了。

 

  • & (和) 转成 &amp;
  • " (双引号) 转成 &quot;
  • < (小于) 转成 &lt;
  • > (大于) 转成 &gt;

此函数只转换上面的特殊字符,并不会全部转换成 HTML 所定的 ASCII 转换。

 

 
使用范例

这是 aulbach@unter.franken.de (27-Jan-1999) 所提供的范例

<FORM ACTION=bla>
<H2>Restaurant Description<H2>
Name of restaurant:
<INPUT TYPE=text NAME="restname" VALUE="<?
     
echo HTMLSpecialChars($restname); ?>"> 
<!-- 变量 $restname 是酱子的 $restname=""The Whit
SyntaxHighlighter.highlight();

[!--infotagslink--]

相关文章

  • php正确禁用eval函数与误区介绍

    eval函数在php中是一个函数并不是系统组件函数,我们在php.ini中的disable_functions是无法禁止它的,因这他不是一个php_function哦。 eval()针对php安全来说具有很...2016-11-25
  • php中eval()函数操作数组的方法

    在php中eval是一个函数并且不能直接禁用了,但eval函数又相当的危险了经常会出现一些问题了,今天我们就一起来看看eval函数对数组的操作 例子, <?php $data="array...2016-11-25
  • Python astype(np.float)函数使用方法解析

    这篇文章主要介绍了Python astype(np.float)函数使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-06-08
  • Python中的imread()函数用法说明

    这篇文章主要介绍了Python中的imread()函数用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-03-16
  • C# 中如何取绝对值函数

    本文主要介绍了C# 中取绝对值的函数。具有很好的参考价值。下面跟着小编一起来看下吧...2020-06-25
  • C#学习笔记- 随机函数Random()的用法详解

    下面小编就为大家带来一篇C#学习笔记- 随机函数Random()的用法详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-25
  • 不打开网页直接查看网站的源代码

      有一种方法,可以不打开网站而直接查看到这个网站的源代码..   这样可以有效地防止误入恶意网站...   在浏览器地址栏输入:   view-source:http://...2016-09-20
  • php 调用goolge地图代码

    <?php require('path.inc.php'); header('content-Type: text/html; charset=utf-8'); $borough_id = intval($_GET['id']); if(!$borough_id){ echo ' ...2016-11-25
  • cmd下过滤文件名称的两种方法

    这篇文章主要介绍了cmd下过滤文件名称的两种方法,需要的朋友可以参考下...2020-06-30
  • JS基于Mootools实现的个性菜单效果代码

    本文实例讲述了JS基于Mootools实现的个性菜单效果代码。分享给大家供大家参考,具体如下:这里演示基于Mootools做的带动画的垂直型菜单,是一个初学者写的,用来学习Mootools的使用有帮助,下载时请注意要将外部引用的mootools...2015-10-23
  • JS+CSS实现分类动态选择及移动功能效果代码

    本文实例讲述了JS+CSS实现分类动态选择及移动功能效果代码。分享给大家供大家参考,具体如下:这是一个类似选项卡功能的选择插件,与普通的TAb区别是加入了动画效果,多用于商品类网站,用作商品分类功能,不过其它网站也可以用,...2015-10-21
  • JS实现自定义简单网页软键盘效果代码

    本文实例讲述了JS实现自定义简单网页软键盘效果。分享给大家供大家参考,具体如下:这是一款自定义的简单点的网页软键盘,没有使用任何控件,仅是为了练习JavaScript编写水平,安全性方面没有过多考虑,有顾虑的可以不用,目的是学...2015-11-08
  • php 取除连续空格与换行代码

    php 取除连续空格与换行代码,这些我们都用到str_replace与正则函数 第一种: $content=str_replace("n","",$content); echo $content; 第二种: $content=preg_replac...2016-11-25
  • 金额阿拉伯数字转换为中文的自定义函数

    CREATE FUNCTION ChangeBigSmall (@ChangeMoney money) RETURNS VarChar(100) AS BEGIN Declare @String1 char(20) Declare @String2 char...2016-11-25
  • php简单用户登陆程序代码

    php简单用户登陆程序代码 这些教程很对初学者来讲是很有用的哦,这款就下面这一点点代码了哦。 <center> <p>&nbsp;</p> <p>&nbsp;</p> <form name="form1...2016-11-25
  • Android开发中findViewById()函数用法与简化

    findViewById方法在android开发中是获取页面控件的值了,有没有发现我们一个页面控件多了会反复研究写findViewById呢,下面我们一起来看它的简化方法。 Android中Fin...2016-09-20
  • C++中 Sort函数详细解析

    这篇文章主要介绍了C++中Sort函数详细解析,sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变...2022-08-18
  • PHP实现清除wordpress里恶意代码

    公司一些wordpress网站由于下载的插件存在恶意代码,导致整个服务器所有网站PHP文件都存在恶意代码,就写了个简单的脚本清除。恶意代码示例...2015-10-23
  • PHP用strstr()函数阻止垃圾评论(通过判断a标记)

    strstr() 函数搜索一个字符串在另一个字符串中的第一次出现。该函数返回字符串的其余部分(从匹配点)。如果未找到所搜索的字符串,则返回 false。语法:strstr(string,search)参数string,必需。规定被搜索的字符串。 参数sea...2013-10-04
  • JS实现双击屏幕滚动效果代码

    本文实例讲述了JS实现双击屏幕滚动效果代码。分享给大家供大家参考,具体如下:这里演示双击滚屏效果代码的实现方法,不知道有觉得有用处的没,现在网上还有很多还在用这个特效的呢,代码分享给大家吧。运行效果截图如下:在线演...2015-10-30