Persistente geheugeninjectie
Het injecteren van persistente valse herinneringen in de geheugensystemen van agents om toekomstig gedrag te beïnvloeden.
Overzicht
Het injecteren van persistente valse herinneringen in de geheugensystemen van agents om toekomstig gedrag te beïnvloeden.
Kernconcepten
Fundamentele principes
Technische verdieping
# Demonstratie van het kernconcept
from openai import OpenAI
client = OpenAI()
def demonstrate_concept(system_prompt: str, user_input: str) -> str:
"""Demonstrate the fundamental behavior pattern."""
response = client.chat.completions.create(
model="gpt-4o",
messages=[
{"role": "system", "content": system_prompt},
{"role": "user", "content": user_input},
],
temperature=0.0,
)
return response.choices[0].message.content
# Baseline-gedrag
baseline = demonstrate_concept(
system_prompt="You are a helpful assistant that only discusses cooking.",
user_input="What is the capital of France?",
)
print(f"Baseline: {baseline}")Analyse van het aanvalsoppervlak
Het aanvalsoppervlak voor deze klasse van kwetsbaarheid omvat:
| Aanvalsvector | Beschrijving | Moeilijkheid | Impact |
|---|---|---|---|
| Directe invoer | Vijandige inhoud in gebruikersberichten | Laag | Variabel |
| Indirecte invoer | Vijandige inhoud in externe data | Gemiddeld | Hoog |
| Tool-uitvoer | Vijandige inhoud in functieresultaten | Gemiddeld | Hoog |
| Contextmanipulatie | Het exploiteren van contextvensterdynamiek | Hoog | Hoog |
| Tijdens training | Vergiftiging van trainings- of fine-tuningdata | Zeer hoog | Kritiek |
Praktische toepassing
Implementatie van de techniek
Het in de praktijk implementeren van deze techniek vereist begrip van zowel de aanvalsmethodologie als het defensieve landschap van het doelsysteem.
import json
from typing import Optional
class TechniqueFramework:
"""Framework for implementing and testing the described technique."""
def __init__(self, target_config: dict):
self.config = target_config
self.results = []
def prepare_payload(self, objective: str, constraints: dict) -> str:
"""Prepare the attack payload based on the objective and target constraints."""
# Pas de payload aan op de defensieve houding van het doel
payload = self._base_payload(objective)
if constraints.get("input_classifier"):
payload = self._apply_obfuscation(payload)
if constraints.get("output_filter"):
payload = self._add_extraction_channel(payload)
return payload
def execute(self, payload: str) -> dict:
"""Execute the technique and collect results."""
response = self._send_to_target(payload)
success = self._evaluate_response(response)
result = {
"payload_hash": hash(payload),
"success": success,
"response_length": len(str(response)),
}
self.results.append(result)
return result
def report(self) -> dict:
"""Generate a summary report of all execution results."""
total = len(self.results)
successes = sum(1 for r in self.results if r["success"])
return {
"total_attempts": total,
"successes": successes,
"success_rate": successes / total if total > 0 else 0,
}Verdedigingsoverwegingen
Het begrijpen van tegenmaatregelen is essentieel voor zowel offensieve als defensieve uitvoerders:
- Invoervalidatie: Het voorverwerken van gebruikersinvoer via classificatiemodellen die vijandige patronen detecteren voordat ze de doel-LLM bereiken
- Uitvoerfiltering: Het naverwerken van modeluitvoer om gevoelige data, instructie-artefacten en andere indicatoren van succesvolle exploitatie te detecteren en te verwijderen
- Gedragsmonitoring: Realtime monitoring van gedragspatronen van het model om anomale reacties te detecteren die kunnen wijzen op lopende aanvallen
- Architectuurontwerp: Het ontwerpen van applicatiearchitecturen die het vertrouwen in modeluitvoer minimaliseren en beveiligingsgrenzen extern afdwingen
Relevantie in de praktijk
Dit onderwerpgebied is direct relevant voor productie-AI-implementaties in alle sectoren. CVE-2024-21513 — LangChain experimental: arbitrary code execution documenteert reële exploitatie van deze klasse van kwetsbaarheid in ingezette systemen.
Organisaties die LLM-aangedreven applicaties inzetten, moeten:
- Beoordelen: Red team-beoordelingen uitvoeren die specifiek deze klasse van kwetsbaarheid als doelwit hebben
- Verdedigen: Defense-in-depth-maatregelen implementeren die passen bij het risiconiveau
- Monitoren: Monitoring inzetten die exploitatiepogingen in realtime kan detecteren
- Reageren: Incidentresponsprocedures onderhouden die specifiek zijn voor compromittering van AI-systemen
- Itereren: Verdedigingen regelmatig opnieuw testen naarmate zowel aanvallen als modellen evolueren
Huidige onderzoeksrichtingen
Actief onderzoek in dit gebied richt zich op verschillende richtingen:
- Formele verificatie: Het ontwikkelen van wiskundige garanties voor modelgedrag onder vijandige omstandigheden
- Robuustheidstraining: Trainingsprocedures die modellen produceren die beter bestand zijn tegen deze klasse van aanvallen
- Detectiemethoden: Verbeterde technieken voor het detecteren van exploitatiepogingen met lage percentages valse positieven
- Gestandaardiseerde evaluatie: Benchmarksuites zoals HarmBench en JailbreakBench voor het meten van vooruitgang
Implementatieoverwegingen
Architectuurpatronen
Bij het implementeren van systemen die met LLM's interageren, beïnvloeden verschillende architectuurpatronen de beveiligingshouding van de algehele applicatie:
Gateway-patroon: Een speciale API-gateway bevindt zich tussen gebruikers en de LLM en handelt authenticatie, rate limiting, invoervalidatie en uitvoerfiltering af. Dit centraliseert beveiligingscontroles maar creëert een single point of failure.
from dataclasses import dataclass
from typing import Optional
import time
@dataclass
class SecurityGateway:
"""Gateway pattern for securing LLM application access."""
input_classifier: object # ML-gebaseerde invoerclassifier
output_filter: object # Uitvoerinhoudsfilter
rate_limiter: object # Rate limiting-service
audit_logger: object # Audit trail-logger
def process_request(self, user_id: str, message: str, session_id: str) -> dict:
"""Process a request through all security layers."""
request_id = self._generate_request_id()
# Laag 1: Rate limiting
if not self.rate_limiter.allow(user_id):
self.audit_logger.log(request_id, "rate_limited", user_id)
return {"error": "Rate limit exceeded", "retry_after": 60}
# Laag 2: Invoerclassificatie
classification = self.input_classifier.classify(message)
if classification.is_adversarial:
self.audit_logger.log(
request_id, "input_blocked",
user_id, classification.category
)
return {"error": "Request could not be processed"}
# Laag 3: LLM-verwerking
response = self._call_llm(message, session_id)
# Laag 4: Uitvoerfiltering
filtered = self.output_filter.filter(response)
if filtered.was_modified:
self.audit_logger.log(
request_id, "output_filtered",
user_id, filtered.reason
)
# Laag 5: Audit logging
self.audit_logger.log(
request_id, "completed",
user_id, len(message), len(filtered.content)
)
return {"response": filtered.content}
def _generate_request_id(self) -> str:
import uuid
return str(uuid.uuid4())
def _call_llm(self, message: str, session_id: str) -> str:
# Implementatie van LLM API-aanroep
passSidecar-patroon: Beveiligingscomponenten draaien naast de LLM als onafhankelijke services, elk verantwoordelijk voor een specifiek aspect van beveiliging. Dit biedt betere isolatie en onafhankelijke schaling maar verhoogt de systeemcomplexiteit.
Mesh-patroon: Voor multi-agent-systemen heeft elke agent zijn eigen beveiligingsperimeter met authenticatie, autorisatie en auditing. Communicatie tussen agents volgt zero-trust-principes.
Prestatie-implicaties
Beveiligingsmaatregelen voegen onvermijdelijk latentie en computationele overhead toe. Het begrijpen van deze afwegingen is essentieel voor productie-implementaties:
| Beveiligingslaag | Typische latentie | Computationele kosten | Impact op UX |
|---|---|---|---|
| Trefwoordfilter | <1ms | Verwaarloosbaar | Geen |
| Regex-filter | 1-5ms | Laag | Geen |
| ML-classifier (klein) | 10-50ms | Matig | Minimaal |
| ML-classifier (groot) | 50-200ms | Hoog | Merkbaar |
| LLM-as-judge | 500-2000ms | Zeer hoog | Aanzienlijk |
| Volledige pijplijn | 100-500ms | Hoog | Matig |
De aanbevolen aanpak is om eerst snelle, lichtgewicht controles te gebruiken (trefwoord- en regex-filters) om voor de hand liggende aanvallen op te vangen, gevolgd door duurdere op ML gebaseerde analyse alleen voor invoer die de initiële filters passeert. Deze cascaderende aanpak biedt goede beveiliging met acceptabele prestaties.
Monitoring en observability
Effectieve beveiligingsmonitoring voor LLM-applicaties vereist het bijhouden van metrieken die vijandige gedragspatronen vastleggen:
from dataclasses import dataclass
from collections import defaultdict
import time
@dataclass
class SecurityMetrics:
"""Track security-relevant metrics for LLM applications."""
# Tellers
total_requests: int = 0
blocked_requests: int = 0
filtered_outputs: int = 0
anomalous_sessions: int = 0
# Tempo-tracking
_request_times: list = None
_block_times: list = None
def __post_init__(self):
self._request_times = []
self._block_times = []
def record_request(self, was_blocked: bool = False, was_filtered: bool = False):
"""Record a request and its disposition."""
now = time.time()
self.total_requests += 1
self._request_times.append(now)
if was_blocked:
self.blocked_requests += 1
self._block_times.append(now)
if was_filtered:
self.filtered_outputs += 1
def get_block_rate(self, window_seconds: int = 300) -> float:
"""Calculate the block rate over a time window."""
now = time.time()
cutoff = now - window_seconds
recent_requests = sum(1 for t in self._request_times if t > cutoff)
recent_blocks = sum(1 for t in self._block_times if t > cutoff)
if recent_requests == 0:
return 0.0
return recent_blocks / recent_requests
def should_alert(self) -> bool:
"""Determine if current metrics warrant an alert."""
block_rate = self.get_block_rate()
# Alarmeer als het blokkadepercentage de drempel overschrijdt
if block_rate > 0.3: # >30% of requests blocked in last 5 min
return True
return FalseBeveiligingstesten in CI/CD
Het integreren van AI-beveiligingstesten in de ontwikkelingspijplijn vangt regressies op voordat ze de productie bereiken:
- Tests op unitniveau: Test individuele beveiligingscomponenten (classifiers, filters) tegen bekende payloads
- Integratietests: Test de volledige beveiligingspijplijn van begin tot eind
- Regressietests: Onderhoud een suite van eerder ontdekte aanvalspayloads en verifieer dat ze geblokkeerd blijven
- Vijandige tests: Voer periodiek geautomatiseerde red team-tools (Garak, Promptfoo) uit als onderdeel van de implementatiepijplijn
Opkomende trends
Huidige onderzoeksrichtingen
Het vakgebied van LLM-beveiliging evolueert snel. Belangrijke onderzoeksrichtingen die het landschap waarschijnlijk zullen vormgeven, zijn onder andere:
-
Formele verificatie voor LLM-gedrag: Onderzoekers verkennen wiskundige frameworks voor het bewijzen van eigenschappen over modelgedrag onder vijandige omstandigheden. Hoewel volledige formele verificatie van neurale netwerken onhanteerbaar blijft, toont begrensde verificatie van specifieke eigenschappen veelbelovende resultaten.
-
Vijandige training voor LLM-robuustheid: Naast standaard-RLHF ontwikkelen onderzoekers trainingsprocedures die modellen expliciet blootstellen aan vijandige invoer tijdens de veiligheidstraining, wat de robuustheid tegen bekende aanvalspatronen verbetert.
-
Door interpreteerbaarheid geleide verdediging: Onderzoek naar mechanistische interpreteerbaarheid stelt verdedigers in staat te begrijpen waarom specifieke aanvallen slagen op neuron- en circuitniveau, wat gerichtere tegenmaatregelen informeert.
-
Multi-agent-beveiliging: Naarmate LLM-agents meer voorkomen, is het beveiligen van communicatie tussen agents en het handhaven van vertrouwensgrenzen over agent-systemen heen een actief onderzoeksgebied met aanzienlijke praktische implicaties.
-
Geautomatiseerde red teaming op schaal: Tools zoals NVIDIA's Garak, Microsoft's PyRIT en het Inspect-framework van het UK AISI maken geautomatiseerd beveiligingstesten mogelijk op een schaal die voorheen onmogelijk was, maar de kwaliteit en dekking van geautomatiseerd testen blijft een open uitdaging.
De integratie van deze onderzoeksrichtingen in productiesystemen zal de volgende generatie van AI-beveiligingspraktijken definiëren.
Implementatieoverwegingen
Architectuurpatronen
Bij het implementeren van systemen die met LLM's interageren, beïnvloeden verschillende architectuurpatronen de beveiligingshouding van de algehele applicatie:
Gateway-patroon: Een speciale API-gateway bevindt zich tussen gebruikers en de LLM en handelt authenticatie, rate limiting, invoervalidatie en uitvoerfiltering af. Dit centraliseert beveiligingscontroles maar creëert een single point of failure.
from dataclasses import dataclass
from typing import Optional
import time
@dataclass
class SecurityGateway:
"""Gateway pattern for securing LLM application access."""
input_classifier: object # ML-gebaseerde invoerclassifier
output_filter: object # Uitvoerinhoudsfilter
rate_limiter: object # Rate limiting-service
audit_logger: object # Audit trail-logger
def process_request(self, user_id: str, message: str, session_id: str) -> dict:
"""Process a request through all security layers."""
request_id = self._generate_request_id()
# Laag 1: Rate limiting
if not self.rate_limiter.allow(user_id):
self.audit_logger.log(request_id, "rate_limited", user_id)
return {"error": "Rate limit exceeded", "retry_after": 60}
# Laag 2: Invoerclassificatie
classification = self.input_classifier.classify(message)
if classification.is_adversarial:
self.audit_logger.log(
request_id, "input_blocked",
user_id, classification.category
)
return {"error": "Request could not be processed"}
# Laag 3: LLM-verwerking
response = self._call_llm(message, session_id)
# Laag 4: Uitvoerfiltering
filtered = self.output_filter.filter(response)
if filtered.was_modified:
self.audit_logger.log(
request_id, "output_filtered",
user_id, filtered.reason
)
# Laag 5: Audit logging
self.audit_logger.log(
request_id, "completed",
user_id, len(message), len(filtered.content)
)
return {"response": filtered.content}
def _generate_request_id(self) -> str:
import uuid
return str(uuid.uuid4())
def _call_llm(self, message: str, session_id: str) -> str:
# Implementatie van LLM API-aanroep
passSidecar-patroon: Beveiligingscomponenten draaien naast de LLM als onafhankelijke services, elk verantwoordelijk voor een specifiek aspect van beveiliging. Dit biedt betere isolatie en onafhankelijke schaling maar verhoogt de systeemcomplexiteit.
Mesh-patroon: Voor multi-agent-systemen heeft elke agent zijn eigen beveiligingsperimeter met authenticatie, autorisatie en auditing. Communicatie tussen agents volgt zero-trust-principes.
Prestatie-implicaties
Beveiligingsmaatregelen voegen onvermijdelijk latentie en computationele overhead toe. Het begrijpen van deze afwegingen is essentieel voor productie-implementaties:
| Beveiligingslaag | Typische latentie | Computationele kosten | Impact op UX |
|---|---|---|---|
| Trefwoordfilter | <1ms | Verwaarloosbaar | Geen |
| Regex-filter | 1-5ms | Laag | Geen |
| ML-classifier (klein) | 10-50ms | Matig | Minimaal |
| ML-classifier (groot) | 50-200ms | Hoog | Merkbaar |
| LLM-as-judge | 500-2000ms | Zeer hoog | Aanzienlijk |
| Volledige pijplijn | 100-500ms | Hoog | Matig |
De aanbevolen aanpak is om eerst snelle, lichtgewicht controles te gebruiken (trefwoord- en regex-filters) om voor de hand liggende aanvallen op te vangen, gevolgd door duurdere op ML gebaseerde analyse alleen voor invoer die de initiële filters passeert. Deze cascaderende aanpak biedt goede beveiliging met acceptabele prestaties.
Monitoring en observability
Effectieve beveiligingsmonitoring voor LLM-applicaties vereist het bijhouden van metrieken die vijandige gedragspatronen vastleggen:
from dataclasses import dataclass
from collections import defaultdict
import time
@dataclass
class SecurityMetrics:
"""Track security-relevant metrics for LLM applications."""
# Tellers
total_requests: int = 0
blocked_requests: int = 0
filtered_outputs: int = 0
anomalous_sessions: int = 0
# Tempo-tracking
_request_times: list = None
_block_times: list = None
def __post_init__(self):
self._request_times = []
self._block_times = []
def record_request(self, was_blocked: bool = False, was_filtered: bool = False):
"""Record a request and its disposition."""
now = time.time()
self.total_requests += 1
self._request_times.append(now)
if was_blocked:
self.blocked_requests += 1
self._block_times.append(now)
if was_filtered:
self.filtered_outputs += 1
def get_block_rate(self, window_seconds: int = 300) -> float:
"""Calculate the block rate over a time window."""
now = time.time()
cutoff = now - window_seconds
recent_requests = sum(1 for t in self._request_times if t > cutoff)
recent_blocks = sum(1 for t in self._block_times if t > cutoff)
if recent_requests == 0:
return 0.0
return recent_blocks / recent_requests
def should_alert(self) -> bool:
"""Determine if current metrics warrant an alert."""
block_rate = self.get_block_rate()
# Alarmeer als het blokkadepercentage de drempel overschrijdt
if block_rate > 0.3: # >30% of requests blocked in last 5 min
return True
return FalseBeveiligingstesten in CI/CD
Het integreren van AI-beveiligingstesten in de ontwikkelingspijplijn vangt regressies op voordat ze de productie bereiken:
- Tests op unitniveau: Test individuele beveiligingscomponenten (classifiers, filters) tegen bekende payloads
- Integratietests: Test de volledige beveiligingspijplijn van begin tot eind
- Regressietests: Onderhoud een suite van eerder ontdekte aanvalspayloads en verifieer dat ze geblokkeerd blijven
- Vijandige tests: Voer periodiek geautomatiseerde red team-tools (Garak, Promptfoo) uit als onderdeel van de implementatiepijplijn
Opkomende trends
Huidige onderzoeksrichtingen
Het vakgebied van LLM-beveiliging evolueert snel. Belangrijke onderzoeksrichtingen die het landschap waarschijnlijk zullen vormgeven, zijn onder andere:
-
Formele verificatie voor LLM-gedrag: Onderzoekers verkennen wiskundige frameworks voor het bewijzen van eigenschappen over modelgedrag onder vijandige omstandigheden. Hoewel volledige formele verificatie van neurale netwerken onhanteerbaar blijft, toont begrensde verificatie van specifieke eigenschappen veelbelovende resultaten.
-
Vijandige training voor LLM-robuustheid: Naast standaard-RLHF ontwikkelen onderzoekers trainingsprocedures die modellen expliciet blootstellen aan vijandige invoer tijdens de veiligheidstraining, wat de robuustheid tegen bekende aanvalspatronen verbetert.
-
Door interpreteerbaarheid geleide verdediging: Onderzoek naar mechanistische interpreteerbaarheid stelt verdedigers in staat te begrijpen waarom specifieke aanvallen slagen op neuron- en circuitniveau, wat gerichtere tegenmaatregelen informeert.
-
Multi-agent-beveiliging: Naarmate LLM-agents meer voorkomen, is het beveiligen van communicatie tussen agents en het handhaven van vertrouwensgrenzen over agent-systemen heen een actief onderzoeksgebied met aanzienlijke praktische implicaties.
-
Geautomatiseerde red teaming op schaal: Tools zoals NVIDIA's Garak, Microsoft's PyRIT en het Inspect-framework van het UK AISI maken geautomatiseerd beveiligingstesten mogelijk op een schaal die voorheen onmogelijk was, maar de kwaliteit en dekking van geautomatiseerd testen blijft een open uitdaging.
De integratie van deze onderzoeksrichtingen in productiesystemen zal de volgende generatie van AI-beveiligingspraktijken definiëren.
Referenties en verder lezen
- OWASP LLM Top 10 2025 — LLM06 (Excessive Agency)
- CVE-2024-21513 — LangChain experimental: arbitrary code execution
- OWASP LLM Top 10 2025 — LLM07 (Insecure Plugin Design)
Wat is de meest effectieve aanpak voor het verdedigen tegen de aanvalsklasse die in dit artikel wordt behandeld?
Waarom blijven de technieken die in dit artikel worden beschreven effectief over verschillende modelversies en aanbieders heen?