0

0

PHP中实现支持显示格式化的用户输入,php格式化

php中文网

php中文网

发布时间:2016-06-13 09:29:09

|

976人浏览过

|

来源于php中文网

原创

php中实现支持显示格式化的用户输入,php格式化

你可以在这个页面下载这个文档附带的文件,也可以在文件下载中的字符处理中下载这个文档描述如何安全显示的有格式的用户输入。我们将讨论没有经过过滤的输出的危险,给出一个安全的显示格式化输出的方法。 

没有过滤输出的危险 

如果你仅仅获得用户的输入然后显示它,你可能会破坏你的输出页面,如一些人能恶意地在他们提交的输入框中嵌入javascript脚本: 

this is my comment. 
<script language="javascript: 
alert('do something bad here!')">. 

这样,即使用户不是恶意的,也会破坏你的一些html的语句,如一个表格突然中断,或是页面显示不完整。 


只显示无格式的文本 

这是一个最简单的解决方案,你只是将用户提交的信息显示为无格式的文本。使用htmlspecialchars()函数,将转化全部的字符为html的编码。 

如<b>将转变为,这可以保证不会有意想不到的html标记在不适当的时候输出。 
这是一个好的解决方案,如果你的用户只关注没有格式的文本内容。但是,如果你给出一些可以格式化的能力,它将更好一些。 
formatting with custom markup tags 
用户自己的标记作格式化 

你可以提供特殊的标记给用户使用,例如,你可以允许使用...加重显示,...斜体显示,这样做简单的查找替换操作就可以了: $output = str_replace("", "<b>", $output); 
$output = str_replace("", "<i>", $output); 

再作的好一点,我们可以允许用户键入一些链接。例如,用户将允许输入[link="url"]...[/link],我们将转换为<a href="">...</a>语句 

这时,我们不能使用一个简单的查找替换,应该使用正则表达式进行替换: 
$output = ereg_replace('\[link="([[:graph:]]+)"\]', '<a href="\\1">', $output); 

ereg_replace()的执行就是: 
查找出现[link="..."]的字符串,使用<a href="..."> 替换它 
[[:graph:]]的含义是任何非空字符,有关正则表达式请看相关的文章。 


在outputlib.php的format_output()函数提供这些标记的转换,总体上的原则是: 
调用htmlspecialchars()将html标记转换成特殊编码,将不该显示的html标记过滤掉, 
然后,将一系列我们自定义的标记转换相应的html标记。 
请参看下面的源代码: 
<?php 


function format_output($output) { 
/**************************************************************************** 
* takes a raw string ($output) and formats it for output using a special 
* stripped down markup that is similar to html 
****************************************************************************/ 

$output = htmlspecialchars(stripslashes($output)); 

/* new paragraph */ 
$output = str_replace('[p]', '<p>', $output); 

/* bold */ 
$output = str_replace('', '<b>', $output); 
$output = str_replace('', '</b>', $output); 

/* italics */ 
$output = str_replace('', '<i>', $output); 
$output = str_replace('', '</i>', $output); 

/* preformatted */ 
$output = str_replace('[pre]', '<pre>', $output); 
$output = str_replace('[/pre]', '</pre>', $output); 

/* indented blocks (blockquote) */ 
$output = str_replace('

', '<blockquote>', $output); 
$output = str_replace('

', '</blockquote>', $output); 

/* anchors */ 
$output = ereg_replace('\[anchor="([[:graph:]]+)"\]', '<a name="\\1"></a>', $output); 

/* links, note we try to prevent javascript in links */ 
$output = str_replace('[link="javascript', '[link=" javascript', $output); 
$output = ereg_replace('\[link="([[:graph:]]+)"\]', '<a href="\\1">', $output); 
$output = str_replace('[/link]', '</a>', $output); 

return nl2br($output); 


?> 

一些注意的地方: 

记住替换自定义标记生成HTML标记字符串是在调用htmlspecialchars()函数之后,而不是在这个调用之前,否则你的艰苦的工作在调用htmlspecialchars()后将付之东流。 

在经过转换之后,查找HTML代码将是替换过的,如双引号"将成为" 

nl2br()函数将回车换行符转换为<br>标记,也要在htmlspecialchars()之后。 

当转换[links=""] 到 <a href="">, 你必须确认提交者不会插入javascript脚本,一个简单的方法去更改[link="javascript 到 [link=" javascript, 这种方式将不替换,只是将原本的代码显示出来。 

outputlib.php 
在浏览器中调用test.php,可以看到format_output() 的使用情况 

正常的HTML标记不能被使用,用下列的特殊标记替换它: 

- this is bold 
- this is italics 
- this is [link="http://www.phpbuilder.com"]a link[/link] 
- this is [anchor="test"]an anchor, and a [link="#test"]link[/link] to the anchor 

[p]段落 
[pre]预先格式化[/pre] 

交错文本



这些只是很少的标记,当然,你可以根据你的需求随意加入更多的标记 

Conclusion 
结论 

这个讨论提供安全显示用户输入的方法,可以使用在下列程序中 

留言板 
用户建议 
系统公告 
BBS系统   

详细说明:http://php.662p.com/thread-343-1-1.html

大米商城damishop
大米商城damishop

damishop介绍 大米外贸商城系统 简称damishop 完全开源版,只需做一种语言一键开启全球133中语言自动翻译功能,价格实现自动汇率转换,集成微信支付宝 paypal以及国外主流支付方式,自带文章博客系统,首创支持可视化编辑。 软件架构 基于MVC+语言包模式,增加控制台,API导入产品方便对接其他系统(带json示例数据)。 使用要求

下载

PHP做一个网页 支持用户上传图片并显示的 怎实现

前台:




后台:
$pic_data = $_FILES["myFile"]["tmp_name"];
$pic_size = $_FILES["myFile"]["size"];
$filepic = addslashes(fread(fopen($pic_data, "rb"), $pic_size ));
后面再加上插入数据库的语句就可以了,如:"insert into pic(id,picture) values(1,$filepic)"
显示图片:
header("Content-type:image/jpeg");
连接数据库
$result=mysql_query("select * from pic where id=1");
$myrow=mysql_fetch_array($result);
echo ($myrow["picture"]);
 

PHP怎格式化数字?

PHP格式化数字的函数是number_format

我建议你去下载一个PHP的使用手册,或者看网上的在线手册也行。

www.itlearner.com/code/php/

关于他的用法如下:

语法: string number_format(float number, int [decimals], string [dec_point], string [thousands_sep]);

返回值: 字符串

函数种类: 数学运算

内容说明

本函数用来将浮点参数 number 格式化。若没加参数 decimals 则返回的字符串只要整数部份,加了此参数才依参数指定的小数点位数返回。参数 dec_point 表示小数点的表示方式方法,默认值是 ".",若需要转换成其它的小数点就可以在这个参数改掉。参数 thousands_sep 为整数部份每三位的分隔符号,默认值是 ","。本函数最特别的地方就是参数数目,最少要有一个,也就是欲格式化的字符串;也可以有二个或者四个参数,但不能用三个参数。治募?注意的是指定小数点的位数之后的数字直接舍弃,没有四舍五入的情形。

使用范例


$short_pi = "3.14159";
$my_pi = number_format($short_pi, 2);
echo $my_pi."\n"; // 3.14
$foo = 850017.9021;
$new_foo = number_format($foo, 3, ".", " ");
echo $new_foo."\n"; // 850 017.902
?>
 

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

42

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

4

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

3

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.1万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号