为什么Linux上的共享库可执行?

前端之家收集整理的这篇文章主要介绍了为什么Linux上的共享库可执行?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我只是好奇.
bash-3.00$ ldd libmylibrary.so
ldd: warning: you do not have execution permission for `libmylibrary.so'

一切似乎只用r工作正常.我注意到/usr/lib中的大多数.so都有x set …

为什么共享库应该设置可执行位?如果我没有设置它会发生什么?

解决方法

实际上它取决于ldd实现. ldd通常是一个脚本,您可以编辑它以查看出现该错误的位置和原因.

在Ubuntu 10.04上,ldd仅检查读取权限.如果文件不是ELF(可执行和可链接格式),则可能使错误不是动态可执行文件.例如,这里的库都是-rw-r – r–

$find /usr/lib -type f -name "libm*.so*" -ls
(...)
-rw-r--r--   1 root     root       216800 Feb 26 22:20 /usr/lib/libmp.so.3.1.16
-rw-r--r--   1 root     root        76728 Mar 14 04:23 /usr/lib/libmjpegutils-1.9.so.0.0.0
-rw-r--r--   1 root     root       134464 Jan 29  2010 /usr/lib/libm17n-core.so.0.3.0
-rw-r--r--   1 root     root       290480 Feb 17  2010 /usr/lib/libmtp.so.8.3.2

想要对共享库进行x访问并不令人震惊.可执行模式是一种约定,它为操作系统提供了另一级别的访问权限控制.可执行加载程序控制该访问,以确保用户可以执行它,还可以防止错误(某些脚本或程序不应由某些人执行).

出于同样的原因,这可以扩展到共享库 – 但是共享库不能自己运行,并且不容易被意外使用).因此需求不太明显(r访问就足够了).

猜你在找的Linux相关文章