轻量级SSH实现之Dropbear

news2025/1/3 2:54:36

轻量级SSH实现之Dropbear

dropbear简介

Dropbear是一个轻量级的SSH服务器和客户端的实现。它运行在 各种 UNIX 平台。
Dropbear 是开源实现,MIT 分发 许可证。
Dropbear在嵌入式Linux(或其他Unix)系统广泛应用,例如无线路由器。
dropbear ssh

特性

  • 内存占用量小,适合内存受限的环境
  • Dropbear 可以静态编译为 110kB 在 x86 上与 uClibc 链接二进制文件(仅选择最小选项)
  • Dropbear 服务器为 OpenSSH 客户端实现 X11 转发和身份验证代理转发
  • 可以从 inetd 或独立运行
  • 兼容 OpenSSH ~/.ssh/authorized_keys 公钥身份验证
  • server, client, keygen, 和 密钥转换器可以编译成单个二进制文件(有点像 busybox)
  • 编译时可以轻松禁用功能以节省空间
  • 多跳模式使用 SSH TCP 转发通过多个 SSH 建立隧道 在单个命令中托管
dbclient user1@hop1,user2@hop2,destination

平台支持

  • Linux – 标准发行版, uClibc, dietlibc, musl libc, uClinux from inetd
  • Mac OS X(使用 PAM 支持编译)
  • FreeBSD、NetBSD 和 OpenBSD
  • Solaris – 经过测试 v8 x86 和 v9 Sparc
  • IRIX 6.5(使用 /dev/urandom,或者 prngd 应该可以工作)
  • Tru64 5.1 (使用 prngd 计算无序状态)
  • AIX 4.3.3(使用 gcc 和 Linux Affinity Toolkit),AIX 5.2(使用 /dev/urandom)。
  • HPUX 11.00 (+prngd),TCP 转发不起作用
  • Cygwin – 在Windows XP上测试1.5.19
    如果需要在其他平台上获得支持,只需要更改一些编译配置及文件生成规则。

其他

加密代码利用Tom St Denis的LibTomCrypt,PTY处理代码取自OpenSSH,登录记录(utmp/wtmp)代码来自Andre Lucas的OpenSSH, 并从PuTTY收集了一些实现细节。

服务端公钥认证

将server端 公钥加入到~/.ssh/authorized_keys中,公钥格式如下:

ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAIEAwVa6M6cGVmUcLl2cFzkxEoJd06Ub4bVDsYrWvXhvUV+ZAM9uGuewZBDoAqNKJxoIn0Hyd0Nk/yU99UVv6NWV/5YSHtnf35LKds56j7cuzoQpFIdjNwdxAN0PCET/MG8qyskG/2IE2DPNIaJ3Wy+Ws4IZEgdJgPlTYUBWWtCWOGc= someone@hostname

必须确保~/.ssh和密钥文件只能由用户编辑,不要把key编译为多行。
Dropbear支持authorized_keys条目的一些选项,请参见手册页。

客户端公钥认证

需要将OpenSSH格式的密钥转换为Dropbear格式的,或者使用dropbearkey工具生成。
如果你有openssh格式的私钥 ~/.ssh/id_rsa, 你需要做如下处理:

dropbearconvert openssh dropbear ~/.ssh/id_rsa  ~/.ssh/id_rsa.db
dbclient -i ~/.ssh/id_rsa.db <hostname>

Dropbear不支持加密的主机密钥,但可以连接到ssh代理。
如果您想获取Dropbear私钥的公钥部分,请查看dropbearkey的-y选项。

主机密钥使用

要运行服务器,您需要生成服务器密钥:

./dropbearkey -t rsa -f dropbear_rsa_host_key
./dropbearkey -t dss -f dropbear_dss_host_key
./dropbearkey -t ecdsa -f dropbear_ecdsa_host_key
./dropbearkey -t ed25519 -f dropbear_ed25519_host_key

或者将openssh的hostkey转成dropbear格式的hostkey

./dropbearconvert openssh dropbear /etc/ssh/ssh_host_dsa_key dropbear_dss_host_key

如果/etc/dropbear/下存在host key, 可以在dropbear启动时,使用-R 选项代入host key。

如果server以非root身份运行,则很可能无法分配pty,并且您不能以运行守护程序以外的任何用户身份登录(显然)。影子密码也不能为非root用户使用。

Dropbear发行版包括OpenSSH的scp的独立版本程序您可以使用make scp编译它,您可能需要更改ssh二进制文件的路径,由options.h中的_PATH_SSH_PROGRAM指定。您可以通过将SCPPROGRESS=1添加到make命令行。

