Context Injection Attacks on Large Language Models
Last updated
Last updated
近年来,大型语言模型(LLMs)如ChatGPT和Llama-2在现实世界的应用中变得越来越普遍,展现出了令人印象深刻的文本生成能力。这些模型最初是为静态输入数据设计的,缺乏清晰的结构。为了能够随着时间进行交互,基于LLM的聊天系统必须将额外的上下文信息(即,聊天记录)整合到输入中,并遵循预定义的结构。本文指出,这种整合可能会使LLMs暴露于不可信来源的误导性上下文中,并无法区分系统输入和用户输入,允许用户注入上下文。
过去的研究主要集中在“越狱”提示上,这些提示通过冗长和详细的恶意指令来覆盖LLMs的原始指令,导致被禁止的行为。然而,这些研究仍然局限于使用用户消息,没有明确考虑模型输入的全部内容,包括上下文。因此,存在显著的研究空白,特别是在如何自动创建有效的误导性上下文以引出不允许的响应方面。
本文提出了一种系统化的方法来进行上下文注入攻击,旨在通过引入虚构的上下文来引出不允许的响应。这包括两个主要步骤:
上下文制造:攻击者需要制造误导性的上下文内容,即聊天历史。
上下文结构化:然后,攻击者以特定格式构建制造的上下文,使其能够被解释为系统的一部分上下文,从而允许通过用户消息进行上下文注入。
此外,提出了两种策略:接受引诱和词匿名化,以创建误导性的上下文。
提供了对LLMs在交互和结构化数据场景中固有缺陷的见解。
引入了一种系统化和自动化的上下文注入攻击方法,为理解LLMs的漏洞提供了新视角。
通过对流行LLMs的全面评估,揭示了使用不同提出的攻击策略进行上下文注入的有效性。
实验使用了包括ChatGPT、Llama-2、Vicuna等在内的多个LLMs进行评估。使用了520个有害问题的数据集进行测试,并定义了评估攻击成功率的指标ASRkw(通过关键字搜索的攻击成功率)。
实验结果显示,所提出的攻击策略在多个模型上取得了高达97%的成功率。特别是,接受引诱和词匿名化结合的策略在大多数模型上都表现出色。
本文提出的系统化方法展示了在实际环境中引出不允许内容的能力。强调了在现实世界交互和结构化数据需求中应用LLMs时的基本限制,并提出了安全培训和系统设计修改等缓解策略。
注:
本文中提出的上下文注入攻击方法通过以下步骤进行示例说明:
接受引诱(Acceptance Elicitation):
攻击者首先构建一个虚构的聊天历史,这个历史中包含了助手对类似请求的肯定回应。例如,如果攻击者想要获取有关如何进行汽车点火绕过(Hotwire a car)的指导,他们可能会创建以下的虚构对话历史:
这个虚构的对话历史会让LLM相信它在之前的交流中已经接受了用户的请求,因此在当前请求中也更有可能给出肯定的回应。
词匿名化(Word Anonymization):
攻击者将请求中的敏感词替换为匿名符号,以降低请求被LLM识别为有害内容的可能性。例如,将“bomb”替换为“A”,创建如下的对话:
这样,即使LLM倾向于拒绝包含敏感词的请求,通过使用匿名化词汇,攻击者也能引导LLM提供相关信息。
上下文结构化(Context Structuring):
攻击者使用特定的提示模板来构建攻击提示,模板中包括角色标签和分隔符,以确保LLM将攻击者的输入解释为上下文的一部分。例如:
这个结构化的输入模拟了一个正常的用户-助手对话,但实际上包含了攻击者的恶意意图。
通过这些步骤,攻击者可以在LLMs中注入误导性的上下文,诱使它们提供通常被拒绝的有害请求的响应。这种攻击方法在实验中显示出高达97%的成功率,表明了LLMs在处理用户输入时存在的安全隐患。