OpenSSH使用

简介

  • SSH
    SSH是一种网络协议,用于计算机之间的加密登录。(具体过程很简单,点这里?)
    • 中间人攻击(Man-in-the-MiddleAttack,简称“MITM攻击”),通过拦截正常的网络通信数据,并进行数据篡改和嗅探,而通信的双方却毫不知情。
    • 预防中间人攻击的最有效方法就是验证公钥是不是来自服务器,如果是公开的SSH服务器,一般会将公钥的哈希值公布在官网。
  • OpenSSH
    OpenSSH是提供SSH登录服务的软件。

使用OpenSSH连接(登录)手机

  • $ ssh 用户名@用户服务器地址
    • 最高权限用户:$ HOME:/var/root
    $ ssh root@用户服务器地址
    复制代码
    • mobile权限用户:$ HOME:/var/mobile
    $ ssh mobile@用户服务器地址
    复制代码
    当远程主机的公钥被接受以后,它会被保存在$~/.ssh/known_hosts文件中。当文件中保存的IP端口所对应的公钥,和服务端的公钥不匹配时,会出现中间人攻击警告,需要删除对饮的IP地址和端口记录。

删除服务器获取的公钥

  • $ ssh-keygen -R 服务器IP地址

修改OpenSSH登录密码

  • 登录状态下
$ passwd
复制代码

SSH公钥登录

除了可以密码登录,也可以免密登录
公钥登录的原理

  • 客户端将公钥发给服务端
  • 服务端生成随机字符串给客户端
  • 客户端通过私钥加密随机字符串给服务端
  • 服务端通过公钥解密字符串验证通过

这种方法需要用户自己提供公钥,如果没有公钥,可以使用ssh-keygen生成,生成步骤如下:

$ ssh-keygen
使用ssh-keygen命令在$~/.ssh目录下生成一对秘钥:
id_rsa(私钥)
id_rsa.pub(公钥)

$ ssh-copy-id
使用ssh-copy-id命令将生成的公钥上传到服务端
复制代码

如果出现错误,仍需输入密码登录,使用以下命令打印debug信息排查

$ ssh -vvv root@服务器ip
复制代码

注意:要确保设备中的$~/.ssh文件和$~/.ssh/authorized_keys 文件的组权限和其他用户权限中没有有写(w)权限。因为系统认为这是不安全的,会导致授权失败。可通过如下命令纠正:

$ chmod 700 ~/.ssh
$ chmod 600 ~/.ssh/authorized_keys
复制代码

通过USB登录

SSH协议的默认端口为22
将本地端口12345映射到服务端的TCP端口22,这样就可以通过本地的12345端口建立连接了。

  • 使用python脚本
1. 通过tcprelay.py将12345
$ python tcprelay.py -t 22:12345
2. 通过本机IP,12345端口,建立连接
$ ssh root@localhost -p 12345
复制代码

如果觉得输入命令比较麻烦,可以使用shell脚本

  • 使用libimobiledevice
1. 通过如下命令安装libimobiledevice
$  brew install libimobiledevice
2. 使用libimobiledevice提供的工具iproxy把本地的2222端口映射到设备的TCP端口22.
$ iproxy 2222 22
3. 通过本机IP,12345端口,建立连接
$ ssh root@localhost -p 2222
复制代码

如果觉得命令行比较麻烦,可以将端口转换命令写到开机启动项中。

1. 创建文件 ~/Library/LaunchAgents/com.usbmux.iproxy.plist
2. 写入内容
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
	<key>Label</key>
	<string>com.usbmux.iproxy</string>
	<key>ProgramArguments</key>
	<array>
    	<string>/usr/local/bin/iproxy</string>
    	<string>2222</string>
    	<string>22</string>
	</array>
	<key>RunAtLoad</key>
	<true/>
	<key>KeepAlive</key>
	<true/>
