利用HttpServlet完成MySql数据库my_user表的登录校验
创始人
2024-11-14 11:33:59
0

功能:利用HttpServlet完成MySql数据库my_user表的登录校验

step1:在porm.xml文件中导jdbc的依赖

mysql数据库输入

SELECT VERSION()

查询当前的数据库版本

 maven官网网址;https://mvnrepository.com/

maven官网中搜索:mySQL

并复制依赖粘贴到pom文件中

main函数下java包的class类

package com.iweb.demo03;  import org.apache.commons.codec.digest.DigestUtils;  import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.PrintWriter; import java.sql.SQLException; import java.util.List; import java.util.Map;  @WebServlet(value = "/login") public class Login extends HttpServlet {     @Override     protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {      }      @Override     protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {          req.setCharacterEncoding("utf-8");         resp.setCharacterEncoding("utf-8");         resp.setContentType("text/html");          PrintWriter pw = resp.getWriter();         String username = req.getParameter("username");         String password = req.getParameter("password");         password = DigestUtils.md5Hex(password);         String sql = "select count(*) cou from my_user m " +                 "where m.username=? and m.password=?";         List> list = null;         try {             list = JDBCUtill.jdbcBySelect(sql, username, password);         } catch (SQLException e) {             throw new RuntimeException(e);         } catch (ClassNotFoundException e) {             throw new RuntimeException(e);         }         Map map = list.get(0);         long cou = (long) map.get("cou");         String path="";         if (cou > 0) {             /* pw.print("欢迎您"+username);//页面跳转*/             /* resp.sendRedirect("/demo03/test5.html");*/         path=req.getContextPath() + "/test5.html";              System.out.println("登录成功");         } else {           path=req.getContextPath()+"/login.html?islogin=0";         }         resp.sendRedirect(path);     } } 

html文件 :

            用户登陆        

用户登陆

账号

密码



附录:

JDBC文件: 

package com.iweb.demo03;// // Source code recreated from a .class file by IntelliJ IDEA // (powered by FernFlower decompiler) //  import java.sql.*; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map;  public class JDBCUtill {     static Connection conn;     static PreparedStatement pstat;     static ResultSet rest;      public JDBCUtill() {     }      private static void getSource() throws SQLException, ClassNotFoundException {         Class.forName("com.mysql.cj.jdbc.Driver");         conn = DriverManager.getConnection("jdbc:mysql://192.168.77.100:3306/mysql?characterEncoding=utf-8", "root", "123456");     }      private static void closeSource() throws SQLException {         if (rest != null) {             rest.close();         }          if (pstat != null) {             pstat.close();         }          if (conn != null) {             conn.close();         }      }      public static List> jdbcBySelect(String sql) throws SQLException, ClassNotFoundException {         List> list = new ArrayList();         getSource();         pstat = conn.prepareStatement(sql);         rest = pstat.executeQuery();         ResultSetMetaData rsmd = rest.getMetaData();         int columnCount = rsmd.getColumnCount();          while(rest.next()) {             Map map = new HashMap();              for(int i = 1; i <= columnCount; ++i) {                 String columnName = rsmd.getColumnName(i);                 Object columnValue = rest.getObject(i);                 map.put(columnName, columnValue);             }              list.add(map);         }          closeSource();         return list;     }      public static List> jdbcBySelect(String sql, String username, String password) throws SQLException, ClassNotFoundException {         List> list = new ArrayList();         getSource();         pstat = conn.prepareStatement(sql);         pstat.setString(1, username);         pstat.setString(2, password);         rest = pstat.executeQuery();         ResultSetMetaData rsmd = rest.getMetaData();         int columnCount = rsmd.getColumnCount();          while(rest.next()) {             Map map = new HashMap();              for(int i = 1; i <= columnCount; ++i) {                 String columnName = rsmd.getColumnName(i);                 Object columnValue = rest.getObject(i);                 map.put(columnName, columnValue);             }              list.add(map);         }          closeSource();         return list;     }      public static  int updateBySql(String sql, E... e) throws SQLException, ClassNotFoundException {         getSource();         int res=0 ;         pstat = conn.prepareStatement(sql);          for(int i = 0; i < e.length; ++i) {             pstat.setObject(i + 1, e[i]);         }          res = pstat.executeUpdate();         closeSource();         return res;     } } 

上一篇:day_30

下一篇:VueRouter 相关信息

相关内容

热门资讯

wepower有外挂!hhpo... wepower有外挂!hhpoker德州有挂(透视)存在挂教程(有挂猫腻)-哔哩哔哩;1、超多福利:...
wepokeai机器人!wej... wepokeai机器人!wejoker透视方法(透视)细节揭秘(确实有挂)-哔哩哔哩;亲真的是有正版...
wepokeai代打的胜率!p... wepokeai代打的胜率!pokermaster脚本(透视)黑科技教程(有挂秘笈)-哔哩哔哩是一款...
wepoke黑科技!德普之星透... wepoke黑科技!德普之星透视辅助软件是真的(透视)教你攻略(有挂方略)-哔哩哔哩是一款可以让一直...
wepoke是真的有挂!hh ... wepoke是真的有挂!hh poker辅助有用(透视)细节方法(有挂功能)-哔哩哔哩;最新版202...
wepokeai代打逻辑!po... wepokeai代打逻辑!pokemmo手机版脚本免费(透视)透明教程(真的有挂)-哔哩哔哩;是一款...
wepoke有app软件!we... wepoke有app软件!wepoker辅助工具(透视)透牌教程(有挂分析)-哔哩哔哩;wepoke...
wepok软件透明挂!哈糖大菠... 【福星临门,好运相随】;wepok软件透明挂!哈糖大菠萝软件下载(透视)2025新版教程(揭秘有挂)...
七分钟了解!新畅游互娱科技(辅... 七分钟了解!新畅游互娱科技(辅助挂)详细透视开挂辅助新2025版(切实真的有挂)-哔哩哔哩;1、首先...
wepokeai代打逻辑!德州... wepokeai代打逻辑!德州hhpoker脚本(透视)辅助教程(有挂秘笈)-哔哩哔哩;是一款可以让...