很多站长朋友们都不太清楚php在线查报错,今天小编就来给大家整理php在线查报错,希望对各位有所帮助,具体内容如下:
本文目录一览: 1、 使用PHP程序检查PHP文件是否有语法错误 2、 php websocket 如何调试bug哪里查看报错信息,var_dump哪里看? 3、 php连接Access数据库查询报错 4、 php网站登陆后台之后显示:查询数据库出错,求大神帮忙!! 5、 php操作数据库WHERE语句查询中文报错,无法读取数据? 6、 PHP表连接查询报错怎么解决? 使用PHP程序检查PHP文件是否有语法错误在网上找了一下。刚开始以为 token_get_all()函数能处理语法错误的问题,结果发现,它只是做简单的词法分析。没有办法。后来到论坛上去问了一下
之前在当当的时候的一个项目中用到了一个简单的模板引擎,其实也是借鉴discuz来做的模板引擎,很简单,它所作的事情就是把一些自定义的标签编译成php代码。已经说了很简单了,所以编译的时候也名优进行模板语法的检查,那么在开发过程中就会出现编译出来的php文件有语法问题,有语法问题没有关系,我修改重新编译一下就好了。首先不能在每次请求的时候都把php模板重新编译一下,会严重影响性能,折中的处理时在每个编译好的php文件末尾检查一下该模板文件是否已经修改过,根据设定的更新频率,如果又需要则重新编译模板文件,现在的问题是编译出来的php文件自己有语法错误,根本执行不到模板检查那一步,所以即使修改了模板文件中的问题也不会重新编译。 所以我想寻找一种简单的方法来检查生成的php文件是否合法。不合法就重新编译,这样开发过程中就不用出现错误就得手动删除缓存文件了。
在网上找了一下。刚开始以为 token_get_all()函数能处理语法错误的问题,结果发现,它只是做简单的词法分析。没有办法。后来到论坛上去问了一下
有人告诉我有这样一个函数 php_check_syntax() 我想问题就这么坚决了。。我真应该rtf(read the fuck mannual). 仔细一看。这个函数已近被弃用了:
note: for technical reasons, this function is deprecated and removed from php. instead, use php -l somefile.php from the commandline.
这个technical reason 到底是什么呢? 先不管了,以后再慢慢研究,反正不能使用这个方法就对了。
他们的建议是使用命令行$php -l filename.php 来检查语法。
gary every给了我一个代码片段参考:
在命令行下检查问题也不大。如果我要放在在线应用呢? 这就涉及到可移植性的问题了。首先是操作系统,然后就是环境变量。这样的话就会依赖于服务器端的配置。在 上有人贴出了自己的php_check_syntax()函数实现。
有的采用的就是上面的命令行的方法。
后面有提到使用eval的方法来验证。eval方法会执行传入的代码, 如果代码有语法错误则会抛出parser error, 可以使用'@'错误抑制符去掉错误信息,eval和echo一样并不是函数,不能使用变量函数的方法调用比如:
$func = ‘eval'
$func()这样的调用就是无效的。它会提示没有eval函数,如果你自己定义这么一个函数也是有问题的。因为eval是一个关键字。
eval调用和include差不多,如果被包含文件中没有明确return就返回null。如果直接eval我们需要检查的文件会造成被检查的文件内代码被执行,这可不是我们想要的,我们只需要检查一下这个文件的语法是否正确。 我们可以在要检查的文件之前添加return 语句,让代码提前跳出,那么后面的代码就不会执行了。好的,就这么干。
checker.php
if(!function_exists('php_check_syntax')) {
function php_check_syntax($file_name, $error_message = null) {
$file_content = file_get_contents($file_name);
$check_code = "return true; ?>";
$file_content = $check_code . $file_content . "<?php ";
if(!@eval($file_content)) {
$error_message = "file: " . realpath($file_name) . " have syntax error";
return false;
}
return true;
}
}
if(!php_check_syntax("file.php", $msg)) {
echo $msg;
}
else {
echo "woohoo, ok!";
}
file.php
<?php
foreach:: a => b
?>
因为parse error 是没法被 set_error_handler处理函数处理的。这个异常没办法catch到。所以才使用了@来抑制错误。这带来的问题就是我们无法得到详细的错误信息。 不过目前我需要的功能也只是检查语法是否正确。不正确的话重新编译模板文件,就这么简单,至于语法错误,在显示网页的时候自然会看得到。
php websocket 如何调试bug哪里查看报错信息,var_dump哪里看?要配置php.ini
xdebug.var_display_max_depth = 10xdebug.var_display_max_children = 256xdebug.var_display_max_data = 1024 ; with no limits
; (maximum nesting is 1023)
xdebug.var_display_max_depth = -1 xdebug.var_display_max_children = -1xdebug.var_display_max_data = -1
php连接Access数据库查询报错试试我的代码
<?PHP
/*
创建ADO连接
*/
$conn = @new COM("ADODB.Connection") or die ("ADO Connection faild.");
$connstr = "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=" . realpath("Database1.accdb");
$conn->Open($connstr);
/*
创建记录集查询
*/
$rs = @new COM("ADODB.RecordSet");
$rs->Open("select * from dbo_dirs",$conn,1,3);
/*
循环读取数据
*/
while(!$rs->eof){
echo $rs->Fields["title"]->Value;
echo "<br/>";
$rs->Movenext(); //将记录集指针下移
}
$rs->close();
?>
php网站登陆后台之后显示:查询数据库出错,求大神帮忙!!你随便输入一个不存在的帐号和密码,然后点登录看,如果也是同样错误,请检查数据库连接,包括密码等,如果连接正确,再检查数据库是否完整,如果均正确,再看PHP代码
php操作数据库WHERE语句查询中文报错,无法读取数据?MYSQL的字段名转义使用返引号`,不是单引号,注意上面代码的下面部分:
WHERE '账户'='中文'; //查询中文字报错,数字字母都能正常查询
【账户】是字段名,应使用反引号:
`账户`
【中文】是常量,单双引号都可以,但是要注意你现在的语句是在单引号里面,因此应该转义或者使用双引号,这部分可以修改为:
WHERE 账户="中文"';
另外,如果只是查询中文内容才报错,可能你粘贴代码和原始代码有区别,原始代码没有把字段名放在单引号里面,否则是查不到内容的。查询中文内容报错,一般是中文的编码和网页文件的编码、以及数据库的编码不一致,你这来数据库是UTF8,那么PHP脚本文件、浏览器网页都必须使用UTF-8
PHP表连接查询报错怎么解决?上面的程序代码改为:
<table align=center width=800 border=1>
<tr>
<td>产品编号</td>
<td>产品分类</td>
<td>产品货号</td>
</tr>
<?
$sql = "select 产品.pid,分类表.sname,产品.name from 产品,分类表 where 产品.sort=分类表.sid order by 产品.pid"
$rst = @new COM("ADODB.RecordSet")
$rst->Open($sql,$con,1,3)
while(!$rst ->EOF){?><td><?=$rst->Fields["pid"]->Value?></td>
<td><?=$rst->Fields["sname"]->Value?></td>
<td><?=$rst->Fields["name"]->Value?></td>
</tr><?
$rst->Movenext();}
$con->close();?>
</table>
通过php判断某个用户是否存在的代码如下:
//拆分发来的信息得到会员卡号<br data-filtered="filtered">
$arry=explode("+",$form_Content);<br data-filtered="filtered">
$memberid =$arry[1];<br data-filtered="filtered">
<br data-filtered="filtered">
//连接数据库<br data-filtered="filtered">
$link=mysql_connect(SAE_MYSQL_HOST_M.':'.SAE_MYSQL_PORT,SAE_MYSQL_USER,SAE_MYSQL_PASS);<br data-filtered="filtered">
if($link) {<br data-filtered="filtered">
mysql_select_db(SAE_MYSQL_DB,$link); <br data-filtered="filtered">
//查询数据<br data-filtered="filtered">
$result1=mysql_query("select * from numbers where pmcode = '".$memberid."';");<br data-filtered="filtered">
<br data-filtered="filtered">
$num_result = mysql_num_rows($result1);<br data-filtered="filtered">
if($num_result==1){<br data-filtered="filtered">
//$row= $result1->fetch_assoc();<br data-filtered="filtered">
$row=mysql_fetch_row($result1);<br data-filtered="filtered">
$result_str="您的会员--信息如下:\n\n卡号:$row[pmcode].\n姓名:.$row[names].\n等级:.$row[4].\n积分:$a[5]";<br data-filtered="filtered">
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType,$result_str); <br data-filtered="filtered">
echo $resultStr
<br data-filtered="filtered">
exit;<br data-filtered="filtered">}else{<br data-filtered="filtered">
$msgType = "text";<br data-filtered="filtered">
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType,"--select * from numbers where pmcode = '".$memberid."'"); <br data-filtered="filtered">
echo $resultStr
<br data-filtered="filtered">
exit;<br data-filtered="filtered">
<br data-filtered="filtered">}<br data-filtered="filtered">
<br data-filtered="filtered">}
else{<br data-filtered="filtered">
echo "连接数据库失败".mysql_error;<br data-filtered="filtered">}
<br data-filtered="filtered">
mysql_close($link);<br data-filtered="filtered">}
关于php在线查报错的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。
查看更多关于php在线查报错 php排查错误的详细内容...