Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

user names are not matching to users in database

0 views
Skip to first unread message

Naccessible

unread,
Dec 6, 2006, 4:16:02 PM12/6/06
to
I am using Java and building a user login table. When the data comes
from a input stream from the console oracle matches the user and data.
When the data comes from a servlet the data, even hardcoded does not
match the database. Why? Is it the database or Java?

Vladimir M. Zakharychev

unread,
Dec 6, 2006, 4:22:21 PM12/6/06
to

Huh? Can you post a snippet of your code and describe the issue in a
little bit more detail (preferably in form of a test script and its
desired and actual output/behavior?) As posted, the question gives out
too little information to be answered...

Regards,
Vladimir M. Zakharychev
N-Networks, makers of Dynamic PSP(tm)
http://www.dynamicpsp.com

Naccessible

unread,
Dec 6, 2006, 5:40:18 PM12/6/06
to

Vladimir,
Thank you for your prompt reply.
Here is a the code snippets that I use:

This is class loginserverlet:

public class loginserverlet extends HttpServlet {

private String userName = null;
private String passWord = null;
boolean valid = true;
String parmuser = null;
String parmpass = null;

public void doPost(HttpServletRequest login, HttpServletResponse
res)
throws ServletException, IOException {

// userName = login.getParameter("username");
// passWord = login.getParameter("password");

PrintWriter out = res.getWriter ();
SeparateTest newtest = new SeparateTest();
parmuser = newtest.SeparateTest();
out.println(parmuser);
if (parmuser.equals("true")){
// PrintWriter out = res.getWriter();
out.println("inuser value -- " + valid);
//
res.sendRedirect("http://192.168.1.2:12080/GADXML/DevGADXML/DGADpages/biography.html");
}
if (parmuser.equals("false")){
// PrintWriter out = res.getWriter();
out.println(" not valid");
//
res.sendRedirect("http://192.168.1.2:12080/GADXML/DevGADXML/DGADpages/notvalidpass.htm");
}
}

}


This is the SeparateTest class:

