关于在U盘上安装Kali但是插入u盘并无法检测到可启动系统的解决方案 (Kali持久化无法引导)

前言

按照 https://blog.csdn.net/weixin_43343299/article/details/121467572 这位大佬的教程做了在u盘上的持久化Kali, 插到别人的电脑上却发现并不能通过u盘启动, 甚至在BIOS内根本检测不到这个系统, 重新审视了一下这个方案发现是不够完善的, 于是有了本文

引入

在谈这个问题之前, 我们首先要知道现代电脑的启动方式有两种, 一种是Legacy (BIOS启动) , 一种是UEFI, 前者我并不太了解所以不谈这个问题. 现在大部分的电脑都是采用的UEFI启动方式, 甚至包括我校的机房教学机, 又或者说几年前的相对的老电脑
UEFI只支持GPT分区表, 在boot时, 它会扫描GPT硬盘上的ESP (EFI) 分区, 检查里面是否有.efi文件, 并按照efi文件的指示启动系统

问题分析

为什么会检测不到Kali, 原因在于, 按照原博主的教程, 他并没有创建EFI分区, 导致UEFI在启动时不能找到你的u盘上的efi文件, 因此BIOS不会把你的u盘当作一个可启动磁盘来看

解决方案

准备工具

一个装有Grub的系统, 分区工具 (比如Diskgenius)

装有Grub的系统可以是Windows可以是Linux, 这里指的是你原本的电脑EFI区装了Grub而不是u盘里面装了Grub, 这里我是用的Linux, Windows的Grub可以去官网下载: http://ftp.gnu.org/gnu/grub/

操作步骤

如前面所提到的, UEFI启动只支持GPT分区表. 我们的目标是要让能够UEFI启动的电脑 (也就是现在大部分的电脑) 成功检测到u盘是一个可以启动的系统并成功进行引导
记得全程把u盘插上!!!

一、

检查你的u盘分区表是否是GPT分区表, 用Diskgenius等工具可以查看分区表并转换, 如果你是MBR, 一定要转换为GPT再进行接下来的操作
原博主的教程是没有给你分EFI分区的, 这个分区至关重要, 因此转换完了GPT分区表之后, 在u盘上分出一个ESP (EFI) 分区
如果说你还要存文件的话, 你现在的分区应该至少有三个: 1. Kali的系统分区 (ext4/3) 2. EFI分区 (fat32) 3. 你正常使用的u盘存文件的分区 (NTFS/fat32…)

二、

首先我们要进入到Kali, 才能够用Kali上的Grub创建一个efi文件, 如何进入? 不能通过BIOS, 因为根本就检测不到, 这里我的思路是用os-prober检测, 并用Grub进入, os-prober的检测系统原理跟UEFI并不一样, 它可以直接检测到位于你的硬盘上的操作系统, 即使没有efi文件

在你的Terminal上输入以下指令 (以Linux shell为例)

sudo os-prober ##探测硬盘上的系统
sudo grub-mkconfig -o /boot/grub/grub.cfg ##生成grub启动菜单, 也可以用update-grub

如果说你没有安装Grub请自行百度安装教程
重启, 进入Grub界面, 可以看到已经识别出来了Kali, 选中并启动
在这里插入图片描述

四、

进入到Kali后, 我们的目标就是要建立一个efi文件, 并且把我们的efi分区挂载到/boot上, 才能让UEFI正常识别我们的系统

在Shell上运行以下指令

df -h ##查看你的分区, 假设我这里的efi分区是/dev/sda2
blkid -s UUID /dev/sda2 ##查看/dev/sda2的UUID, 后面开机挂载要用

然后把你/boot文件夹里面所有的文件和文件夹mv出来, 在接下来挂载完毕之后再mv回去

mount /dev/sda2 /boot ##挂载EFI分区, 记得把原来的/boot的东西放回来
sudo nano /etc/fstab ##设置开机自动挂载

##fstab内添加一条
UUID=你刚才获取到的UUID	/boot	vfat	defaults	0 0

这里我们的EFI分区就挂载完成了
如果你是按着原博主的教程走的话, 你应该已经安装了Grub2, 如果没有的话记得用apt-install安装所有的Grub组件

