dthh5038 2015-01-07 17:14
浏览 26

我可以将PHP open_basedir应用于套接字路径吗?

The PHP manual states:

open_basedir (string)

Limit the files that can be accessed by PHP to the specified directory-tree, including the file itself. This directive is NOT affected by whether Safe Mode is turned On or Off.

When a script tries to access the filesystem, for example using include, or fopen(), the location of the file is checked. When the file is outside the specified directory-tree, PHP will refuse to access it.

Also, a little bit further...

open_basedir can affect more than just filesystem functions; for example if MySQL is configured to use mysqlnd drivers, LOAD DATA INFILE will be affected by open_basedir . Much of the extended functionality of PHP uses open_basedir in this way.

However, it seems that this restriction does not reach socket manipulation. On my server, even though I have set open_basedir to /home:/tmp, I can still access a socket file under /run through the socket_connect function (note that I haven't moved /var/run (/run) to some twisted location under /home or /tmp).

Is there a way to extend open_basedir's restrictions to include socket files* paths, so that it is impossible to open a socket file outside of /home and /tmp?

* I understand that socket files are not really "opened", but rather "bound to" through the socket_connect function and the bind system call. However, since open_basedir seems to apply on non-filesystem functions... I'm guessing there could be a way.

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥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
    • ¥20 重新写的代码替换了之后运行hbuliderx就这样了