我正在使用Java作为Web应用程序,并且正在使用MySql数据库。在执行它之前,我需要转义查询。这是我的实际代码:Java&MySql - 在执行它之前如何逃避查询
db_result=mydb.selectQuery("SELECT nickname FROM users WHERE nickname='"+log_check_user+"' AND password='"+log_check_pass+"'");
public Vector selectQuery(String query) {
Vector v = null;
String [] record;
int colonne = 0;
try {
Statement stmt = db.createStatement();
ResultSet rs = stmt.executeQuery(query);
v = new Vector();
ResultSetMetaData rsmd = rs.getMetaData();
colonne = rsmd.getColumnCount();
while(rs.next()) {
record = new String[colonne];
for (int i=0; i<colonne; i++) record[i] = rs.getString(i+1);
v.add((String[]) record.clone());
}
rs.close();
stmt.close();
} catch (Exception e) { e.printStackTrace(); errore = e.getMessage(); }
return v;
}
我需要这个,你可以相信,以避免SQL注入问题!我该怎么做?
db是什么?什么样的对象;哪一堂课?根据您使用的数据库驱动程序,可能有更好的方法,如使用预准备语句。 – Kissaki 2010-11-10 15:08:26
MySql ...我写过了:) jdbc驱动! – markzzz 2010-11-10 16:25:36