扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
随着智能手机的计算能力和存储能力的提高,手机中将会存放越来越多的私有数据,这些数据的泄密可能造成严重后果。手机信息安全一直是我们的重点之一,对于一些重要的功能我们要求鉴权后才能使用,但这只能挡住初级的黑客,只能防君子不能防小人,所以我们希望把重要的数据进行加密后再保存。为此,今天花了一点时间去了解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 cryptowget 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 |
下载并编译 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 (提示输入密码和算法) |
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
去集群 更超群——大容量网络演进之路
2019 IBM 中国论坛
H3C 2019 Navigate 领航者峰会
助推数据中心网络现代化转型 打造灵活可靠基础架构平台