Maison Java javaDidacticiel Comment empêcher l'injection SQL dans jdbc ?

Comment empêcher l'injection SQL dans jdbc ?

May 06, 2019 pm 02:06 PM
jdbc 防止sql注入

Comment empêcher l'injection SQL dans jdbc ?

JDBC-Prévention des vulnérabilités d'injection SQL

L'utilisation de la précompilation peut prévenir efficacement les vulnérabilités d'injection SQL.

Raison : ne peut pas empêcher efficacement les vulnérabilités d'injection SQL dans l'instruction car l'utilisateur peut transmettre certains caractères spéciaux lors de la transmission de paramètres, tels que des guillemets simples '  , ou -- cela affectera notre instruction SQL.

Donc, utiliser l'espace réservé dans la précompilation, c'est-à-dire ?, peut résoudre efficacement ce problème.

public class Prepared {
@Test
public void papa(){
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try{
//注册驱动
// Class.forName("com.mysql.jdbc.Driver");
//建立连接
// conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/user","root","dumy");
conn =JDBCUtils.getConnection();
//编写sql代码
//String sql = "select * from administer where id = ?";
String sql = "select * from administer where username = ? and password =?";
//预编译
pstmt = conn.prepareStatement(sql);
//给? 赋值
pstmt.setString(1, "ddd");
pstmt.setString(2, "123");
rs= pstmt.executeQuery();
while(rs.next()){
System.out.println("登录成功");
}
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCUtils.release(pstmt, conn, rs);
}
}
}
Copier après la connexion

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comment empêcher l'injection SQL dans mybatis Comment empêcher l'injection SQL dans mybatis Jan 17, 2024 pm 03:42 PM

Méthodes Mybatis pour empêcher l'injection SQL : 1. Utiliser des instructions SQL précompilées ; 2. Utiliser l'espace réservé #{} ; 3. Utiliser l'espace réservé {} 4. Utiliser le SQL dynamique ; 6. Restreindre les autorisations de la base de données ; Utilisez le pare-feu d'application Web ; 8. Gardez MyBatis et la sécurité de la base de données à jour. Introduction détaillée : 1. Utilisez des instructions SQL précompilées. MyBatis utilise des instructions SQL précompilées pour effectuer des opérations de requête et de mise à jour. Les instructions SQL précompilées utilisent des requêtes paramétrées, etc.

Après Java8 (291), TLS1.1 est désactivé et JDBC ne peut pas se connecter à SqlServer2008 via SSL. Comment résoudre le problème ? Après Java8 (291), TLS1.1 est désactivé et JDBC ne peut pas se connecter à SqlServer2008 via SSL. Comment résoudre le problème ? May 16, 2023 pm 11:55 PM

Après Java8-291, TLS1.1 est désactivé, de sorte que JDBC ne peut pas se connecter à SqlServer2008 à l'aide de SSL. Que dois-je faire ? Voici la solution pour modifier le fichier java.security 1. Recherchez le fichier java.security de jre. c'est jre, allez dans {JAVA_HOME}/jre/ Dans lib/security, par exemple ????C:\ProgramFiles\Java\jre1.8.0_301\lib\security S'il s'agit de la version portable sans installation verte d'Eclipse. , recherchez java.security dans le dossier d'installation, tel que ????xxx\plugins \org

Apprenez à gérer les caractères spéciaux et à convertir les guillemets simples en PHP Apprenez à gérer les caractères spéciaux et à convertir les guillemets simples en PHP Mar 27, 2024 pm 12:39 PM

