twi*_*oid 75 startup security scripts webcam software-recommendation
我正在使用笔记本电脑。我想在我的 Ubuntu 机器上获得支持。当输入错误的密码时,稍后会拍摄一张照片,显示谁一直试图获得访问权限。
我四处搜索,我发现的唯一一件事就是在 Mac 上执行此操作。是否可以为 Ubuntu 编写一个脚本来做同样的事情。
如果可能,那么什么是脚本或软件来实现这一点。
ger*_*ijk 63
基于这个帖子在ubuntu论坛由BkkBonanza。
这是一种使用 PAM 的方法,适用于所有失败的登录尝试。使用 SSH、虚拟终端或通过常规登录屏幕,这并不重要,因为最后一切都由 PAM 处理。
安装ffmpeg,我们将使用它作为抓取网络摄像头图像的命令行方式。更新:升级到 Ubuntu 14.04 时删除了 ffmpeg。我们可以在下面的脚本中使用 avconv 代替 ffmpeg。无需单独安装任何东西。
在某处创建一个小脚本,例如/usr/local/bin/grabpicture具有以下内容:
#!/bin/bash
ts=`date +%s`
ffmpeg -f video4linux2 -s vga -i /dev/video0 -vframes 3 /tmp/vid-$ts.%01d.jpg
exit 0 #important - has to exit with status 0
Run Code Online (Sandbox Code Playgroud)
/dev/video0使用网络摄像头的实际视频设备更改并选择保存图片的路径 - 我只是选择/tmp。在较新版本的 Ubuntu 中,使用( )avconv代替。ffmpegsudo apt-get install libav-tools
使其可执行,例如chmod +x /usr/local/bin/grabpicture。
测试,仅仅通过调用它:/usr/local/bin/grabpicture。检查您是否看到文件出现在/tmp/vid....jpg.
配置 PAM 以在每次失败的尝试时调用它。
注意:请小心执行此操作 - 如果此操作失败,您将无法以常规方式再次访问您的系统。
打开具有 root 访问权限 ( sudo -i)的终端窗口并保持打开状态 - 以防万一您在接下来的步骤中搞砸了。
/etc/pam.d/common-auth在您喜欢的编辑器中打开,例如通过执行gksudo gedit /etc/pam.d/common-auth. 请记住以下步骤,此文件中的行顺序很重要。
找到下面的行。默认情况下,在带有 的那一行之前有一行pam_deny.so。在我的 12.04 系统上,它看起来像这样:
auth [success=1 default=ignore] pam_unix.so nullok_secure
Run Code Online (Sandbox Code Playgroud)
在这一行中,将 更改为success=1使其success=2在成功时跳过我们的脚本。这是重要的一步如果您在此步骤中失败,请参阅下文如何恢复 (***)。
就在那里,添加一个新脚本来调用实际脚本:
auth [default=ignore] pam_exec.so seteuid /usr/local/bin/grabpicture
Run Code Online (Sandbox Code Playgroud)
保存并关闭文件。无需重新启动任何东西。
测试一下。
su -l username以另一个用户身份登录username(当然要更改为实际用户名)。故意输入错误的密码。检查这是否会产生新图片。如果测试成功,您可以从您的 DE (Unity/KDE/...) 注销,并且在从登录屏幕输入错误密码时应该会看到相同的信息。
(***) 如果您弄乱了 /etc/pam.d/common-auth 文件,如何恢复系统:
初始化=/bin/sh
到以“linux”开头的行
挂载具有写访问权限的系统
mount -o 重新挂载,rw /
编辑文件并修复
vi /etc/pam.d/common-auth