dongqie4402 2015-05-26 10:35
浏览 162

PHP eval和依赖注入

I am writing a web application, which I want to be be "scriptable" - meaning that I want users to be able to write little snippets of code to add additional functionality.

The script to be run, simply returns a boolean, indicating whether a condition has been met - however, the logic depends on interrogating objects in the main block - so I need a way of injecting the environment in which eval is being called - into the script being interpreted.

Putting security concerns aside for a moment, this is what I want to do.

/* script pseudo code */
if object1.date() - today() < SOME_CONSTANT 
    return true;
else
   if object2.field1 == 123 && oject1.date() > object2.field2
       return true;
   else
       return false;

/* Main block of code */
$obj1 = New path\to\Object1();
$obj2 = New Path\To\Object2();

$result = eval($script);

if $result
    doSomething();

My questions then is:

How do I inject the environment into a string that is to be eval'd, so that I may access the object in the expression being evaluated?

  • 写回答

1条回答 默认 最新

  • duanao2585 2015-05-26 10:47
    关注

    The global statement makes global variables available inside a function. So put:

    global $var1, $var2, $var3, ...;
    

    in your function that calls eval, where these are all the global variables that the snippets should be able to access.

    评论

报告相同问题?

悬赏问题

  • ¥15 各位请问平行检验趋势图这样要怎么调整?说标准差差异太大了
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 wpf界面一直接收PLC给过来的信号,导致UI界面操作起来会卡顿
  • ¥15 init i2c:2 freq:100000[MAIXPY]: find ov2640[MAIXPY]: find ov sensor是main文件哪里有问题吗
  • ¥15 运动想象脑电信号数据集.vhdr
  • ¥15 三因素重复测量数据R语句编写,不存在交互作用
  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab