web项目 maven下 使用servlet调用 mysql数据库

在登录界面的基础下,需要先配置 mysql 数据库,然后修改 Verify.java 就可以了,登陆界面项目:点击打开链接

首先建立简单的数据库和表:

 

CREATE TABLE users (  
userId INT PRIMARY KEY,  
username VARCHAR(20),  
passwd VARCHAR(20),  
grade INT);  
  
INSERT INTO `users` (`userId`, `username`, `passwd`, `grade`) VALUES('1','admin','123','1');  
INSERT INTO `users` (`userId`, `username`, `passwd`, `grade`) VALUES('2','hou','123','2');  
INSERT INTO `users` (`userId`, `username`, `passwd`, `grade`) VALUES('3','test','123','3');


然后通过登录界面,调用数据库判断,如果是数据库中的用户名,就在welcome页面输出用户名和密码。

 

 

package com.busymonkey;

import javax.servlet.ServletException;
import javax.servlet.http.*;
import java.io.*;
import java.sql.*;

public class Verify extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    public Verify() {
        super();
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    	Connection ct = null;
    	Statement sm = null;
    	ResultSet rs = null;
    	try {
        	String u=request.getParameter("username");
        	String p=request.getParameter("passwd");
        	
        	//数据库连接
        	Class.forName("com.mysql.jdbc.Driver");
        	//得到连接
        	ct = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/db_hou", "root", "123456");
        	//创建Statement
        	sm = ct.createStatement();
        	rs = sm.executeQuery("select * from users where username='"+u
        			+"' and passwd='"+p+"'");
        	
        	if (rs.next()) {
        		HttpSession hs = request.getSession(true);
        		hs.setMaxInactiveInterval(20);
        		hs.setAttribute("pass", "ok");
        		response.sendRedirect("welcome?uname=" + u + "&upass=" + p);
        	}
        	else {
        		response.sendRedirect("login");
        	}
        }
        catch (Exception ex) {
        	ex.printStackTrace();
        }finally{
        	try {
        		if (rs!=null) rs.close();
        		if (sm!=null) sm.close();
        		if (ct!=null) ct.close();
        	}
        	catch (Exception ex) {
        		ex.printStackTrace();
        	}
        }
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doGet(request, response);
    }

}


然后maven pom文件包括依赖

 

 

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.31</version>
</dependency>

 

这里注意一个问题,通常情况下maven自动下载的依赖会放到项目的 target 目录的项目文件夹下,但是在 tomcat 服务器启动是在 tomcat 安装目录下的 webapps 目录下,而在maven项目  install 的时候,是把 src 目录下的 WEB-INI 文件同步到 tomcat 安装文件夹下的 webapps 目录中,所以如果 tomcat 的 webapps 目录下,相对应启动的项目中没有同步lib依赖,那就把maven 项目中target中的lib依赖拷贝到src文件夹的main文件夹中的lib中,再进行maven install。这样就可以同步依赖文件了。

 

 

对于sql注入漏洞,修改的verify.java 代码如下:

 

package com.busymonkey;

import javax.servlet.ServletException;
import javax.servlet.http.*;
import java.io.*;
import java.sql.*;

public class Verify extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    public Verify() {
        super();
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    	Connection ct = null;
    	Statement sm = null;
    	ResultSet rs = null;
    	try {
        	String u=request.getParameter("username");
        	String p=request.getParameter("passwd");
        	
        	//数据库连接
        	Class.forName("com.mysql.jdbc.Driver");
        	//得到连接
        	ct = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/db_hou", "root", "123456");
        	//创建Statement
        	sm = ct.createStatement();
        	rs = sm.executeQuery("select * from users where username='"+u+"' and passwd='"+p+"'");
        	
        	if (rs.next()) {//next能进来说明用户是存在的
        		String dbPasswd = rs.getString("passwd");
        		if (dbPasswd.equals(p)) {
	        		HttpSession hs = request.getSession(true);
	        		hs.setMaxInactiveInterval(20);
	        		hs.setAttribute("pass", "ok");
	        		response.sendRedirect("welcome?uname=" + u + "&upass=" + p); 			
        		}
        		else
        		{
        			response.sendRedirect("login");
        		}
        	}
        	else {
        		response.sendRedirect("login");
        	}
        }
        catch (Exception ex) {
        	ex.printStackTrace();
        }finally{
        	try {
        		if (rs!=null) rs.close();
        		if (sm!=null) sm.close();
        		if (ct!=null) ct.close();
        	}
        	catch (Exception ex) {
        		ex.printStackTrace();
        	}
        }
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doGet(request, response);
    }

}

 

如果要用servlet显示图片,则在wel页面加入一句话即可,然后图片放到 tomcat下webapps下的项目文件夹中的WEB-INF文件夹下,新建一个imgs的文件夹,将图片放在里面即可:

 

 

package com.busymonkey;

import javax.servlet.ServletException;
import javax.servlet.http.*;
import java.io.*;

public class WelCome extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    public WelCome() {
        super();
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        HttpSession hs = request.getSession(true);
        String val = (String) hs.getAttribute("pass");//非法登陆返回空
        if ( val == null )
        {
        	try {
        		response.sendRedirect("login");
        	}
        	catch (Exception ex) {
        		ex.printStackTrace();
        	}
        }
    	String u = request.getParameter("uname");
        String p = request.getParameter("upass");
    	try {
        	PrintWriter pw = response.getWriter();
        	pw.println("<img src=./imgs/1.GIF ><br>");
        	pw.println("Welcome!!!! " + u + " pass=" + p);
        }
        catch (Exception ex) {
        	ex.printStackTrace();
        }
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doGet(request, response);
    }

}

 

 

 

 

 

 

 

 

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的实现: 1. 环境准备: - JDK - Tomcat - MySQL - IDEA 2. 创建一个Java web项目: - 在IDEA中选择File -> New -> Project - 选择Java Enterprise -> Web Application - 填写项目名称和路径 - 选择Tomcat服务器 - 选择Java EE版本 - 点击Next - 勾选Create web.xml - 点击Finish 3. 导入MySQL JDBC驱动: - 在IDEA中打开项目 - 右键单击项目 -> Open Module Settings -> Libraries - 点击+ -> From Maven - 在搜索框中输入mysql-connector-java - 选择最新版本 - 点击OK 4. 创建数据库和表: - 打开MySQL命令行或客户端 - 创建一个数据库:CREATE DATABASE db_test; - 创建一个表: CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `age` int(11) NOT NULL, `gender` varchar(10) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 5. 编写JavaBean: - 右键单击src目录 -> New -> Java Class - 命名为User - 添加属性:id、name、age、gender - 添加getter和setter方法 - 添加toString方法 6. 编写DAO层: - 右键单击src目录 -> New -> Package - 命名为dao - 右键单击dao包 -> New -> Java Class - 命名为UserDao - 添加方法:insert、delete、update、select - 在方法中使用JDBC连接数据库 7. 编写Servlet: - 右键单击src目录 -> New -> Package - 命名为servlet - 右键单击servlet包 -> New -> Java Class - 命名为UserServlet - 继承HttpServlet类 - 在doGet和doPost方法中调用DAO层方法并返回结果 8. 编写JSP页面: - 右键单击web目录 -> New -> JSP File - 命名为index.jsp - 在页面中添加HTML和JSP代码 - 调用Servlet方法并显示结果 以上是一个简单的实现,具体实现过程可以参考相关资料和API文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值