概述
本文讲述移植openssh的过程。
移植环境:
嵌入式操作系统:Linux-3.18.20
交叉编译器:arm-linux-gnueabi-gcc(4.9.2)
PC操作系统:Ubuntu 18.04
源码及依赖库:
openssh:openssh-SNAP-20181203.tar.gz(Index of /openssh_snap/)
openssl:zlib-1.2.11.tar.gz(Index of /openssl)
zlib:openssl-1.0.1k.tar.gz(zlib Home Site)
编译openssl
若需openssh支持Openssl,还需进行Openssl的安装,否则跳过本小节。
解压并进入Openssl目录:
tar -zxvf openssl-1.0.2p.tar.gz
cd openssl-1.0.2p
配置环境:
export CC=arm-linux-gnueabi-gcc
配置Openssl:
./Configure
--prefix=/usr/local/openssl
--openssldir=/usr/lib/ssl
linux-generic32
no-asm
shared
编译并安装:
make
sudo make install
openssl将会被安装到/usr/local/openssl目录下。
编译zlib
解压并进入zlib目录:
tar -zxvf zlib-1.2.11.tar.gz
cd zlib-1.2.11
配置编译环境:
export CC=arm-linux-gnueabi-gcc
配置zlib:
./configure --prefix=/usr/local/zlib
编译并安装:
make
make install
编译openssh
解压并进入ssh目录:
tar -zxvf openssh-SNAP-20181203.tar.gz
cd openssh-SNAP-20181203
配置编译环境:
export CC=arm-linux-gnueabi-gcc
配置ssh:
./configure
--host=arm-oe-linux-gnueabi
--with-libs
--with-zlib=/usr/local/zlib
--with-ssl-dir=/usr/local/openssl
--disable-etc-default-login
编译:
make
安装:
将编译生成的scp、sftp、ssh、sshd、ssh-add、ssh-agent、ssh-keygen、ssh-keyscan 和ssh-rand-helper复制到目标板的/usr/local/bin目录;
将编译生成的sftp-server和ssh-keysign复制到目标板的/usr/local/libexec目录;
将编译生成的sshd_config、ssh_config 和moduli拷贝到目标板的/usr/local/etc目录;
修改/etc/passwd文件:
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin //新增一行
修改sshd_config文件:
#PermitRootLogin prohibit-password
PermitRootLogin yes
测试
运行sshd:
/usr/local/bin/sshd
使用ssh软件访问嵌入式系统,然后输入用户和密码,可远程登录嵌到入式linux系统,如下图:
![c778b3c61397faa7b031c3d8652e39d4.png](https://i-blog.csdnimg.cn/blog_migrate/88eeafaefaca5ae71e53e10cd28c2243.png)
使用WinSCP软件访问嵌入式系统,然后输入用户和密码,可远程访问文件系统:
![572c25653721711b67a5385acc5994a1.png](https://i-blog.csdnimg.cn/blog_migrate/a8245b4d290d8e3e778d754493f91b57.jpeg)