链接

SSH维基
https://en.wikipedia.org/wiki/Secure_Shell

dropbear github地址
https://github.com/mkj/dropbear

LibTomCrypt源码地址
http://www.libtom.net/LibTomCrypt/

OpenSSH官方主页
http://openssh.org/

busybox主页
https://www.busybox.net/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/360433.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

蛋白质组学技术与常见分析培训班火热招生中!

什么是蛋白质组学&#xff1f; 蛋白质组学(proteomics)&#xff0c;是以蛋白质组为研究对象&#xff0c;研究细胞、组织或生物体蛋白质组成及其变化规律的科学。包括蛋白质的表达水平&#xff0c;翻译后修饰&#xff0c;蛋白与蛋白相互作用等研究内容&#xff0c;集中于动态描述…

华为机试JavaScript 字符串按次数降序排列;次数相同,按单词长度升序;排列次数和单词长度均相同,按字典升序排列

华为机试练习&#xff1a; 题目要求 1. 给定一个字符串s&#xff0c;s包括以空格分隔的若干个单词&#xff0c;请对s进行如下处理后输出:单词内部调整:对每个单词字母重新按 字典序排序 2、单词间顺序调整: 1) 统计每个单词出现的次数&#xff0c;并按次数 降序排列 …

【Kubernetes】【十四】Pod控制器详解 DaemonSet(DS) Job CronJob(CJ)

DaemonSet类型的控制器可以保证在集群中的每一台&#xff08;或指定&#xff09;节点上都运行一个副本。一般适用于日志收集、节点监控等场景。也就是说&#xff0c;如果一个Pod提供的功能是节点级别的&#xff08;每个节点都需要且只需要一个&#xff09;&#xff0c;那么这类…

05 基于STL的演讲比赛流程管理系统

文件基本上是黑马程序员的文档&#xff0c;部分添加自己需要的内容&#xff0c;仅用于自己学习&#xff01;链接&#xff1a;黑马程序视频课程GitHub:链接 演讲比赛流程管理系统 1、 演讲比赛程序需求 1.1 比赛规则 学校举行一场演讲比赛&#xff0c;共有12个人参加。比赛共…

江南爱窗帘十大品牌 | 窗帘的定做有哪些技巧和注意事项?

人们的家居空间中总是会有各式各样的窗帘存在的&#xff0c;为了使得窗帘的品质更加的过关&#xff0c;人们在选购时&#xff0c;总是会希望可以购买到高品质的。一般情况下&#xff0c;会采用定制这种方法去进行制作。那么&#xff0c;窗帘的定做有哪些注意事项?窗帘定制技巧…

PX4之启动脚本

PX4通过rcS脚本来设定需要启动的程序&#xff0c;比如设备驱动、控制模块、数据通信等。rcS脚本在项目中的文件位置 ROMFS/px4fmu_common/rcS 对应硬件平台固件上的位置 /etc/init.d/rcS 启动脚本流程如下 #!/bin/sh # PX4FMU startup script. # # 一些注释 ## 设置默认参…

【HDFS】FsDatasetImpl#convertTemporaryToRbw方法

功能: 把一个temporary副本转换成RBW副本。 方法的参数: 正在被转换成Rbw状态的的Temporary状态副本。 调用场景: datanode接收一个块的数据完成时,如果stage处于BlockConstructionStage.TRANSFER_RBW,那么就需要把temporary副本转换成RBW类型副本。 注意点: TEMPORARY副…

python 打包EXE

注&#xff1a; 从个人博客园 移植而来 环境&#xff1a; Windows7 Python 2.7 参考&#xff1a; 使用pyinstaller打包python程序 Pyinstaller 打包发布经验总结 Using PyInstaller 简介 使用python引用第三方的各种模块编写一个工具后&#xff0c;如果想发给其他人&…

Python基础-环境安装

Python安装1.下载PythonPython网址&#xff1a;https://www.python.org/进入Python官网&#xff0c;点击Downloads&#xff0c;选择自己对应的操作系统&#xff08;此处以Windows为例&#xff09;在左侧的稳定发行版中&#xff0c;选择一个3.5版本以上的&#xff0c;然后点击对…

2003-Can‘t connect to MySQL server on ‘192.168.232.128(10060 “Unknown error“)

