String Vergleich mit Passwort geht nur bei Zahlen ?

Status
Nicht offen für weitere Antworten.
S

Steffie_Coco

Gast
Hallo,

wenn ich für ein PasswordField Zahlen eingebe klappt der Login ohne sql fehler, wenn ich aber in das PasswordField Buchstaben eingeben und die sql methode ausführe bekomme ich diesen Fehler:
Kan mir jemand sagen, warum ich Zahlen vergleichen kann mit der sql methode , aber bei buchstaben "dddddd" kommt ein fehler?


Code:
dddddd
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: [b]Unknown column 'dddddd' [/b]in 'where clause'
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
	at java.lang.reflect.Constructor.newInstance(Unknown Source)
	at com.mysql.jdbc.Util.handleNewInstance(Util.java:406)
	at com.mysql.jdbc.Util.getInstance(Util.java:381)
	at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1030)
	at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:956)
	at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3491)
	at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3423)
	at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1936)
	at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2060)
	at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2542)
	at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1734)
	at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:1885)
	at Database.userExist(Database.java:94)
	at Login.actionPerformed(Login.java:117)




Methodenaufruf:

Code:
char[] password    = passwordPF.getPassword();	
			 
			[b] boolean status = database.userExist(usernameTF.getText(),String.valueOf(password)); [/b]
			
			 
				if(status == true)
				{
					System.out.println("User exist in database");
					
					/*this.dispose(); 
					pupils = new PupilsGUI();*/
					
					//if(what person...)
				}


Code:
public boolean userExist(String usernameLogin , String passwordLogin)
	{
		//username:  akis   password: 1234
		//username: teacher password: 1234
	 
		System.out.println(passwordLogin);
		boolean status = false;
		try 
		{
			PreparedStatement ps = myConnection.prepareStatement("SELECT * FROM USERS where username = '"+usernameLogin+"' " + "AND password = "+passwordLogin+" "); 
			ResultSet rs = ps.executeQuery(); //Statement wird ausgeführt.
            
            if(rs.next())
            {
            	status = true;
            }	
           	
						
		}
		catch (SQLException e)
		{			
			e.printStackTrace();
		}   
		
		return status;
		
	}
 
S

SlaterB

Gast
angenommen, der User tippt als Passwort username ein

dann hast du als SQL:

SELECT * FROM USERS where username = 'gast' AND password = username

wie soll nun die DB unterscheiden, ob du einen Text username oder die Spalte username meinst?
bei 'gast' ist die Sache klarer, überleg mal warum
 
S

Steffie_Coco

Gast
SlaterB hat gesagt.:
angenommen, der User tippt als Passwort username ein

dann hast du als SQL:

SELECT * FROM USERS where username = 'gast' AND password = username

wie soll nun die DB unterscheiden, ob du einen Text username oder die Spalte username meinst?
bei 'gast' ist die Sache klarer, überleg mal warum

HÄ ??? ich tippe weder Gast noch username ein als Password sondern es geht hier um Dinge wie "dddddddfad"

das hat nichts mit deinem Problem zu tun. Lies bitte nochmals meine Frage, danke.
 
B

Bert Brenner

Bekanntes Mitglied
Slater hat recht, überprüf doch noch mal dein erzeugtes SQL.

Vielleicht gibst du das mal selbst in einem SQL Editior ein.
 
P

parabool

Bekanntes Mitglied
Bei deinen Passwortvergleich fehlen die Anführungszeichen.
Daher klappt der vergleich bei Zahlen, weil sie als solche erkannt werden und das passwort aus der db
implizit in einen zahlenwert umgewandelt wird (nehme ich an)
Sind Buchstaben enthalten geht dies nicht ->wird als spaltenname interpretiert

slaterB hatte dir schonden entscheidenden Tip gegeben.
 
S

Steffie_Coco

