linux – 每个用户的SSH MOTD

编程之家收集整理的这篇文章主要介绍了linux – 每个用户的SSH MOTD编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想为SSH用户显示横幅(欢迎消息),并为每个用户提供特定的欢迎消息.

解决方法

您没有指定,您使用的是什么SSH服务器.我假设OpenSSH.

请注意,SSH横幅和MOTD是两个不同的东西.

虽然在SSH终端中几乎无法区分,但它们具有不同的行为,例如,在SFTP客户端中.

MOTD只是在交互式终端上打印的文本.因此,它不会(也不会)被发送到SFTP客户端,例如(稍后会详细介绍).

MOTD被硬编码到OpenSSH中的/ etc / motd.您可以使用PrintMotd指令仅全局打开/关闭它.

但是,在某些Linux系统上,PrintMotd始终处于关闭状态,而PAM堆栈则打印出MOTD(使用pam_motd模块).在这种情况下,您可以通过/etc/pam.d/sshd将其关闭,或者将自定义motd = path指定为模块参数.

SSH标题是一种特殊的SSH 2.0功能,通过特定的SSH数据包(SSH2_MSG_USERAUTH_BANNER)发送.

因此,即使是非终端客户端(如SFTP客户端)也可以对其进行处理并向用户显示.例如,请参阅the banner displays in WinSCP SFTP/SCP client.

SSH横幅可使用Banner和Match指令在sshd_config中按用户(或组或其他标准)进行配置:

Match User username1
    Banner /etc/banner_user1

Match User username2
    Banner /etc/banner_user2

另见Disable ssh banner for specific users or ips.

当然,您也可以使用消息/横幅的自定义实现.只需从全局配置文件脚本中打印使用自定义逻辑选择的消息.

与MOTD一样,这不适用于非交互式会话(SFTP等).

更重要的是,不仅不起作用,还需要确保仅为交互式终端打印消息. OpenSSH为/ etc / motd自动执行的操作.使用仅为交互式终端执行的全局配置文件脚本,或者根据TERM环境变量的值有条件地打印消息.

如果您打印非交互式会话的消息,则会破坏使用严格协议的任何客户端,例如SFTP或SCP,因为客户端会尝试将您的文本消息解释为协议消息,但是会失败.

参见例如description of such issue in documentation of WinSCP SFTP/SCP client.

(我是WinSCP的作者)

总结

以上是编程之家为你收集整理的linux – 每个用户的SSH MOTD全部内容,希望文章能够帮你解决linux – 每个用户的SSH MOTD所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

小编个人微信号 jb51ccc
喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

相关文章

猜你在找的Linux相关文章

问题 最近在用容器跑 Tomcat 的时候,使用的官方的镜像 tomcat:8.5.43-jdk8-openjdk, 然后启动之后报了下面的错 java.util.MissingResourceExc
一、问题详情 linux一切皆文件 2021年4月2号,晚上10.45分左右,线上业务异常,后排查 线上服务器CPU 异常高,机器是 16核 64G的。但是实际负载已经达到了 140左右。 top 命
一、 /etc/security/limits.conf 详解 /etc/security/limits.conf 文件实际是 Linux PAM(插入式认证模块,Pluggable Authenti
一、问题 最近朋友出现一个这样的问题, 朋友在vim 某个文件的时候,发现里面的中文乱码了, 但是使用 tail 命令的时候是正常的。最后协助解决了下。 Vim 的时候 Tail 二、问题原因 综上所
禁止软件升级 sudo echo 软件包名 hold | sudo dpkg --set-selections 取消软件禁止升级的限制 sudo echo 软件包名 install | sudo dp
译 原文作者:Bobbin Zachariah 原文链接:https://linoxide.com/linux-command/essential-linux-basic-commands/ @ 在本
 规则包含两个部分,一个是依赖关系,一个是生成目标的方法。在Makefile中,规则的顺序是很重要的,因为,Makefile中只应该有一个最终目标,其它的目标都是被这个目标所连带出来的,所以一定要让make知道你的最终目标是什么。一般来说,定义在Makefile中的目标可能会有很多,但是第一条规则中的目标将被确立为最终的目标。如果第一条规则中的目标有很多个,那么,第一个