MySQL远程连接报错2003-cant connection to mysql server on ‘IP’&#xff08;10061 unknown error&#xff09;的解决 **首先去看有没有关闭防火墙&#xff01;&#xff01;&#xff01;** 停止firewall服务 systemctl stop firewalld.service 禁止firewall开机启动 syste…

C++的完美讲解,还不快来看看?

目录 简介&#xff1a; 创建C程序&#xff1a; Windows编译简介&#xff1a; Hello,C World! 简介&#xff1a; C融合了3中不同的编程传统:C语言代表的过程性传统、C在C语言基础上添加的类代表的面向对象语言的传统以及C模板支持的通用编程传统。一般来说&#xff0c;计算机语言…

揭开JavaWeb中Cookie与Session的神秘面纱

文章目录1&#xff0c;会话跟踪技术的概述2&#xff0c;Cookie2.1 Cookie的基本使用2.2 Cookie的原理分析2.3 Cookie的使用细节2.3.1 Cookie的存活时间2.3.2 Cookie存储中文3&#xff0c;Session3.1 Session的基本使用3.2 Session的原理分析3.3 Session的使用细节3.3.1 Session…

数据结构与算法系列之kmp算法

什么是kmp算法 1.kmp算法是一种改进的字符串算法&#xff0c;其核心是利用匹配失败后的信息&#xff0c;尽量减少模式串与主串的匹配次数已达到快速匹配的目的。 它主要实现作用的是 在 &#xff08;主串&#xff09;中找到 &#xff08;匹配&#xff09;字符串。 例 BF算法与k…

接口服务限流方案

一.限流方式1.中间件支持限流2.限流配置单台服务最大qps&#xff0c;通过令牌桶算法进行限流3.支持url前缀匹配二.配置1.文件配置qps 1000 //单台服务最大qpsrule "/ucenter" //限流识别前缀&#xff0c;如不配置为全局限流downgradeHttpStatus 200//降级方案返回…

PointNet++的源码运行

首先&#xff0c;从github上下载源码https://github.com/yanx27/Pointnet_Pointnet2_pytorch也可以从百度网盘下载链接&#xff1a;https://pan.baidu.com/s/1sgTYuqnBVC9p3bib450SOQ 提取码&#xff1a;gujd再下载对应的测试数据分类数据modelnet40_normal_resampled下载&…

UnRaid虚拟机安装OpenWrt软路由

文章目录0、前言1、Openwrt虚拟机安装1.1、前提&#xff0c;需要先在UnRaid中开启虚拟机&#xff1a;1.2、下载OpenWrt虚拟机镜像并上传至UnRaid共享文件夹1.3、创建OpenWrt虚拟机2、开启并设置OpenWrt虚拟机2.1、修改OpenWrt管理ip2.2、OpenWrt的上网设置0、前言 最近折腾了很…

扁桃体肥大对儿童有什么影响?怎么办及怎样才能消下去?

很多人不知道扁桃体肥大对孩子有什么影响。今天&#xff0c;李松培医生将向大家讲解这方面的知识。同时&#xff0c;他还将告诉大家如何消除扁桃体肥大扁桃体肥大对儿童有什么影响&#xff1a;事实上&#xff0c;说实话&#xff0c;扁桃体肥大对儿童的影响很大&#xff0c;因为…

最全Linux驱动开发全流程详细解析(持续更新)

Linux驱动开发详细解析 一、驱动概念 驱动与底层硬件直接打交道&#xff0c;充当了硬件与应用软件中间的桥梁。 具体任务 读写设备寄存器&#xff08;实现控制的方式&#xff09;完成设备的轮询、中断处理、DMA通信&#xff08;CPU与外设通信的方式&#xff09;进行物理内存…

Python爬虫(8)selenium爬虫后数据,存入sqlit3实现增删改查

之前的文章有关于更多操作方式详细解答&#xff0c;本篇基于前面的知识点进行操作&#xff0c;如果不了解可以先看之前的文章 Python爬虫&#xff08;8&#xff09;selenium爬虫后数据&#xff0c;存入sqlit3实现增删改查导入默认包和环境元素定位创建一个sqlit3表将爬虫到的信…

知识蒸馏综述笔记

知识蒸馏的目的 将学习能力强的复杂教师模型中的“知识”迁移到简单的学生模型中 1.知识蒸馏的背景知识 2.解释知识蒸馏的作用机制 3.归纳知识蒸馏中知识的不同形式 4.详细分析和对比了知识蒸馏的各种关键方法&#xff0c; 5.介绍知识蒸馏与其它技术融合、 6.对知识蒸馏…