


Comment utiliser Redis et Dart pour développer des fonctions de défense contre la pénétration du cache
Comment développer une fonction de défense contre la pénétration du cache à l'aide de Redis et Dart
Dans les applications Web modernes, la mise en cache est une technologie courante d'optimisation des performances. Cependant, les systèmes de mise en cache peuvent être vulnérables aux attaques par pénétration du cache. La pénétration du cache fait référence à la demande de données qui n'existent pas dans le cache. Lorsque les requêtes sont fréquentes, un grand nombre de requêtes invalides accèdent directement à la base de données ou à d'autres services back-end, affectant ainsi les performances du système.
Afin de résoudre le problème de la pénétration du cache, nous pouvons utiliser les langages Redis et Dart pour développer une fonction de défense contre la pénétration du cache. Voici les étapes de mise en œuvre spécifiques et un exemple de code :
- Importez la bibliothèque Redis dans le projet Dart
Tout d'abord, utilisez le fichier pubspec.yaml pour importer la bibliothèque Redis dans le projet Dart, comme indiqué ci-dessous :
dependencies: redis: ^4.0.0
Ensuite, exécutez la commande pub get
pour obtenir les dépendances requises. pub get
命令以获取所需的依赖项。
- 连接到Redis服务器
使用下面的代码连接到Redis服务器:
import 'package:redis/redis.dart'; Future<void> main() async { final redis = await RedisConnection.connect('localhost', 6379); }
请确保将localhost
和6379
替换为您的Redis服务器的正确主机名和端口号。
- 创建缓存键
在防御缓存穿透时,我们需要创建一个能够表示请求的唯一缓存键。这可以通过组合请求的关键参数来实现。例如,对于URL为/api/data?id=123
的请求,我们可以使用data_123
作为缓存键。
String createCacheKey(String dataType, String id) { return '$dataType_$id'; }
- 缓存穿透防御功能实现
以下是一个使用Redis和Dart实现缓存穿透防御功能的示例:
import 'package:redis/redis.dart'; class Cache { final RedisConnection _redis; Cache(this._redis); Future<String?> get(String key) async { final value = await _redis.get(key); if (value == null) { return null; } else if (value.isEmpty) { // 如果值为空字符串,则表示请求结果为空 return ''; } else { return value; } } Future<void> set(String key, String value, {Duration? expiration}) async { await _redis.set(key, value); if (expiration != null) { await _redis.expire(key, expiration.inSeconds); } } } class DataService { final Cache _cache; DataService(this._cache); Future<String> getData(String id) async { final cacheKey = createCacheKey('data', id); final cachedValue = await _cache.get(cacheKey); if (cachedValue != null) { return cachedValue; } // 从后端服务获取数据 final data = await fetchDataFromBackendService(id); // 如果数据不存在,则将空字符串存储到缓存中,避免重复查询 final expiration = data.isNotEmpty ? Duration(minutes: 5) : Duration(seconds: 30); await _cache.set(cacheKey, data, expiration: expiration); return data; } Future<String> fetchDataFromBackendService(String id) async { // 从后端服务获取数据的实现代码 } } Future<void> main() async { final redis = await RedisConnection.connect('localhost', 6379); final cache = Cache(redis); final dataService = DataService(cache); final data = await dataService.getData('123'); print('Data: $data'); }
在上面的示例中,我们首先通过创建Cache
类来封装与Redis的交互。然后,通过创建DataService
类来实现数据的获取逻辑。在getData
- Connectez-vous au serveur Redis🎜Utilisez le code suivant pour vous connecter au serveur Redis : 🎜rrreee🎜Veuillez vous assurer de remplacer
localhost
et 6379 code> Le nom d'hôte et le numéro de port corrects pour votre serveur Redis. 🎜<ol start="3">🎜Créer une clé de cache🎜🎜🎜Lors de la défense contre la pénétration du cache, nous devons créer une clé de cache unique qui représente la demande. Ceci peut être réalisé en combinant les paramètres clés de la demande. Par exemple, pour une requête avec l'URL <code>/api/data?id=123
, nous pouvons utiliser data_123
comme clé de cache. 🎜rrreee- 🎜Implémentation de la fonction de défense contre la pénétration du cache🎜🎜🎜Ce qui suit est un exemple d'utilisation de Redis et Dart pour implémenter la fonction de défense contre la pénétration du cache : 🎜rrreee🎜Dans l'exemple ci-dessus, nous créons d'abord du Cache
DataService
. Dans la méthode getData
, nous essayons d'abord d'obtenir les données demandées du cache, si les données n'existent pas, nous récupérons les données du service backend et stockons le résultat dans le cache. 🎜🎜Grâce aux étapes ci-dessus et à l'exemple de code, nous pouvons utiliser Redis et Dart pour développer une fonction de défense contre la pénétration du cache simple et efficace. Cela améliorera considérablement les performances et la sécurité du système et évitera un accès non valide à la base de données ou au service backend. 🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Le mode Redis Cluster déploie les instances Redis sur plusieurs serveurs grâce à la rupture, à l'amélioration de l'évolutivité et de la disponibilité. Les étapes de construction sont les suivantes: Créez des instances de redis étranges avec différents ports; Créer 3 instances Sentinel, Moniteur Redis Instances et basculement; Configurer les fichiers de configuration Sentinel, ajouter des informations d'instance Redis de surveillance et des paramètres de basculement; Configurer les fichiers de configuration d'instance Redis, activer le mode de cluster et spécifier le chemin du fichier d'informations de cluster; Créer un fichier nœuds.conf, contenant des informations de chaque instance redis; Démarrez le cluster, exécutez la commande CREATE pour créer un cluster et spécifiez le nombre de répliques; Connectez-vous au cluster pour exécuter la commande d'informations de cluster pour vérifier l'état du cluster; faire

Comment effacer les données Redis: utilisez la commande flushall pour effacer toutes les valeurs de clé. Utilisez la commande flushdb pour effacer la valeur clé de la base de données actuellement sélectionnée. Utilisez SELECT pour commuter les bases de données, puis utilisez FlushDB pour effacer plusieurs bases de données. Utilisez la commande del pour supprimer une clé spécifique. Utilisez l'outil Redis-CLI pour effacer les données.

Pour lire une file d'attente à partir de Redis, vous devez obtenir le nom de la file d'attente, lire les éléments à l'aide de la commande LPOP et traiter la file d'attente vide. Les étapes spécifiques sont les suivantes: Obtenez le nom de la file d'attente: Nommez-le avec le préfixe de "Fitre:" tel que "Fitre: My-Quyue". Utilisez la commande LPOP: éjectez l'élément de la tête de la file d'attente et renvoyez sa valeur, telle que la file d'attente LPOP: My-Queue. Traitement des files d'attente vides: si la file d'attente est vide, LPOP renvoie NIL et vous pouvez vérifier si la file d'attente existe avant de lire l'élément.

L'utilisation des opérations Redis pour verrouiller nécessite l'obtention du verrouillage via la commande setnx, puis en utilisant la commande Expire pour définir le temps d'expiration. Les étapes spécifiques sont les suivantes: (1) Utilisez la commande setnx pour essayer de définir une paire de valeurs de clé; (2) Utilisez la commande Expire pour définir le temps d'expiration du verrou; (3) Utilisez la commande del pour supprimer le verrouillage lorsque le verrouillage n'est plus nécessaire.

L'utilisation de la directive Redis nécessite les étapes suivantes: Ouvrez le client Redis. Entrez la commande (Verbe Key Value). Fournit les paramètres requis (varie de l'instruction à l'instruction). Appuyez sur Entrée pour exécuter la commande. Redis renvoie une réponse indiquant le résultat de l'opération (généralement OK ou -err).

La meilleure façon de comprendre le code source redis est d'aller étape par étape: familiarisez-vous avec les bases de Redis. Sélectionnez un module ou une fonction spécifique comme point de départ. Commencez par le point d'entrée du module ou de la fonction et affichez le code ligne par ligne. Affichez le code via la chaîne d'appel de fonction. Familiez les structures de données sous-jacentes utilisées par Redis. Identifiez l'algorithme utilisé par Redis.

Utilisez l'outil de ligne de commande redis (Redis-CLI) pour gérer et utiliser Redis via les étapes suivantes: Connectez-vous au serveur, spécifiez l'adresse et le port. Envoyez des commandes au serveur à l'aide du nom et des paramètres de commande. Utilisez la commande d'aide pour afficher les informations d'aide pour une commande spécifique. Utilisez la commande QUIT pour quitter l'outil de ligne de commande.

Sur CentOS Systems, vous pouvez limiter le temps d'exécution des scripts LUA en modifiant les fichiers de configuration Redis ou en utilisant des commandes Redis pour empêcher les scripts malveillants de consommer trop de ressources. Méthode 1: Modifiez le fichier de configuration Redis et localisez le fichier de configuration Redis: le fichier de configuration redis est généralement situé dans /etc/redis/redis.conf. Edit Fichier de configuration: Ouvrez le fichier de configuration à l'aide d'un éditeur de texte (tel que VI ou NANO): Sudovi / etc / redis / redis.conf Définissez le délai d'exécution du script LUA: Ajouter ou modifier les lignes suivantes dans le fichier de configuration pour définir le temps d'exécution maximal du script LUA (unité: millisecondes)
