利用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 相关信息

相关内容

热门资讯

绝活儿辅助!广西老友玩老是输怎... 绝活儿辅助!广西老友玩老是输怎么办(辅助挂)都是真的有辅助app(讲解有挂)在进入广西老友玩老是输怎...
法门辅助!福建13水插件(辅助... 法门辅助!福建13水插件(辅助挂)一贯是有辅助技巧(有挂技术)1、许多玩家不知道福建13水插件辅助怎...
办法辅助!潮友会app下载官方... 办法辅助!潮友会app下载官方辅助器(辅助挂)真是真的是有辅助app(有挂教程)该软件可以轻松地帮助...
妙招辅助!邯郸胡乐挂辅助(辅助... 妙招辅助!邯郸胡乐挂辅助(辅助挂)好像存在有辅助插件(有挂方略)1、上手简单,内置详细流程视频教学,...
教程书辅助!乐酷辅助(辅助挂)... 教程书辅助!乐酷辅助(辅助挂)其实存在有辅助脚本(有挂细节)乐酷辅助能透视中分为三种模型:乐酷辅助模...
学习辅助!决战卡五星辅助(辅助... 学习辅助!决战卡五星辅助(辅助挂)本来真的是有辅助软件(有人有挂)学习辅助!决战卡五星辅助(辅助挂)...
绝活辅助!边锋嘉兴麻将辅助器(... 绝活辅助!边锋嘉兴麻将辅助器(辅助挂)真是真的有辅助神器(新版有挂)1、边锋嘉兴麻将辅助器公共底牌简...
举措辅助!枫叶辅助器(辅助挂)... 举措辅助!枫叶辅助器(辅助挂)本来存在有辅助技巧(竟然有挂)1、下载好枫叶辅助器正确养号方法之后点击...
讲义辅助!点我达辅助(辅助挂)... 讲义辅助!点我达辅助(辅助挂)一直存在有辅助技巧(有人有挂)1、点我达辅助辅助器安装包、点我达辅助辅...
模块辅助!威信茶馆有挂的吗(辅... 模块辅助!威信茶馆有挂的吗(辅助挂)一直真的是有辅助脚本(揭秘有挂)1、玩家可以在威信茶馆有挂的吗线...