public class SeparateTest {
public String uName = null;
public String pWord = null;
public String pmuser = null;
public boolean validtst = true;

public String SeparateTest() {
initLogin logtest = new initLogin();
uName = "david";
pWord = "rachel";
validtst = logtest.authenticate(uName, pWord);
System.out.println(validtst);
if (validtst){
pmuser = "true";
}
else if (!validtst){
pmuser = "false";
}
return pmuser;
}

and this is initLogin class:

public class initLogin {

private String username = "";
private String password = "";

public initLogin() {
}

public void setUsername(String username) {
this.username = username;
}

public void setPassword(String password) {
this.password = password;
}

public boolean authenticate(String username2,
String password2) {
String query="select * from USERS;";
String DbUserName="";
String DbPassword="";
String finalUser="";
String retval = null;

String data = "jdbc:odbc:GADXML";
try{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
Connection conn = DriverManager.getConnection(data, "system",
"rosetta");
Statement stat = conn.createStatement();
ResultSet rst=stat.executeQuery(query);
StringBuffer testUser = new StringBuffer(username2);
StringBuffer testPass = new StringBuffer(password2);
String testuser = testUser.toString();
String testpass = testPass.toString();

parameterInput chkparm = new parameterInput();
retval = chkparm.readLine(testuser);
username2 = retval;
retval = null;
retval = chkparm.readLine(testpass);
password2 = retval;
retval = null;
System.out.println("username -- " + username2);
System.out.println("password -- " + password2);
while(rst.next())
{
DbUserName=rst.getString("username");
DbPassword=rst.getString("password");
finalUser=rst.getString("usertype");
finalUser=rst.getString("approver");
testUser = new StringBuffer(DbUserName);
testPass = new StringBuffer(DbPassword);
testuser = testUser.toString();
testpass = testPass.toString();

retval = chkparm.readLine(testuser);
DbUserName = retval;
retval = null;
retval = chkparm.readLine(testpass);
DbPassword = retval;
retval = null;
if (username2.equals(DbUserName) &&
password2.equals(DbPassword)) {
return true;
}
}
return true;
}
catch(Exception e){
e.printStackTrace();
System.out.println("here is the problem -- " + DbUserName);
return false;
}
}
}

And parameter input:

public class parameterInput {
String input = null;
public static String readLine(String firstVal){
StringBuffer response = new StringBuffer();
try {
System.out.println("passed value -- " + firstVal);
StringReader buff = new StringReader(firstVal);
int in = 0;
int totval = 0;
int inplace = 0;
int nextplace = 0;
char inChar;
do {
in = buff.read();
inChar = (char) in;
if ((in != -1) && ((inChar != '\n')||(inChar !=
'\t'))){
response.append(inChar);
inplace++;
nextplace = inplace + in;
totval = totval + nextplace;
System.out.println("char: " + inChar + " value: " +
in );
}
} while ((in != -1) & ((inChar != '\n') || (inChar !=
'\t')));
buff.close();
return response.toString();
// return totval;
} catch (IOException e) {
System.out.println("Exception: " + e.getMessage());
return null;
}
}
}

Here is the TestGad class:

public class testgad {
private String valid = "";
private String passWord = "";
// public static int username = 0;
// public static int password = 0;
public static String username = null;
public static String password = null;
boolean truetest = false;

public testgad() {

System.out.println("newtest");
initLogin logtest = new initLogin();
System.out.println(username);
System.out.println(password);
truetest = logtest.authenticate(username, password);
if (truetest){
System.out.println("its true");
}
if (!truetest){
System.out.println("its not really true");
}

// loginbean logtest = new loginbean();
// logtest.authent2cate(username, password);
}

public static void main(String[] args) {
username = "david";
password = "rachel";
testgad testgad = new testgad();
}
}

This code basically cycles through the oracle user database and
compares passwords for login to either the web, via the loginserverlet
class or from the console using TestGad class. TestGad works fine but
loginserverlet does not. It consistently returns "false" which is not
correct. both classes are "hardcoded with a username and password" so
the results should be the same. Thank you for your response.

HansF

unread,
Dec 7, 2006, 12:03:46 AM12/7/06
to
On Wed, 06 Dec 2006 14:40:18 -0800, Naccessible wrote:

> username = "david";
> password = "rachel";

Are you being sting by case sensitivity? By default, the user name in
Oracle is DAVID, not david. Ditto for password.

--
Hans Forbrich (mailto: Fuzzy.GreyBeard_at_gmail.com)
*** Feel free to correct me when I'm wrong!
*** Top posting [replies] guarantees I won't respond.

Vladimir M. Zakharychev

unread,
Dec 7, 2006, 2:34:53 AM12/7/06
to

Naccessible wrote:
[code snipped]

> This code basically cycles through the oracle user database and
> compares passwords for login to either the web, via the loginserverlet
> class or from the console using TestGad class. TestGad works fine but
> loginserverlet does not. It consistently returns "false" which is not
> correct. both classes are "hardcoded with a username and password" so
> the results should be the same. Thank you for your response.

Interesting. If I understood correctly, the same "authentication" code
used both from console test class and from the servlet, yet it works
when called from test class and doesn't when called from the servlet. I
would verify the DSN on the webserver - does it really connect to the
same database? I would also add some more logging to the initLogin to
see what really goes on, is the connection really established, what is
being fetched from the dababase and what it's being compared with.

Naccessible

unread,
Dec 7, 2006, 12:44:34 PM12/7/06
to
I put in logging code and found that I get this exception from the
database when I use the servlet instead of the console.
I get this exception from initLogin:
the problem is java.sql.SQLException: [Microsoft][ODBC Driver Manager]
Data source name not found and no default driver specified
What is this error? How do I fix it?

Naccessible

unread,
Dec 7, 2006, 12:48:45 PM12/7/06
to
I appreciate your response Hans.

It works correctly when the username and password comes from hardcoded
data from the console, "TestGad" code. I entered the data into the
database as small letters. I will try tests with all capital letters.

N-.

Naccessible

unread,
Dec 7, 2006, 1:04:40 PM12/7/06
to
Vladimir,
Thank you so much!!!! The DSN was the problem. I googled another
site with the error and found that I needed to use the SYSTEM DSN
rather than the USER DSN as I had it set. THANKS!!!!
This is a very good message board.
N-.
0 new messages