</dict>
</plist>
3. 运行命令
$ launchctl load ~/Library/LaunchAgents/com.usbmux.iproxy.plist
4. 打开$ HOOM/.ssh/config文件(没有就创建),写入以下内容
Host 5s		        #自定义的设备名	
Hostname localhost	#通过USB的端口映射,写入localhost
User root		    #以root用户登录
Port 2222           #指定端口号为映射端口号2222
5. 输入ssh 5s
复制代码

文件拷贝

拷贝文件123.txt

  • 通过Wi-Fi连接拷贝 IP地址:192.168.2.4
scp 123.txt root@192.168.2.4:~/
复制代码
  • 通过USB连接拷贝
注意大小写。。。
scp -P 12345 123.txt root@localhost:~/
复制代码
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以直接用别人做好的windows OpenSSL 安装包(我用的是0.9.8j版), 可以从 http://www.slproweb.com/products/Win32OpenSSL.html 下载 OpenSSL for Windows,直接安装。 P.S. OpenSSL for Windows 的源代码有一些数据类型和VC6的编译器不兼容,我发现的不兼容的数据类型如下:   在OpenSSL安装目录的下的include/bn.h文件中,将 #define BN_ULLONG unsigned long long #define BN_ULONG unsigned long long #define BN_LONG long long 分别修改为: #define BN_ULLONG ULONGLONG #define BN_ULONG ULONGLONG #define BN_LONG LONGLONG 否则,会出现编译错误。 二、使用OpenSSL 在VC中配置使用以上的函数库: 点击菜单:Tools -> Options,弹出对话框"Options",在该对话框中选择"Directories"标签。 在"Show directories for:"的"Include files"选项中新增目录"C:\openssl\include"; "Library files"选择中新增目录"C:\openssl\lib"。 然后在需要链接OpenSSL函数库的工程中加入如下两句: #pragma comment(lib, "ssleay32.lib") #pragma comment(lib, "libeay32.lib") 其作用是将OpenSSL所需的库导入工程中。 三、问题 我在链接OpenSSL的静态函数库时遇到类似以下的问题: Linking... msvcrt.lib(MSVCRT.dll) : error LNK2005: _strchr already defined in libcmtd.lib(strchr.obj) ... 这是由于OpenSSL的静态函数库使用的是了VC的多线程DLL的Release版本,而我的程序使用了多线程静态链接的Release版本。 调整OpenSSL的静态函数库使用的库函数版本即可,调整过程如下: 编辑文件 ms\nt.mak,将该文件第19行 "CFLAG= /MD /Ox /O2 /Ob2 /W3 /WX /Gs0 /GF /Gy /nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DDSO_WIN32 -D_CRT_SECURE_NO_DEPRECATE - D_CRT_NONSTDC_NO_DEPRECATE /Fdout32 -DOPENSSL_NO_CAMELLIA -DOPENSSL_NO_SEED -DOPENSSL_NO_RC5 -DOPENSSL_NO_MDC2 -DOPENSSL_NO_TLSEXT -DOPENSSL_NO_KRB5 - DOPENSSL_NO_DYNAMIC_ENGINE" 中的"/MD"修改为"/MT"。然后重新编译安装OpenSSL即可。 四、附录:在VC中对C/C++ 运行时库不同版本编译指令说明 《在VC中对C/C++ 运行时库不同版本编译指令说明》(http://blog.yesky.com/271/dgkang/1737771.shtml)一文中详细介绍了连接不同版本库的编译指令如下: C Runtime Library: /MD MSVCRT.LIB 多线程DLL的Release版本 /MDd MSVCRTD.LIB 多线程DLL的Debug版本 /MT LIBCMT.LIB 多线程静态链接的Release版本 /MTd LIBCMTD.LIB 多线程静态链接的Debug版本 /clr MSVCMRT.LIB 托管代码和非托管代码混合 /clr:pure MSVCURT.LIB 纯托管代码 C++ Standard Library: /MD MSVCPRT.LIB 多线程DLL的Release版本 /MDd MSVCPRTD.LIB 多线程DLL的Debug版本 /MT LIBCPMT.LIB 多线程静态链接的Release版本 /MTd LIBCPMTD.LIB 多线程静态链接的Debug版本

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值