- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
<分区>
页面总是转发到“custLogin”,但数据是正确的。
下面的代码:
类(class)登录:
private CustomerDB db;
public void init() {
String dbUrl = "jdbc:mysql://localhost:3306/fyp";
String dbUser = "root";
String dbPassword = "";
db = new CustomerDB(dbUrl, dbUser, dbPassword);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doPost(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String action = request.getParameter("action");
if (!isAuthenticated(request) && !("authenticate".equals(action))) {
doLogin(request, response);
return;
}
if ("authenticate".equals(action)) {
doAuthenticate(request, response);
} else if ("logout".equals(action)) {
doLogout(request, response);
} else {
response.sendError(HttpServletResponse.SC_NOT_IMPLEMENTED);
}
}
private void doAuthenticate(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
String username = request.getParameter("custID");
String password = request.getParameter("custPW");
String targetURL;
init();
boolean isValid = db.isValidUser("chan123", "123456");
if (isValid) {
targetURL = "/index.jsp";
} else {
targetURL = "/custLogin.jsp";
}
RequestDispatcher rd;
rd = getServletContext().getRequestDispatcher("/" + targetURL);
rd.forward(request, response);
}
public boolean isAuthenticated(HttpServletRequest request) {
boolean result = false;
HttpSession session = request.getSession();
if (session.getAttribute("userInfo") != null) {
result = true;
}
return result;
}
private void doLogin(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
String targetURL = "login.jsp";
RequestDispatcher rd;
rd = getServletContext().getRequestDispatcher("/" + targetURL);
rd.forward(request, response);
}
private void doLogout(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
HttpSession session = request.getSession(false);
if (session != null) {
session.removeAttribute("userInfo");
session.invalidate();
}
doLogin(request, response);
}
chan123 是 custID。123456 是客户密码。
类 CustomerDB:
private String dbUrl;
private String dbUser;
private String dbPassword;
public CustomerDB() {
}
public CustomerDB(String dburl, String dbUser, String dbPassword) {
this.dbUrl = dbUrl;
this.dbUser = dbUser;
this.dbPassword = dbPassword;
}
public Connection getConnection() throws SQLException, IOException {
System.setProperty("jdbc.drivers", "com.mysql.jdbc.Driver");
Connection conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/fyp", "root", "");
return conn;
}
public boolean isValidUser(String custID, String custPW) {
boolean isValid = false;
Connection cnnct = null;
PreparedStatement pStmnt = null;
try {
cnnct = getConnection();
String preQueryStatement = "SELECT * FROM customer WHERE custID=? and custPW=?";
pStmnt = cnnct.prepareStatement(preQueryStatement);
pStmnt.setString(1, custID);
pStmnt.setString(2, custPW);
ResultSet rs = null;
rs = pStmnt.executeQuery();
if (rs.next()) {
isValid = true;
}
pStmnt.close();
cnnct.close();
} catch (SQLException ex) {
while (ex != null) {
ex.printStackTrace();
ex = ex.getNextException();
}
} catch (IOException ex) {
ex.printStackTrace();
}
return isValid;
}
我创建了测试 java。它可以加载正确的结果。
public static void main(String[] arg) {
String dbUrl = "jdbc:mysql://localhost:3306/fyp";
String dbUser = "root";
String dbPassword = "";
CustomerDB db = new CustomerDB(dbUrl, dbUser,dbPassword);
boolean n = db.isValidUser("chan123", "123456");
if (n) {
System.out.println("TTTTTT");
}else
System.out.println("f");
}
它显示“TTTTTT”。
但页面转到“custLogin”。输出:
SEVERE: java.sql.SQLException: No suitable driver found for jdbc:mysql://localhost:3306/fyp
at java.sql.DriverManager.getConnection(DriverManager.java:596)
at java.sql.DriverManager.getConnection(DriverManager.java:215)
at fyp.db.CustomerDB.getConnection(CustomerDB.java:29)
at fyp.db.CustomerDB.isValidUser(CustomerDB.java:39)
at fyp.servlet.Login.doAuthenticate(Login.java:52)
at fyp.servlet.Login.doPost(Login.java:39)
...
请帮我解决这个问题。谢谢!
谁能解释一下 localhost:5000 之间的区别和其他本地主机。 谢谢你。 最佳答案 localhost:5000 正在访问端口 5000 上的 localhost。 例如,如果您从浏览器访问它
假设本地 Python 脚本正在运行网络服务器。 有没有办法设置别名,以便http://localwebapp/等于 http://localhost:1234/ ? 编辑:或至少 http://lo
我对网络开发完全陌生。所以我总是看到“localhost”之类的东西并问自己:那是什么? 我感觉知道什么是“主持人”了。执行某事的东西。所以我的 Mac 是其上运行的所有内容的主机。那么“localh
我正在学习 xmpp 编程,我使用 sudo apt-get install ejabberd 在我的 ubuntu 15.10 上安装了 ejabberd,然后我通过添加管理员用户 ejabberd
是否总是可以 ping localhost 并解析为 127.0.0.1? 我知道 Windows Vista、XP、Ubuntu 和 Debian 都这样做,但每个人都这样做吗? 最佳答案 任何正确
我们在同一台计算机上使用客户端/服务器 RMI 通信(因此所有 ip 都应该是本地主机)。 我们启动注册表(使用默认端口1099) registry = LocateRegistry.createRe
我已经在 windows/system32/drivers/etc/ 中验证了我的主机文件其中有一个 localhost 的条目,但它不会去任何地方。我必须在 URL 中有一个端口号:http://1
我的主机上有一个守护程序在某个端口(即 8008)上运行,我的代码通常通过联系 localhost:8008 与守护程序交互。 我现在已经将我的代码容器化了,但还没有将守护进程容器化。如何将容器上的
在 SMTP 中,HELO 命令之后应该是什么,它有什么作用? 我在我的应用程序中发送电子邮件,我想知道我是否应该使用 localhost、发件人地址的域名 (me@example.com)、应用程序
我遇到无法打开本地主机Web应用程序的问题,因为Microsoft Edge会将URL http://localhost:3000重定向到https://localhost:3000。因此,我得到了错
一直在尝试设置我想用于登录的 Facebook 应用程序,以允许我在 Mac 的本地主机上测试它。 Facebook 抛出错误“应用程序域:http://localhost 不是有效域。”当我尝试将站
我在 MacOS 10.15 上使用 minikube 1.4.0 版和 Kubernetes 1.16.0 版。 我正在开发一些依赖于外部服务的授权/认证代码。在对服务的 API 调用中,我需要提供
当我用谷歌搜索这个问题时,我注意到这是 nginx 的一个常见问题。但是我从来没有在我的机器上使用过 nginx。我使用 MAMP,偶尔使用 Python Bottle。 现在,无论我的 MAMP/P
我在本地运行 Squid,我想通过在 localhost:3000 上运行的 Ruby 服务器通过 Squid 进行访问。 如果我尝试访问 localhost:3000,我会收到以下消息: The f
我使用 VS 2012 默认模板创建了 MVC4 移动应用程序。使用 http://localhost/mvcapplication1/ 在桌面浏览器中运行良好但是当我尝试在 WP8 Emulator
如何将默认的 xampp localhost c:xampp/htdoc 更改为另一个文件夹,即 c:/alan?当我使用 IP 地址时,我应该能够在 C:/alan 中查看我的网站文件。 感谢您帮助
我正在使用带有centos版本6(Fedora)的Vmware。我正在使用hadoop 1.0.4版本。我的 http://localhost:50070 地址显示为“无法连接”,但是 http://
我正在运行带有 apache 2.4.38 和 Maria DB 10.1.38 + PHP 7.3.3 的 Windows Server 2016 有时,我可以看到(使用 netstat)从 127
尝试通过 SSH 连接到本地主机时的调试信息 ssh root@localhost -vvv 输出 OpenSSH_6.6.1、OpenSSL 1.0.1f 2014 年 1 月 6 日debug1:
我正在使用 Node 和 Laravel 编写一个应用程序。我正在运行小型 laravel 本地服务器,该服务器解析为 http://localhost:8000 。我还在 localhost:300
我是一名优秀的程序员,十分优秀!