在以下代码中..我没有得到合适的driver..error: 请帮忙。我已经和它一起工作了一个小时,似乎无法弄明白。
太疯狂了。在我开始搞乱GWT之前,我能够更早地做到这一点。
package com.gwt.churchweb.churchweblogin.client;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.VerticalPanel;
import com.google.gwt.user.client.ui.Label;
import com.google.gwt.user.client.ui.FlexTable;
import com.google.gwt.user.client.ui.TextBox;
import com.google.gwt.user.client.ui.HasHorizontalAlignment;
import com.google.gwt.user.client.ui.CheckBox;
import com.google.gwt.user.client.ui.Button;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.user.client.Window;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.DriverManager;
import java.util.logging.Level;
import java.util.logging.Logger;
public class Login extends Composite {
public Login() {
VerticalPanel verticalPanel = new VerticalPanel();
initWidget(verticalPanel);
verticalPanel.setSize("329px", "186px");
Label lblNewLabel = new Label("Sign into your account");
lblNewLabel.setStyleName("gwt-Login-SigninLabel");
verticalPanel.add(lblNewLabel);
FlexTable flexTable = new FlexTable();
verticalPanel.add(flexTable);
flexTable.setWidth("308px");
Label lblNewLabel_1 = new Label("Username:");
lblNewLabel_1.setStyleName("gwt-Label-Login");
flexTable.setWidget(0, 0, lblNewLabel_1);
lblNewLabel_1.setWidth("72px");
final TextBox textboxUsername = new TextBox();
textboxUsername.setStyleName("gwt-LoginTextBox");
flexTable.setWidget(0, 1, textboxUsername);
textboxUsername.setWidth("204px");
Label lblNewLabel_2 = new Label("Password:");
lblNewLabel_2.setStyleName("gwt-Label-Login");
flexTable.setWidget(1, 0, lblNewLabel_2);
lblNewLabel_2.setWidth("66px");
final TextBox textBoxPassword = new TextBox();
textBoxPassword.setStyleName("gwt-LoginTextBox");
flexTable.setWidget(1, 1, textBoxPassword);
textBoxPassword.setWidth("204px");
flexTable.getCellFormatter().setHorizontalAlignment(0, 0, HasHorizontalAlignment.ALIGN_LEFT);
flexTable.getCellFormatter().setHorizontalAlignment(1, 0, HasHorizontalAlignment.ALIGN_LEFT);
CheckBox chckbxRememberMeOn = new CheckBox("Remember me on this computer");
chckbxRememberMeOn.setStyleName("gwt-Checkbox-Login");
flexTable.setWidget(2, 1, chckbxRememberMeOn);
Button btnSignIn = new Button("Sign In");
btnSignIn.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
Connection con = null;
Statement st = null;
ResultSet rs = null;
String url = "jdbc:mysql://localhost:3306/churchweb";
String user = "root";
String password = "*****";
try {
con = DriverManager.getConnection(url, user, password);
st = con.createStatement();
rs = st.executeQuery("SELECT VERSION()");
Window.alert("Fixing to try it");
if (rs.next()) {
Window.alert(rs.getString(1));
}
} catch (SQLException ex) {
Logger lgr = Logger.getLogger(Login.class.getName());
lgr.log(Level.SEVERE, ex.getMessage(), ex);
} finally {
try {
if (rs != null) {
rs.close();
}
if (st != null) {
st.close();
}
if (con != null) {
con.close();
}
} catch (SQLException ex) {
Logger lgr = Logger.getLogger(Login.class.getName());
lgr.log(Level.WARNING, ex.getMessage(), ex);
}
}
if (textboxUsername.getText().length() == 0
|| textBoxPassword.getText().length() == 0) {
Window.alert("Username or password is empty.");
}
}
});
btnSignIn.setStyleName("gwt-Login-SigninButton");
flexTable.setWidget(3, 1, btnSignIn);
}
}
答案 0 :(得分:2)
确保MySQL Connector/J驱动程序jar文件位于类路径中。
答案 1 :(得分:2)
您还没有将驱动程序加载到您的应用程序,尝试添加Class.forName(“com.mysql.jdbc.Driver”);
答案 2 :(得分:1)
您需要加载驱动程序。来自sun网页的connector-j驱动程序附带的doc中有一些示例。以下是该文档的摘录。
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
} catch (Exception ex) {
// handle the error
}
如果您想了解有关加载java jdbc驱动程序的更多信息,请查看与驱动程序下载捆绑在一起的connector-j.pdf的第6章。