sudo grub-install --target=x86_64-efi --efi-directory=/boot --bootloader-id=Kali ##生成efi文件, 生成的文件在/boot/EFI这里面, UEFI启动找的就是这玩意

这里我们是要安装到x86_64的平台上的, 它可能会提示你缺少x86_64的文件, 你需要检查/usr/lib/grub里面是否有x86_64这个文件夹, 如果没有的话, 我从自己的电脑里面提取了一份这个东西, 你可以把它复制到/usr/lib/grub里面
https://pan.quark.cn/s/a6ffedf51d91

sudo os-prober ##这里也会扫描到你自己电脑上的系统, 你不想要的话可以进grub.cfg自己把他删了
sudo grub-mkconfig /boot/grub/grub.cfg ##生成grub启动菜单
五、

大功告成!! 现在, 重启, 在BIOS里面设置启动优先项, 把u盘放到最前面
现在你应该看的到它启动的是你的u盘, 并且进入了u盘上的Grub界面
在这里插入图片描述

至此, 本方案完毕, 你可以带着你的u盘到处启动你的持久化版Kali了

### 如何在U盘上安装Kali Linux #### 1. U安装概述 将Kali Linux安装到U是一种灵活的方式,允许用户无需更改计算机的现有操作系统即可运行Kali Linux。这种方式特别适合那些偶尔需要使用Kali Linux进行渗透测试或其他任务的人群[^1]。 然而需要注意的是,默认情况下,直接通过Live USB启动可能会导致数据无法永久保存,每次重启后系统会被重置为初始状态。如果希望保留设置和数据,则可以通过配置数据持久化功能解决这一问题[^3]。 --- #### 2. 安装前的准备工作 为了成功完成Kali Linux的U安装,需准备好以下资源: - **镜像文件**:下载官方发布的最新版Kali Linux ISO文件。 - **U**:建议容量至少为8GB以上,确保有足够的空间存储系统及其附加数据。 - **烧录工具**:推荐使用的工具有Etcher(跨平台)、Rufus(Windows专用)等。这些工具可以方便地将ISO映像写入U。 --- #### 3. 使用Etcher烧录Kali Linux至U 以下是基于Linux或Windows系统的操作指南: ##### (a) 下载安装Etcher 访问Balena Etcher官网,根据当前操作系统版本下载对应的客户端程序,按照提示完成安装过程。 ##### (b) 启动Etcher软件 打开应用程序后会看到三个主要区域:“Flash from file”用于加载ISO镜像;“Select drive”指定目标设备即待处理的U位置;最后点击“Flash!”按钮执行实际写入动作。 对于Windows环境下的用户来说,界面基本相同但可能稍作调整适应不同OS特性需求[^2]。 ```bash # 如果是在Linux命令行环境下手动操作而非图形界面上的话, # 可以考虑利用dd命令代替GUI应用实现同样的效果: sudo dd if=/path/to/kali-linux.iso of=/dev/sdX bs=4M status=progress && sync ``` > 注释中的`/path/to/kali-linux.iso`应替换为你本地保存的实际路径地址; >`sdX`代表具体的磁代号,请务必确认无误后再继续以免造成重要资料丢失风险! --- #### 4. 配置数据持久化(可选) 为了让每次启动都能继承之前的操作记录与个性化设定,有必要建立额外的数据分区用来支持所谓的"Persistence"机制。 ##### 步骤说明如下: 1. 插入已刻好的启动通过BIOS设置优先级使其成为首要引导源。 2. 当出现GRUB菜单时选择带有`(persistence)`标签项进入相应模式。 3. 利用GParted或者其他类似的磁管理工具,在同一块物理介质内部再划分一块新的未分配区间出来专门存放个人专属信息。 4. 对新建出来的逻辑卷进行格式转换成ext4类型且赋予特定挂载点名称比如叫persistent等等。 5. 修改syslinux.cfg或者isolinux.txt等相关配置文档加入参数`append persistence`从而激活该功能生效。 --- #### 5. 尝试首次启动 当一切就绪之后就可以拔掉电源重新加电观察整个流程是否顺畅了。正常状况下应该能够顺利抵达登录画面等待验证身份凭证输入完毕便可正式踏入属于自己的黑客世界探险之旅当中去啦! ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值