- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在使用 Java Servlet 开发 Web 应用程序。我正在尝试实现登录、注销和注册功能,但我对如何让一切正常工作感到有点困惑。这是登录页面的代码:
To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package hw5package;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;
import java.util.UUID;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
/**
*
* @author Tyler
*/
public class Login extends HttpServlet {
/**
* Processes requests for both HTTP
* <code>GET</code> and
* <code>POST</code> methods.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
try {
String driver = "oracle.jdbc.driver.OracleDriver";
String url = "jdbc:oracle:thin:@cci-ora02.uncc.edu:1521:class";
String username = "teverha4";
String password = "qwe123";
out.println("<html>");
out.println("<head>");
out.println("<title>ITIS 4166 Project</title>");
out.println("</head>");
out.println("<body>");
out.println("<div align='center'>");
out.println("<h1>ITIS 4166 Project - Login Page</h1>");
out.println("<h2>by: Tyler Everhart</h2>");
out.println("<br />");
out.println("<br />");
out.println("<br />");
out.println("<br />");
out.println("<table width='20%' border='1' cellspacing='1' cellpadding='1'>");
out.println("<form id='loginForm' name='loginForm' method='POST'>");
out.println("<tr>");
out.println("<td bgcolor='006F13' align='left' colspan='2'><b>Login</b></td>");
out.println("</tr>");
out.println("<tr>");
out.println("<td bgcolor='35D551' align='left'>Username:</td>");
out.println("<td bgcolor='35D551'>");
out.println("<input type='text' name='username' id='username' />");
out.println("</td>");
out.println("</tr>");
String passUsername = request.getParameter("username");
out.println("<tr>");
out.println("<td bgcolor='35D551' align='left'>Password:</td>");
out.println("<td bgcolor='35D551'>");
out.println("<input type='password' name='pwd' id='pwd' />");
out.println("</td>");
out.println("</tr>");
String passPwd = request.getParameter("pwd");
out.println("<tr>");
out.println("<td bgcolor='006F13' align='center' colspan='2'>");
out.println("<input type='submit' value='Submit' onclick='loginValidation()' /> ");
out.println("<input type='reset' value='Reset' />");
out.println("</td>");
out.println("</tr>");
out.println("</form>");
out.println("</table>");
out.println("<a href='Registration'>New User, Click Here to Register</a>");
out.println("</div>");
out.println("</body>");
out.println("</html>");
Class.forName(driver);
Connection connection = DriverManager.getConnection(url, username, password);
Statement statement = connection.createStatement();
String query = "SELECT UserName, PassWord FROM UserLogin";
ResultSet resultSet = statement.executeQuery(query);
HttpSession session = request.getSession(true);
while (resultSet.next()) {
if ((passUsername.equals(resultSet.getString("UserName")) && passPwd.equals(resultSet.getString("PassWord")))) {
String sessionID = UUID.randomUUID().toString();
session.setAttribute("username", passUsername);
session.setAttribute("sessionID", sessionID);
response.sendRedirect("Categories");
}
else if (passUsername.equals("") || passPwd.equals("")) {
out.println("Enter a username and password.");
}
else {
out.println("Either your username or password is incorrect or could not be found.");
out.println("Please try again, or click the link below to register.");
}
}
}
catch (ClassNotFoundException cnfe) {
System.err.println("Error loading driver: " + cnfe);
out.println("<tr>Error loading driver: " + cnfe + "</tr>");
}
catch (SQLException sqle) {
System.err.println("Error with connection: " + sqle);
out.println("<tr>Error with connection: " + sqle + "</tr>");
}
finally {
out.close();
}
}
// <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">
/**
* Handles the HTTP
* <code>GET</code> method.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}
/**
* Handles the HTTP
* <code>POST</code> method.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}
/**
* Returns a short description of the servlet.
*
* @return a String containing servlet description
*/
@Override
public String getServletInfo() {
return "Short description";
}// </editor-fold>
这是注册页面的代码:
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package hw5package;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;
import java.util.Random;
import java.util.UUID;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
/**
*
* @author Tyler
*/
public class Registration extends HttpServlet {
/**
* Processes requests for both HTTP
* <code>GET</code> and
* <code>POST</code> methods.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
try {
String driver = "oracle.jdbc.driver.OracleDriver";
String url = "jdbc:oracle:thin:@cci-ora02.uncc.edu:1521:class";
String username = "teverha4";
String password = "qwe123";
out.println("<html>");
out.println("<head>");
out.println("<title>ITIS 4166 Project</title>");
out.println("</head>");
out.println("<body>");
out.println("<div align='center'>");
out.println("<h1>ITIS 4166 Project - Registration Page</h1>");
out.println("<h2>by: Tyler Everhart</h2>");
out.println("<br />");
out.println("<br />");
out.println("<br />");
out.println("<br />");
out.println("<table width='25%' border='1' cellspacing='1' cellpadding='1'>");
out.println("<tr>");
out.println("<th bgcolor='006F13' align='left' colspan='2'>Register Account Information</th>");
out.println("</tr>");
out.println("<tr>");
out.println("<td bgcolor='35D551' align='left'>Requested Username:</td>");
out.println("<td bgcolor='35D551'>");
out.println("<form id='enterForm' name='enterForm'>");
out.println("<input type='text' name='requested_username' />");
out.println("</td>");
out.println("</tr>");
String passUsername = request.getParameter("requested_username");
out.println("<tr>");
out.println("<td bgcolor='35D551' align='left'>Password:</td>");
out.println("<td bgcolor='35D551'>");
out.println("<input type='password' name='pwd' />");
out.println("</td>");
out.println("</tr>");
String passPwd = request.getParameter("pwd");
out.println("<tr>");
out.println("<td bgcolor='35D551' align='left'>Confirm Password:</td>");
out.println("<td bgcolor='35D551'>");
out.println("<input type='password' name='pwd1' />");
out.println("</td>");
out.println("</tr>");
String passPwd1 = request.getParameter("pwd1");
out.println("<tr>");
out.println("<td bgcolor='006F13' align='center' colspan='2'>");
out.println("<input name='Submit' type='submit' value='Submit' /> ");
out.println("<input type='reset' value='Reset' />");
out.println("</td>");
out.println("</tr>");
out.println("</form>");
out.println("</table>");
out.println("</div>");
out.println("</body>");
out.println("</html>");
Class.forName(driver);
Connection connection = DriverManager.getConnection(url, username, password);
Statement statement = connection.createStatement();
HttpSession session = request.getSession();
if (passPwd.equals("") || passPwd1.equals("")) {
Integer registerError = Integer.valueOf(1);
session.setAttribute("registerError", registerError);
out.println("Please enter a valid password.");
}
else if (!passPwd.equals(passPwd1)) {
Integer registerError = Integer.valueOf(2);
session.setAttribute("registerError", registerError);
out.println("Your password and confirm password does not match.");
}
else {
String query2 = "INSERT INTO UserLogin (UserName, PassWord, StockAmt, TechnologyStock, UtilityStock) VALUES (?,?,?,?,?)";
PreparedStatement stmt = connection.prepareStatement(query2);
stmt.setString(1, passUsername);
stmt.setString(2, passPwd);
stmt.setInt(3, 0);
stmt.setInt(4, 0);
stmt.setInt(5, 0);
stmt.executeQuery();
session.setAttribute("sessionUsername", passUsername);
String sessionID = UUID.randomUUID().toString();
Random StockID1 = new Random();
StockID1.nextInt(10);
String insertDataSqlMicrosoft = "INSERT INTO StockInfo(StockID, UserID, Type, StockName, Owned, Price, Total) VALUES('" + StockID1 + "','" + passUsername + ",'Technology','Microsoft (MSFT)',0,32.75,0";
PreparedStatement stmtMicrosoft = connection.prepareStatement(insertDataSqlMicrosoft);
stmtMicrosoft.executeQuery();
Random StockID2 = new Random();
StockID2.nextInt(4);
String insertDataSqlIntel = "INSERT INTO StockInfo(StockID, UserID, Type, StockName, Owned, Price, Total) VALUES('" + StockID2 + "','" + passUsername + "','Technology','Intel (INTC)',0,26.75,0)";
PreparedStatement stmtIntel = connection.prepareStatement(insertDataSqlIntel);
stmtIntel.executeQuery();
Random StockID3 = new Random();
StockID3.nextInt(9);
String insertDataSqlDuke = "INSERT INTO StockInfo(StockID, UserID, Type, StockName, Owned, Price, Total) VALUES('" + StockID3 + "','" + passUsername + "','Utility','Duke Energy (DUK)',0,89.00,0";
PreparedStatement stmtDuke = connection.prepareStatement(insertDataSqlDuke);
stmtDuke.executeQuery();
Random StockID4 = new Random();
StockID4.nextInt(7);
String insertDataSqlCable = "INSERT INTO StockInfo(StockID, UserID, Type, StockName, Owned, Price, Total) VALUES('" + StockID4 + "','" + passUsername + "','Utility','Time Warner Cable (TWC)',0,30.00,0)";
PreparedStatement stmtCable = connection.prepareStatement(insertDataSqlCable);
stmtCable.executeQuery();
session.setAttribute("sessionID", sessionID);
response.sendRedirect("Categories");
}
}
catch (ClassNotFoundException cnfe) {
System.err.println("Error loading driver: " + cnfe);
out.println("<tr>Error loading driver: " + cnfe + "</tr>");
}
catch (SQLException sqle) {
System.err.println("Error with connection: " + sqle);
out.println("<tr>Error with connection: " + sqle + "</tr>");
} finally {
out.close();
}
}
// <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">
/**
* Handles the HTTP
* <code>GET</code> method.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}
/**
* Handles the HTTP
* <code>POST</code> method.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}
/**
* Returns a short description of the servlet.
*
* @return a String containing servlet description
*/
@Override
public String getServletInfo() {
return "Short description";
}// </editor-fold>
}
我解决了之前从数据库读取时遇到的问题,现在又遇到了新问题。当我输入我已经验证过的用户名和密码存在于数据库中时,我不会被重定向到我想去的页面。此外,当我尝试注册新用户时,我没有被重定向到该页面,而是收到一条错误消息:
连接错误:java.sql.SQLException: ORA-00917: 缺少逗号
注册人的用户名和密码被发送到数据库,但程序不会将您重定向到适当的页面。
最佳答案
检查您的驱动程序类和 URL 语法。
URL 连接的语法是
jdbc:oracle:thin:@//[HOST][:PORT]/SERVICE
这是我从 OracleFAQ 获得的工作示例.
import java.sql.*;
class Conn {
public static void main (String[] args) throws Exception
{
Class.forName ("oracle.jdbc.OracleDriver");
Connection conn = DriverManager.getConnection
("jdbc:oracle:thin:@//localhost:1521/orcl", "scott", "tiger");
// @//machineName:port/SID, userid, password
try {
Statement stmt = conn.createStatement();
try {
ResultSet rset = stmt.executeQuery("select BANNER from SYS.V_$VERSION");
try {
while (rset.next())
System.out.println (rset.getString(1)); // Print col 1
}
finally {
try { rset.close(); } catch (Exception ignore) {}
}
}
finally {
try { stmt.close(); } catch (Exception ignore) {}
}
}
finally {
try { conn.close(); } catch (Exception ignore) {}
}
}
}
还有一些我想提出的建议。
要找到正确的主机名/端口/服务,请检查 tnsnames.ora 文件。检查OracleFAQ
这里还有一些链接可以帮助您入门:
http://docs.oracle.com/cd/B13789_01/java.101/b10979/getsta.htm
http://docs.oracle.com/javase/tutorial/jdbc/basics/gettingstarted.html
http://www.oracle.com/technetwork/indexes/downloads/index.html
关于java - 连接错误 : java. sql.SQLException: ORA-00917: 缺少逗号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9612479/
我有一个字符串 "1,23,45,448.00",我想用小数点替换所有逗号,用逗号替换所有小数点。 我需要的输出是“1.23.45.448,00” 我尝试用 . 替换 , 如下: var mystri
我刚刚开始阅读 C。 情况: x = ( y = 3, ( z = ++y + 2 ) + 5 ) 它首先评估y = 3,然后评估( z =++y + 2) 我的问题: 它应该首先评估( z =++y
我是 VIM 初学者,我有一个奇怪的问题。我开始在终端模拟器中使用 vim,但今天我转向了 gVim。然后我意识到我不能在插入模式下写逗号!我试过 :map , , :imap ,都说没有找到映射。然
我上面有一个 JavaScript 正则表达式函数代码: function AcceptDigits(objtextbox) { var exp = /[^\d{1,3}]/g; ob
我需要使用 Java 的 split() 方法分割字符串。如何编写某个单词的分隔符的正则表达式模式?例如“和”? 我得到了分割空格和逗号的模式,即 [,\\s] 但我想添加单词 and ,以便它也成为
我们通常使用逗号来强调句子中的某些内容。但是说到搜索引擎优化,我只是想知道这是否有用,尤其是当标题标签或页面标题中所需的字符数有限(65到70个)以便爬虫读取时。我们是否需要使用逗号? 最佳答案 页面
我想找出每个学科学期的学生上课人数。以下是给出正确答案的查询 select semester,subject,count(stdId) from tblSubjectMaster group by s
int m = 5, d = 12, y = 1975, val; // May 12, 1975 谁能解释一下下面代码行中逗号运算符的功能/用途: val = (d+=m<3?y--:y-2
我不能在 Visual Studio 2013 中使用 Ctrl+, 和在 Windows 8.1 中使用 Pycharm。有没有办法找到哪个应用程序占用了这个快捷方式/热键? 我试过 Windows
我发现很难用谷歌搜索 powershell 中这两种执行方法调用的区别的答案。 : $member = "1.2.3.4:567" # IPaddress + port for demonstrati
谁能建议我如何在 emacs 中通过 n 逗号前进(或后退)? 我正在尝试浏览 CSV 文件 我知道我可以做类似的事情: C-u 100 M-f 但是能够在逗号上做更多的正则表达式会更准确 最佳答案
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
这是一个棘手的问题,我会尽力描述它。 我有一个文本输入,用户可以在标签中输入。 用户在输入中键入标签(例如“starcraft”)并按下逗号键后,我希望逗号之前的所有字符(即单词“starcraft”
我如何打印 csv 文件中逗号后的最后一个值,我想循环遍历该文件并打印出最后一个值: 数据: 20181016135716, 00-00-00-00-00-04, 10.0.0.1, 10.0.0.8
这个问题在这里已经有了答案: How to format the HH:mm:ss separators of a TimeSpan in a culture-aware manner? (3 个答
我想去掉除数字、$、逗号 (,) 之外的所有内容。 这只是 strip 字母 string Cadena; Cadena = tbpatronpos6.Text;
我已经在我的 xml 文件中创建了一个编辑文本。这是我的代码: 问题是在我的输出项目中它只能工作其中一个。只有点或只有逗号。怎么了 ?在模拟器中工作正常,只有在我的版本中没有。 最佳答案 我用不同
我正在尝试编写一个正则表达式来提取由空格分隔的单词(可选逗号 + 空格),从单词中删除“堆栈”前缀(如果有的话)。我正在尝试找到一个纯正则表达式解决方案,而无需对结果进行任何后处理或类似(如果可能)。
我正在尝试在数据库中插入一些数据,但遇到了一些麻烦。目前我无法将数据添加到我的表中,我不知道为什么。 我正在使用一些您不需要理解的通用方法,这适用于我的所有项目,并且在任何项目中都没有任何错误。 以下
我想从 json 中删除尾随逗号, { "key1": "value1", "object": { "key2": "value2", // <- remove comma },
我是一名优秀的程序员,十分优秀!