我想做的就是从数据库中获取已保存的运算符,并将其用于if-else条件。这是我的密码。它总是真实的。无法弄清楚我做错了什么
$sql_c = "select cc.operator, cc.dpt_id, dp.dpt_value as value from criteria_condition cc
join decision_point_type dp on cc.dpt_id = dp.dpt_id where criteria_id = $nodecriteria";
$res_c = mysql_query($sql_c);
while($row = mysql_fetch_array($res_c)){
$operand = $row['operator'];
$dpt_value = $row['value'];
}
echo "'$userinput'".$operand ."'$dpt_value'".'<br>';
if("'$userinput'".$operand."'$dpt_value'"){
echo 'true';
}else{
echo 'false';
}
Echo显示"hello"==="hello",但在这种情况下,它不能正常工作。
不能像那样使用字符串作为运算符。
看看这个:
您可以使用eval(),但是最安全的路线是:
$left = (int)$a;
$right = (int)$b;
$result = 0;
switch($char){
case "*":
$result = $left * $right;
break;
case "+";
$result = $left + $right;
break;
// etc
}
资源:
PHP使用字符串作为运算符