0

ねえ、私は今少し混乱しています。ここにsystem.out.printコードがいくつかあるので、問題が何であるかを知ることができます。とにかく、これが私が得るエラーです、そしてそれは実際のSQLクエリを含むtry/catchで捕らえられます。

とにかくここに私のコードがあります。

JSPページ

<%@ page import="webtest.*" %>
<%@ page import="java.sql.*" %>
<%@ page import="java.io.*" %>
<%@ page import="java.util.*"%>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>


<%String username = request.getParameter("username");
String password = request.getParameter("password");
UserNameCheck unc = new UserNameCheck();
%>
<H1>
<%=unc.LoginResults("select name,password from mattroepracticetable" +
        " where name='"+username+"' and password='"+password+"' ")%>

</H1>
</body>
</html>

これがUserNameCheckクラスです

package webtest;

import java.sql.*;
public class UserNameCheck{
DWConnect dwc = new DWConnect();

public String LoginResults(String sql){
Statement stmt;
ResultSet rslt;
System.out.println(sql);
String V=null;
try{
    stmt = dwc.conn.createStatement();
    System.out.print(sql);
    rslt = stmt.executeQuery(sql);
    if (rslt.next()){
         V = rslt.getString("username");
        System.out.print("hey");
    }
    else V = "Invalid UserName or Password";
    System.out.print("not hey");
}
catch (Exception e){System.out.print(e);}
return V;
}
}

とにかく私が受け取っているエラーは次のとおりです

select name,password from mattroepracticetable where name='MattRoe' and password='MattRoe' java.sql.SQLException: Invalid column name

ただし、SQL式を直接コピーしてSQLplusに貼り付けると、正常に機能します。
jspinitでデータベース接続を初期化することになっていることは知っていますが、この方法でも初期化できると思いました。
誰かが私がどこで間違っていたのか説明できたら、jspinitを使ってこれを設定する方法、または一般的にこれを設定する方法を教えていただければ幸いです。

4

1 に答える 1

4

あなたの質問は:

select
   name,password from mattroepracticetable
where 
   name='"+username+"' and password='"+password+"'"

しかし、ResultSetからあなたは読み込もうとしています:

V = rslt.getString( "username" );

次のように変更する必要があります。

V = rslt.getString( "name" );
于 2012-07-10T15:10:01.570 に答える