Gast
Code:
PreparedStatement ps = myConnection.prepareStatement("SELECT *
 FROM USERS where username = '"+usernameLogin+"'  AND password = '"+passwordLogin+"' ");

geht auch mit '' nicht...
 
P

parabool

Bekanntes Mitglied
ja, ganz übersehen:

Prepared Statement-Abfragen sehen so aus:

...SELECT * FROM USERS where username = ? AND password = ?");
ps.setString(1,username);
ps.setString(2,password);
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
B String vergleich Java Basics - Anfänger-Themen 3
C Probleme mit String-Vergleich Java Basics - Anfänger-Themen 4
T Input/Output String-Vergleich schlägt fehl Java Basics - Anfänger-Themen 7
M String-Vergleich und NullPointerException Java Basics - Anfänger-Themen 4
N Vergleich zweier String Arrays scheitert Java Basics - Anfänger-Themen 3
P String-Vergleich Java Basics - Anfänger-Themen 3
C String Objekte Vergleich je nach Instanzierung unterschiedlich!!?!! Java Basics - Anfänger-Themen 4
R String-Vergleich Java Basics - Anfänger-Themen 15
J Erste Schritte Vergleich der String-Objekte Java Basics - Anfänger-Themen 17
P Erste Schritte vergleich substring und string Java Basics - Anfänger-Themen 4
Y Java Programm URL und String Vergleich! Java Basics - Anfänger-Themen 4
S String Vergleich funktioniert nicht Java Basics - Anfänger-Themen 3
A String-Vergleich geht nicht Java Basics - Anfänger-Themen 2
U Automatenprüfung in Java implementieren — String Vergleich klappt nicht Java Basics - Anfänger-Themen 40
L Problem String-Vergleich Java Basics - Anfänger-Themen 2
Y Datentypen String vergleich Java Basics - Anfänger-Themen 3
G Komplizierterer String Vergleich Java Basics - Anfänger-Themen 10
G String-Vergleich: Was ist besser "equals()" oder & Java Basics - Anfänger-Themen 4
S String Vergleich. Java Basics - Anfänger-Themen 4
G exception bei String-Vergleich Java Basics - Anfänger-Themen 3
S Vergleich String Java Basics - Anfänger-Themen 4
M Vergleich von String mit String bzw. Stringkonstante Java Basics - Anfänger-Themen 2
N String Vergleich!!! Java Basics - Anfänger-Themen 9
P Ein Objekt nach einem String durchsuchen? Java Basics - Anfänger-Themen 7
AlexVo String zu Java Anweisung getString("*** java code ***") Java Basics - Anfänger-Themen 19
O String mit Character vergleichen Java Basics - Anfänger-Themen 3
I String.split regex Frage Java Basics - Anfänger-Themen 2
H Methode über String Wert aufrufen Java Basics - Anfänger-Themen 8
F Java Programm, das kleine Buchstaben in einem String zählen soll und bei großen Buchstaben oder Sonderzeichen abbrechen soll. Java Basics - Anfänger-Themen 5
tobikoch String x= null Bedeutung Java Basics - Anfänger-Themen 9
GAZ String replace() Elemente tauschen Java Basics - Anfänger-Themen 13
R String in char-Array übertragen Java Basics - Anfänger-Themen 5
T Zeichen im String verschiebe Java Basics - Anfänger-Themen 9
J Verschieben von Buchstaben in einem String um vorgegebene Anzahl von Zeichen innerhalb eines weiteren String Java Basics - Anfänger-Themen 12
P Datentypen Array und String Java Basics - Anfänger-Themen 2
javapingu Hex String zu long Java Basics - Anfänger-Themen 2
D Attribut Telefonnummer - eigene Klasse oder String Java Basics - Anfänger-Themen 13
Vamecruft Compiler-Fehler public static void zu static String ändern Java Basics - Anfänger-Themen 2
O if Abfrage erkennt String nicht Java Basics - Anfänger-Themen 1
A eine neue normale String-Array von einer String-Array, die in for schleife ist, schaffen Java Basics - Anfänger-Themen 3
A keine Ergebnisse - String nummer in array nummer converting Java Basics - Anfänger-Themen 1
O Datentypen String teilen Java Basics - Anfänger-Themen 5
macle Rekursive String Methode, Gerade Zahlen rausfiltern Java Basics - Anfänger-Themen 10
B String to int Java Basics - Anfänger-Themen 11
D String value change listener Java Basics - Anfänger-Themen 2
I Wo am besten eine String Konstante initialisieren? Java Basics - Anfänger-Themen 5
F JMenuItem Kann nicht nach einem String benannt werden... Java Basics - Anfänger-Themen 11
B String to Float Java Basics - Anfänger-Themen 27
B Map<String, FilterMeta, wie Wert bekommen? Java Basics - Anfänger-Themen 4
Dimax stream in string[] speichern Java Basics - Anfänger-Themen 6
Dimax String Probleme Java Basics - Anfänger-Themen 12
H Wie wird ein String intern gespeichert? Java Basics - Anfänger-Themen 10
C String auf Dualzahl überprüfen Java Basics - Anfänger-Themen 5
L Mit Zahlen im String rechnen Java Basics - Anfänger-Themen 19
A final String verrechnen Java Basics - Anfänger-Themen 2
N String N-Gramme mit Stream erstellen Java Basics - Anfänger-Themen 7
A Implementierung von String toString methode() Java Basics - Anfänger-Themen 4
Z Matrix Klasse mit Mehrdimensionalen Array (Addition, Multiplikation, to String) Java Basics - Anfänger-Themen 57
J Eine Position im String durch einen Integer - Wert teilen Java Basics - Anfänger-Themen 5
Z Methode zum Heraufinden von Anagrammen ohne Java API, Ausnahme String Java Basics - Anfänger-Themen 14
Dimax Erste Schritte String replace alle Zeichen Java Basics - Anfänger-Themen 10
F Auto String mit Array Name aus Datei... oder so ähnlich Java Basics - Anfänger-Themen 4
J Characters als String zusammenfassen Java Basics - Anfänger-Themen 3
D Input/Output Mehrzeiligen String aus Textdatei erstellen Java Basics - Anfänger-Themen 5
J zwei String Arrays miteinander vergleichen Java Basics - Anfänger-Themen 18
F String auf E-Mail kürzen Java Basics - Anfänger-Themen 11
J String aus einem Array entfernen Java Basics - Anfänger-Themen 10
S String index out of range Java Basics - Anfänger-Themen 11
L String in Do-While-Schleife Abbruchkriterium Java Basics - Anfänger-Themen 1
V int zu Integer und String Java Basics - Anfänger-Themen 6
X Erste Schritte String: Alle doppelten Leerzeilen entfernen Java Basics - Anfänger-Themen 21
J String Array zu Map<Character, List<Character>> mit Streams Java Basics - Anfänger-Themen 1
P Datenspeichern im String Java Basics - Anfänger-Themen 5
J String wird in GUI falsch ausgegeben Java Basics - Anfänger-Themen 10
S Nutzereingabe splitten und in string array wieder ausgeben. Java Basics - Anfänger-Themen 1
S String umwandeln Java Basics - Anfänger-Themen 6
S Ersetzen eines Asterix in einem String Java Basics - Anfänger-Themen 8
B String nach erstem Leerzeichen trennen Java Basics - Anfänger-Themen 7
G String wird nach Einlesen aus Datei nicht erkannt Java Basics - Anfänger-Themen 3
M String in Scanner einlesen Java Basics - Anfänger-Themen 6
R String vergleichen Java Basics - Anfänger-Themen 59
L String zerlegen & elemente hinzufügen Java Basics - Anfänger-Themen 5
FelixN RegEx aus einem String als String-Array zurückgeben Java Basics - Anfänger-Themen 8
Curtis_MC 2dimensionales Array als String ausgeben Java Basics - Anfänger-Themen 2
J Zeichen im String zählen Java Basics - Anfänger-Themen 3
J erstes Vorkommen eines Chars aus einem String entfernen Java Basics - Anfänger-Themen 3
S String richtig formatieren Java Basics - Anfänger-Themen 2
M String außerhalb der main-Methode Java Basics - Anfänger-Themen 4
N Fehler bei string Attribut! Java Basics - Anfänger-Themen 18
I String Repraesentation eines Objekts Java Basics - Anfänger-Themen 1
S Gesamten String in einer Zeile ausgeben Java Basics - Anfänger-Themen 2
J Umwandlung String zu ASCII-Wert und anders Java Basics - Anfänger-Themen 17
L String als ungültig deklarieren Java Basics - Anfänger-Themen 2
I char Array to String Java Basics - Anfänger-Themen 3
I converting boolean Array to String Array Java Basics - Anfänger-Themen 10
S String split Java Basics - Anfänger-Themen 12
C Java String Methode Java Basics - Anfänger-Themen 6
G String mit mehreren Attributen aufteilen Java Basics - Anfänger-Themen 6
Dimax String Split Java Basics - Anfänger-Themen 2
D Methode mit Übergabe double und Rückgabe String Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Anzeige

Neue Themen


Oben