Dans le processus de développement PHP, la gestion des caractères spéciaux est un problème courant, en particulier dans le traitement des chaînes, les caractères spéciaux sont souvent échappés. Parmi eux, la conversion de caractères spéciaux en guillemets simples est une exigence relativement courante, car en PHP, les guillemets simples sont un moyen courant d'encapsuler des chaînes. Dans cet article, nous expliquerons comment gérer les guillemets simples de conversion de caractères spéciaux en PHP et fournirons des exemples de code spécifiques. En PHP, les caractères spéciaux incluent, sans s'y limiter, les guillemets simples ('), les guillemets doubles ("), la barre oblique inverse (), etc. Dans les chaînes

L'importance et les méthodes pratiques de $stmt php en programmation L'importance et les méthodes pratiques de $stmt php en programmation Feb 27, 2024 pm 02:00 PM

L'importance et les méthodes pratiques de $stmtPHP dans la programmation Dans le processus de programmation PHP, utiliser l'objet $stmt pour exécuter des instructions préparées (PreparedStatement) est une technologie très précieuse. Cette technologie peut non seulement améliorer la sécurité du programme, mais également empêcher efficacement les attaques par injection SQL et rendre les opérations de base de données plus efficaces. L'importance de $stmtPHP dans la programmation des instructions préparées fait référence à la division de l'instruction SQL en deux parties avant de l'exécuter : SQ

Le rôle et l'utilisation de SqlParameter en C# Le rôle et l'utilisation de SqlParameter en C# Feb 06, 2024 am 10:35 AM

SqlParameter en C# est une classe importante utilisée pour les opérations de base de données SQL Server et appartient à l'espace de noms System.Data.SqlClient. Sa fonction principale est de fournir un moyen sûr de transmettre des paramètres lors de l'exécution de requêtes ou de commandes SQL pour aider à prévenir les attaques par injection SQL. rend le code plus lisible et plus facile à maintenir.

Requêtes paramétrées en C# à l'aide de SqlParameter Requêtes paramétrées en C# à l'aide de SqlParameter Feb 18, 2024 pm 10:02 PM

Le rôle et l'utilisation de SqlParameter en C# Dans le développement C#, l'interaction avec la base de données est l'une des tâches courantes. Afin de garantir la sécurité et la validité des données, nous devons souvent utiliser des requêtes paramétrées pour empêcher les attaques par injection SQL. SqlParameter est une classe en C# utilisée pour créer des requêtes paramétrées. Elle fournit un moyen sûr et pratique de gérer les paramètres dans les requêtes de base de données. Le rôle de SqlParameter La classe SqlParameter est principalement utilisée pour ajouter des paramètres au langage SQL.

Comment masquer les interfaces de base de données indésirables en PHP ? Comment masquer les interfaces de base de données indésirables en PHP ? Mar 09, 2024 pm 05:24 PM

Masquer les interfaces de bases de données indésirables en PHP est très important, en particulier lors du développement d'applications Web. En masquant les interfaces de base de données inutiles, vous pouvez augmenter la sécurité du programme et empêcher les utilisateurs malveillants d'utiliser ces interfaces pour attaquer la base de données. Ce qui suit explique comment masquer les interfaces de base de données inutiles en PHP et fournit des exemples de code spécifiques. Utilisez PDO (PHPDataObjects) en PHP pour vous connecter à la base de données. PDO est une extension de connexion à la base de données en PHP. Elle fournit une interface unifiée.

Décoder les goulots d'étranglement des performances de Laravel : les techniques d'optimisation entièrement révélées ! Décoder les goulots d'étranglement des performances de Laravel : les techniques d'optimisation entièrement révélées ! Mar 06, 2024 pm 02:33 PM

Décoder les goulots d'étranglement des performances de Laravel : les techniques d'optimisation entièrement révélées ! Laravel, en tant que framework PHP populaire, offre aux développeurs des fonctions riches et une expérience de développement pratique. Cependant, à mesure que la taille du projet augmente et que le nombre de visites augmente, nous pouvons être confrontés au défi des goulots d'étranglement en matière de performances. Cet article approfondira les techniques d'optimisation des performances de Laravel pour aider les développeurs à découvrir et à résoudre les problèmes de performances potentiels. 1. Optimisation des requêtes de base de données à l'aide du chargement différé d'Eloquent Lorsque vous utilisez Eloquent pour interroger la base de données, évitez

See all articles