选择显示字体大小

如何使php文件与html码更好的分离--eval函数的用法


大家都知道,php是一种服务器端的内嵌html式的脚本编程语言.可是按照内嵌html
方式来作一网站的话,代码很快就变得庞大而且不可控制.如何才能使php代码与html
分离,做出类似dw的lib(模板)而使得页面更加容易修改并且代码容易维护呢?
后来,看了很多文章,说phplib可以实现,随手看了几页,觉得头晕脑涨,顿时没有了看
下去的欲望(那位大虾如果有此心得,敬请不吝赐教,先行谢过!).可是问题还得解决,在
郁闷了多日之后,一次偶然机会,得以下载vbb论坛的源码,粗粗看过之后,发现除了php
文件外,很少看见html码.心想这不就是我想要的样式吗,看吧.依然头晕脑涨:(,唯一的
收获是知道了它把html码放在数据库里,通过php文件调用,经过一系列处理后,用eval函数
将希望的变量带入生成所需要的动态页.这样,我就没再看vbb源码,而转入eval函数了.
星空浪子的php中文手册是这样介绍eval函数的:

函式:eval()

杂项函式库

eval
将值代入字串之中。

语法: void eval(string code_str);

传回值: 无

函式种类: 资料处理


内容说明

本函式可将字串之中的变数值代入,通常用在处理资料库的资料上。参数 code_str
为欲处理的字串。值得注意的是待处理的字串要符合 php 的字串格式,同时在结尾
处要有分号。使用本函式处理后的字串会沿续到 php 程式结束。

使用范例

<?php
&#36;string = '杯子';
&#36;name = '咖啡';
&#36;str = '这个 &#36;string 中装有 &#36;name.<br>';
echo &#36;str;
eval( &quot;\&#36;str = \&quot;&#36;str\&quot;;&quot; );
echo &#36;str;
?>

本例的传回值为

这个 &#36;string 中装有 &#36;name.
这个 杯子 中装有 咖啡.


例子测试没有任何问题.可是,当我测试如下代码时,却出现了错误:
<?
&#36;aa='my name is yyy!';
&#36;str='<input type=&quot;text&quot; name=&quot;textfield&quot; value=&quot;&#36;aa&quot;>';
eval( &quot;\&#36;str = \&quot;&#36;str\&quot;;&quot; );
echo &#36;str;
?>
百思不得其解后,在chainasp上求救,在网友提出的一系列解决方案
中,终于以这种方式运行成功:
<?
&#36;aa='my name is yyy!';
&#36;str='<input type=&quot;text&quot; name=&quot;textfield&quot; value=&quot;\'&#36;aa\'&quot;>';
eval( &quot;\&#36;str = \&quot;&#36;str\&quot;;&quot; );
echo &#36;str;
?>

可是,当我把&#36;str 插入如下一个表中然后又提取出时,又出错了,简直恼火
死了.

数据库 evaltest
# 表结构 'envtest'

create table envtest (
 id tinyint(4) not null auto_increment,
 sour mediumtext,
 primary key (id),
 unique id (id),
 key id_2 (id)
);

#表内容 'envtest'
insert into envtest values( '1', '<input type=\&quot;text\&quot; name=\&quot;textfield\&quot; value=\&quot;&#36;aa\&quot;>');

php文件如下:
<?
&#36;aa='my name is yyy!';
&#36;conn=mysql_connect('localhost','root','');
&#36;sele='select sour from envtest where id=1';
&#36;res=mysql_db_query('evaltest',&#36;sele);
&#36;arra=mysql_fetch_array(&#36;res);
&#36;str=&#36;arra['sour'];
eval( &quot;echo \&quot;&#36;str\&quot;;&quot; );
?>
再看看星空浪子的php中文手册,发现这么一句话:&quot;待处理的字串要符合 php 的字串格式&quot;,什么叫
&quot;符合 php 的字串格式&quot;(有谁知道,麻烦告诉一声)?我不知道,也无从查找,只好看看字串处理函数.
发现htmlspecialchars()好像可用,于是试了一把:
<?
&#36;aa='my name is yyy!';
&#36;conn=mysql_connect('localhost','root','');
&#36;sele='select sour from envtest where id=1';
&#36;res=mysql_db_query('evaltest',&#36;sele);
&#36;arra=mysql_fetch_array(&#36;res);
&#36;str=htmlspecialchars(&#36;arra['sour']);
eval( &quot;echo \&quot;&#36;str\&quot;;&quot; );
?>
可是在页面上显示是这样的:
<input type=&quot;text&quot; name=&quot;textfield&quot; value=&quot;my name is yyy!&quot;>
变量带入成功,可显示不符合要求.察看文件源码,内容如下:
<input type=&quot;text&quot; name=&quot;textfield&quot; value=&quot;my &bsp name &bsp is yyy!&quot;>
再看看手册的htmlspecialchars()的用法,发现此函数对字串作了如下操作:
& (和) 转成 &
&quot; (双引号) 转成 &quot;
< (小于) 转成 <
> (大于) 转成 >
再查找,没发现与此函数作用相反的函数,于是,自己加了几行代码,再作如下调试,终于成功.
<?php
function dehtml(&#36;str){
 &#36;str=str_replace('&quot;','&quot;',&#36;str);
 &#36;str=str_replace('<','<',&#36;str);
 &#36;str=str_replace('>','>',&#36;str);
 &#36;str=str_replace('&','&',&#36;str);  
return &#36;str;
}  
&#36;aa='my name is yyy!';
&#36;conn=mysql_connect('localhost','root','');
&#36;sele='select sour from envtest where id=1';
&#36;res=mysql_db_query('evaltest',&#36;sele);
&#36;arra=mysql_fetch_array(&#36;res);
&#36;str=htmlspecialchars(&#36;arra['sour']);
eval( &quot;echo dehtml(\&quot;&#36;str\&quot;);&quot; );
?>
在这个代码调试成功后,我又把一个内容复杂的html页面的源码加入一变量后插入到evaltest表中,
再次测试,也成功了.
有关eval函数用法里的&quot;待处理的字串要符合 php 的字串格式&quot;,我想是经过
htmlspecialchars()函数处理过的字串吧,不知正确与否,有待方家斧正.

以上方法敬请各位网友测试,如果发现有什么错误或者有比这更好的解决方法,请告我一声,我的邮件
地址为:chensiping@263.net

  


 


关键字 本文所属关键字

相关 与本文相关文章

分类 所有文章关键字导航

源码编程相关

Java   Asp   PHP   .Net   XML   C/C++   CGI   VB   Jsp   J2ee   J2se   J2me   EJB   Servlet   Tomcat   Resin   Struts   Weblogic   Eclipse   ANT   GUI   JMS   Web servise   IDEA   Webphere   Hibernate   Spring   Jboss   Applet   Swing   Socket   Javamail   Perl   Ajax   P2P   安全   模式   框架   测试   开源   游戏

SQL数据库相关

My-SQL   Ms-SQL   Access   DB2   Oracle   Sybase   SQLserver   索引   存储过程   加密   数据库   分页   视图  

手机无线相关

3G   Wap   CDMA   GRPS   GSM   IVR   彩信   短信   无线   增值业务

网页设计制作相关

HTML   CSS   网页配色   网页特效   Javascript   VBscript   Dreamweaver   Frontpage   JS   Web   网站设计

网站建设推广相关

建站经验   网站优化   网站排名   推广   Alexa

操作系统/服务器相关

Windows XP   Windows 2000   Windows 2003   Windows Me   Windows 9.x   Linux   UNIX   注册表   操作系统   服务器   应用服务器

图形图像多媒体相关

Photoshop   Fireworks   Flash   Coreldraw   Illustrator   Freehand   Photoimpact   多媒体   图形图像

标准 网站致力的规范

Valid CSS!

无不良内容,无不良广告,无恶意代码

Valid XHTML 1.0 Transitional

creativecommons