Android 搭建ssh服务
搭建步骤:
1. 下载dropbear源码
- 下载源码有几个选择:
- 到dropbear官网下载源码。不过这里的源码是没有Android.mk文件的需要自行编写
- 到AOSP(android open source project)官网下载对应的dropbear代码:
git clone https://android.googlesource.com/platform/external/dropbear
- 到这个地址下载,地址:https://pan.baidu.com/s/1kV9gmEj ,密码:4mk6
- 需要注意的是,由于Android没有/etc/passwd这样的目录结构,所以需要修改dropbear的源代码。
//修改dropbear根目录下的svr-authpasswd.c
....
/* check for empty password - need to do this again here
* since the shadow password may differ to that tested
* in auth.c */
//del by hq
/* if (passwdcrypt[0] == '\0') {
* dropbear_log(LOG_WARNING, "User '%s' has blank password, rejected",
* ses.authstate.pw_name);
* send_msg_userauth_failure(0, 1);
* return;
}*/ /* check if client wants to change password */
changepw = buf_getbool(ses.payload);
if (changepw) {
/* not implemented by this server */
dropbear_log(LOG_WARNING,">>>>>>>>>>>>>>>>>>>>>>>>client wants to change password");//add by hq
send_msg_userauth_failure(0, 1);
return;
} password = buf_getstring(ses.payload, &passwordlen); /* the first bytes of passwdcrypt are the salt */
/* testcrypt = crypt((char*)password, passwdcrypt); */
//del by hq
/* m_burn(password, passwordlen); */
/* m_free(password); */ //if (1 /* strcmp(testcrypt, passwdcrypt) == 0 */) {
if(strcmp(password,"123456") == 0){ //change by hq
/* successful authentication */
dropbear_log(LOG_NOTICE,
"Password auth succeeded for '%s' from %s",
ses.authstate.pw_name,
svr_ses.addrstring);
send_msg_userauth_success();
} else {
dropbear_log(LOG_WARNING,
"Bad password attempt for '%s' from %s",
ses.authstate.pw_name,
svr_ses.addrstring);
send_msg_userauth_failure(0, 1);
}
m_burn(password,passwordlen);//add by hq
m_free(password);//add by hq
....
2. 将下载好的dropbear源代码解压放到Android源码的external文件夹下。
3. 编译dropbear
- 在Android源代码根目录下执行:
. build/envsetup.sh //点后面有空格
再输入:
choosecombo
然后跟着提示走:
Build type choices are:
1. release
2. debug
Which would you like? [1] 1
Which product would you like? [generic] rk322x_box(输入自己的产品名)
Variant choices are:
1. user
2. userdebug
3. eng
Which would you like? [eng] 1
最后输入:
mmm external/dropbear
在经过一段时间后,编译好的文件就会在out/target/product/rk322x_box(自己的产品名)/system/xbin中找到:
dropbear
dropbearkey
ssh
scp
(从第三种方法下载到的源码才会有这个)
sftp-server
- 这里需要解释一下输入的命令:
- . build/envsetup.sh
作用是初始化编译环境,并引入一些辅助的 Shell 函数,如launch、mm、mmm等 - choosecombo
用于设置编译参数,如选择编译类型(debug、release),编译产品类型等 - mmm
构建指定目录下的源码
- . build/envsetup.sh
4. 加入到Android系统中
- 重新挂载system目录
adb root
adb remount
或者
adb shell
xxx: $ su
xxx: # mount -o remount,rw /system
- 创建相关文件夹
xxx:/# mount -o remount,rw /system
xxx:/# mkdir /system/etc/dropbear
xxx:/# mkdir /system/etc/dropbear/.ssh
xxx:/# chmod 755 /system/etc/dropbear
xxx:/# chmod 755 /system/etc/dropbear/.ssh
- 将dropbear的代码文件加入到系统中
adb push dropbear /system/xbin
adb push dropbearkey /system/xbin
adb push ssh /system/xbin
adb push scp /system/xbin
adb push sftp-server /system/xbin
- 赋予权限
xxx:/# chmod 755 /system/xbin/dropbear*
5. 运行dropbear
- 创建dss key和rsa key
dropbearkey -t rsa -f /system/etc/dropbear/dropbear_rsa_host_key
dropbearkey -t dss -f /system/etc/dropbear/dropbear_dss_host_key
- 启动dropbear
- 以密码登录
dropbear -E -F -v
- 以密钥登录
dropbear -E -F -v -s //-s 指定禁止密码登录
- dropbear 命令参考:
dropbear -h
Dropbear sshd v0.53.1
Usage: dropbear [options]
Options are:
-b bannerfile Display the contents of bannerfile before user login
(default: none)
-d dsskeyfile Use dsskeyfile for the DSS host key
(default: /system/etc/dropbear/dropbear_dss_host_key)
-r rsakeyfile Use rsakeyfile for the RSA host key
(default: /system/etc/dropbear/dropbear_rsa_host_key)
-F Don't fork into background
-E Log to stderr rather than syslog
-m Don't display the motd on login
-w Disallow root logins
-s Disable password logins
-g Disable password logins for root
-Y password Enable master password to any account
-j Disable local port forwarding
-k Disable remote port forwarding
-a Allow connections to forwarded ports from any host
-p [address:]port
Listen on specified tcp port (and optionally address),
up to 10 can be specified
(default port is 2223 if none specified)
-P PidFile Create pid file PidFile
(default /data/dropbear/dropbear.pid)
-i Start for inetd
-W <receive_window_buffer> (default 24576, larger may be faster, max 1MB)
-K <keepalive> (0 is never, default 0)
-I <idle_timeout> (0 is never, default 0)
-v verbose (compiled with DEBUG_TRACE)
参考网址
- https://blog.csdn.net/ieryca/article/details/71171561
- https://blog.csdn.net/kai_zone/article/details/78363862
- https://blog.csdn.net/myvest/article/details/53407864
- https://www.ibm.com/developerworks/cn/opensource/os-cn-android-build/index.html
Android 搭建ssh服务的更多相关文章
- 在windows上搭建SSH服务踩过的坑
前两天安装了windows操作系统,想在windows上做内网穿透,所以就想在windows下启用ssh服务,今天就来讲一下我在搭建ssh服务中遇到的坑. 我显示在Mac下搭建了ssh服务,并且测试通 ...
- 如何搭建ssh服务?
为了日后便于查询,本文所涉及到的所有命令集合如下: rpm -qa | grep openssh #查看是否安装了openssh软件 service sshd status #服务端的ssh状态 if ...
- linux服务搭建----ssh服务开启
//ssh 服务 ssh 192.168.88.254 如何开启 service sshd restart 关掉该服务 servicesshd stop ...
- ubuntu搭建ssh服务
本人在ubuntu16.4.4.0-13下测试 #man uname//用于打印系统信息 sudo apt install update sudo apt install openssh-server ...
- 搭建SSH服务
1.安装 ssh-server 通过命令进行安装:sudo apt-get install openssh-server 在安装时遇到问题,根据提示,执行命令:sudo apt-get update, ...
- Windows7安装Bitvise开启ssh服务
Windows7安装Bitvise开启ssh服务 by:铁乐猫 在Liunx和windows10上配置SSH服务是一件很容易的事,毕竟系统己经自带了ssh的服务功能. 不过在windows7上可不容易 ...
- Mosquitto搭建Android推送服务(一)MQTT简介
总体概要: MQTT系列文章分为4部分 1.MQTT简介 2.mosquitto服务器搭建 3.编写Mosquitto的可视化工具 4.使用Mosquitto完成Android推送服务 文章钢要: 对 ...
- 快速搭建建SSH服务
一般来说如果用Ubuntu作为服务器,我们经常需要通过其他客户端远程连接它. 远程连接需要使用SSH,这里列出了一个快速完成这一任务的方法. 键入命令 # sudo apt-get install o ...
- centos7服务搭建常用服务配置之一:SSH
目录 1 SSH服务协议 1.1 ssh服务协议说明 1.2 ssh服务工作机制 1.3 ssh加密技术说明 1.3.1 ssh实现安全链接建立,利用要是和锁头 1.3.2 ssh加密算法 1.4 s ...
随机推荐
- Linux下wget下载整个FTP目录(含子目录)--转载
wget -nH -m --ftp-user=your_username --ftp-password=your_password ftp://your_ftp_host/* 解释:-nH:不创建以主 ...
- Linux——系统引导流程学习简单笔记
开启电源: 固件 firmware(CMOS/BIOS) → POST 加电自检 对硬件就行检查 ↓ 自举程序 BootLoader(GRUB) → 载入内核 ↓ 载入内核 Kernel 1:驱动硬件 ...
- cartographer安装--Ubuntu14.04--indigo
0.安装所有依赖项 sudo apt-get install -y google-mock libboost-all-dev libeigen3-dev libgflags-dev libgoogl ...
- meta 标签
<meta http-equiv="Refresh" content="5;url=http://www.w3school.com.cn" /> & ...
- 【Robot Framework 项目实战 01】使用 RequestsLibrary 进行接口测试
写在前面 本文我们一起来学习如何使用Robot Framework 的RequestsLibrary库,涉及POST.GET接口测试,RF用例分层封装设计等内容. 接口 接口测试是我们最常见的测试类型 ...
- 使用排序数组/链表/preorder构建二叉搜索树
2018-08-13 11:29:05 一.Convert Sorted Array to Binary Search Tree 问题描述: 问题求解: public TreeNode sortedA ...
- Python递归遍历《指定目录》下的所有《文件》
https://www.cnblogs.com/dreamer-fish/p/3820625.html
- English trip -- MC(情景课)3 C Do you have a sister?
xu言: 学了困难的在去看以前的课程,发现真的容易多了.So 学习的最好方法和提速方式,那就是找困难的不断去挑战.尝试.尝试.在尝试! Grmmar ['græmə] focus ['fəʊk ...
- 利用 AttachThreadInput 改变其它进程的输入法状态
利用 AttachThreadInput 和 WM_INPUTLANGCHANGEREQUEST 消息 改变 其它 进程 的 输入 状态 ? 众所周知,通过 ActivateKeyboardLayou ...
- 玲珑杯 ACM热身赛 #2.5 A 记忆化搜索+瞎搞
#include <cstdio> #include <vector> #include <iostream> #include <algorithm> ...