随着智能手机的计算能力和存储能力的提高,手机中将会存放越来越多的私有数据,这些数据的泄密可能造成严重后果。手机信息安全一直是我们的重点之一,对于一些重要的功能我们要求鉴权后才能使用,但这只能挡住初级的黑客,只能防君子不能防小人,所以我们希望把重要的数据进行加密后再保存。为此,今天花了一点时间去了解Linux 磁盘加密的方法。
方法一: 下载并编译util-linux
http://www.paranoiacs.org/~sluskyb/hacks/util-linux/losetup-combined.patch
http://ftp.cwi.nl/aeb/util-linux/util-linux-2.12.tar.gz
http://hydra.azilian.net/util-linux-2.12-kernel-2.6.patch
tar zxvf util-linux-2.12.tar.gz
cd util-linux-2.12
patch -p1 < ../losetup-combined.patch
patch -p1 < ../util-linux-2.12-kernel-2.6.patch
(如果有_syscall5之类编译错误,将它换成新的调用方式syscall)
make;make install
编译内核(已经支持cryptoloop则跳过此步)
make menuconfig
Device Drivers >Block Devices>Loopback device support
BLK_DEV_CRYPTOLOOP
加载模块
modprobe cryptoloop
(以及加密模块)
创建loop设备
dd if=/dev/zero of=~/cryptoloop.image bs=1M count=10
losetup -e aes-256 /dev/loop0 ~/cryptoloop.image
(提示输入密码)
创建文件系统并加载
mkfs.ext3 /dev/loop0
mkdir /mnt/crypto
mount -t ext3 ~/cryptoloop.image /mnt/crypto/ -oencryption=aes-256
(提示输入密码)
卸载
umount /mnt/crypto
losetup -d /dev/loop0
重新加载
losetup -e aes-256 /dev/loop0 ~/cryptoloop.image
mount -t ext3 ~/cryptoloop.image /mnt/crypto/ -oencryption=aes-256
cryptoloop就是一种transfer的实现。至于使用哪种transfer及transfer的参数(如密码),这可以通过LOOP_SET_STATUS64的ioctrl系统调用来完成(mount命令就是这样实现的)。
cryptoloop的缺点是只能针对loop设备,而且对日志型文件系统无效。
方法二:device-mapper crypto
下载并编译cryptsetup(已经有了就跳过) wget http://www.saout.de/misc/dm-crypt/cryptsetup-0.1.tar.bz2
cd cryptsetup-0.1
./configure;make;make install
编译内核(已经支持则跳过此步)
make menuconfig
Device Drivers > Multi-device support (RAID and LVM)
CONFIG_BLK_DEV_DM
CONFIG_DM_CRYPT
加载模块
modprobe dm-crypt
(以及加密模块)
创建loop设备
dd if=/dev/zero of=~/dm-crypt.image bs=1M count=10
losetup /dev/loop0 ~/dm-crypt.image
建立device-mapper
cryptsetup -y create dm-crypt /dev/loop0
(提示输入密码)
创建文件系统并加载
mkfs.ext3 /dev/mapper/dm-crypt
mount /dev/mapper/dm-crypt /mnt/crypto
卸载
umount /mnt/crypto/
cryptsetup remove dm-crypt
losetup -d /dev/loop0
重新加载
cryptsetup -y create dm-crypt /dev/loop0
mount /dev/mapper/dm-crypt /mnt/crypto
device-mapper crypto 的实现在drivers/md目录下,相对来说要复杂得多,没有来得及仔细阅读。
方法三:ecryptfs
下载并编译
http://people.redhat.com/~dhowells/keyutils/keyutils-1.2.tar.bz2
tar jxf keyutils-1.2.tar.bz2
cd keyutils-1.2
make;make install
tar jxf ecryptfs-20070306.tar.bz2
cd ecryptfs-20070306/ecryptfs-util
./configure;make;make install
编译内核
make menuconfig
File systems>Miscellaneous filesystems
CONFIG_ECRYPT_FS
加载模块
modprobe ecryptfs
(以及加密模块)
加载
mkdir /root/crypt
mkdir /mnt/crypt
mount -t ecryptfs /root/crypt /mnt/crypt
(提示输入密码和算法)
卸载
umount /mnt/crypt
重新加载
mount -t ecryptfs /root/crypt /mnt/crypt
(提示输入密码和算法)
看来ecryptfs的特点是能够对目录进行加密,而不必加密整个磁盘。直接读取原始目录中的文件,只能读到加密后的数据,要正确读取数据,只有先把该目录用ecryptfs文件系统格式加载到另外一个目录,之后才能读取。而在加载时要指定密码和加密算法,这就起到保密作用。如果加载时指定错误的密码或加密算法,仍然可以加载而不会出错,但读出的数据是无效的。
ecryptfs的代码在fs/ecryptfs目录下,只有比较新的kernel版本才有,我用的是linux-2.6.21。它的实现与前面两种方法不同,它完全是按文件系统的方式来实现的。
以上几种加密方法,在加载时都要输入密码,为了使用上的方便,可以与PAM+libpam-mount插件集成起来,用当前用户的密码作为加密的密码,这样就只需要在登录时输入一次就够了。
上一篇:没有了 下一篇:squid.conf文件的配置
·让SQL注入攻击危害最小化三大措施(10-18)
·黑客笔记:入侵骗子站xuehk.com全过程(10-07)
·Serv-U 7.2.0.1 拒绝服务漏洞的利用(stou con-1(10-06)
·Serv-U 7.2.0.1 远程覆盖文件漏洞的利用 Remote(10-06)
·如何编写Linux 2.6.x下内核级后门程序(09-30)
·Linux操作系统下防范黑客入侵的一些实用技巧(09-27)
·我们应该怎样判断风险的等级(09-27)
·终端服务3389的SHIFT后门自动扫描(09-15)
·一个linux提权用的技巧(09-15)
·Apache的prefork模式和worker模式的区别(09-04)
·MySQL优化 推荐(08-21)
·发现一个mstsc.exe在XP SP3上的变化(07-26)
·MySQL 双向数据同步解决方案(07-18)
·MSSQL Server服务器数据同步解决方案(07-18)
·访问控制Access Control专业术语详解(07-18)
·Rootkit的检测、清除、预防(05-29)
·七种方法修改网吧注册表[以破解下载为例](03-14)
·深入防火墙记录(03-14)
·如何清除局域网中的ARP病毒(03-14)
·提升网站程序开发安全的6大诀窍(03-14)
·Windows 2003服务器安全加固方案(03-14)
·Windows 2000系统加固应用指南(03-14)
·Windows 2003 单网卡实现VPN(03-14)
·感染Linux系统脚本程序的病毒技术介绍(03-14)
·Linux下DOM制作流程[嵌入式系统盘](03-14)
·加速动态网站之MySQL索引分析和优化(03-14)
·MySQL数据库配置技巧(03-14)
·注意防范局域网内入侵服务器(01-27)
·利用IP地址欺骗突破防火墙(01-27)
·IUSR_计算机名和IWAM_计算机名帐户的用户名和密(303)
·Linux下DOM制作流程[嵌入式系统盘](291)
·如何清除局域网中的ARP病毒(282)
·Windows 2003 单网卡实现VPN(254)
·开发Linux系统下的磁盘加密方法详解(247)
·访问控制Access Control专业术语详解(194)
·Windows 2003服务器安全加固方案(158)
·MySQL 双向数据同步解决方案(131)
·MySQL优化 推荐(119)
·squid.conf文件的配置(113)
·七种方法修改网吧注册表[以破解下载为例](94)
·黑客笔记:入侵骗子站xuehk.com全过程(94)
·拿webshell权限的45种方法(91)
·Windows 2000系统加固应用指南(90)
·Apache的prefork模式和worker模式的区别(87)
·IIS最小权限分配的批处理文件[服务器优化](86)
·注意防范局域网内入侵服务器(72)
·MSSQL Server服务器数据同步解决方案(71)
·终端服务3389的SHIFT后门自动扫描(54)
·利用IP地址欺骗突破防火墙(51)
·MySQL数据库配置技巧(49)
·Rootkit的检测、清除、预防(48)
·深入防火墙记录(46)
·如何用iptables实现NAT(45)
·常见的4种挂马方式(44)
·Linux操作系统下防范黑客入侵的一些实用技巧(44)
·骗黑客 伪装Linux设置假象加固系统安全(43)
·Linux系统管理员利器,重复劳动必备[图](43)
·提升网站程序开发安全的6大诀窍(43)

