学习服务器与数据库(3)

 本系列的学习的资料主要来自衷水木先生的博客,本节将调通服务器与数据库。

第一部分:MySQL准备
        之前我门已经安装好了 MySQL 数据库软件,但是还没有用过。我们将第三方管理软件,比如Navicat for MySQL(第一篇文章中给的下载链接中也给的是这个并附带了激活码)。Navicat 是不需要安装的,直接将文件夹解压到合适的位置后,打开目录下的 navicat.exe 即可运行,我在文件夹外附加了一个激活码。


打开主界面,空的——在左侧管理区域右键-新建连接:


        如下图,
        连接名是自己起的名字;
        主机名或IP地址是 MySQL 安装的主机地址,如果是本机可以直接用localhost或者127.0.0.1;
        端口号是安装 MySQL 时指定的端口号,默认是3306(如果手贱改过或忘了,可以百度一下MySQL配置文件查看一下);
        用户名、密码就是安装MySQL时创建的用户名密码,也可以是添加的用户名密码,这个我们之前说过。


 左下角有“连接测试”,记得测试一下:


  这样就成功了!

        如果遇到下边提示:
        1045 - Access denied for user 'xxx'@'localhost'(useing password:YES) :用户名、密码错误;
        2005 - Unknown MySQL server host 'localhost'(11004) :主机地址不对;
        2001 - Can't connect to MySQL server on 'localhost'(10061) : 端口号有问题,或者 MySQL 服务没开;

        特别提醒:连接数据库之前,请一定记得打开 MySQL 服务,资源管理器>服务>MySQL57>右键-开启服务:


 OK,连接成功后,新建数据库:


   右键,新建数据库,新建表:



     表名:table_user_password


表名:table_user_info


  第二部分:Servlet 操作 MySQL

        OK!MySQL准备好了,下面我们来从 Servlet 中连接 MySQL。这怎么连疑问?我们肯定没法自己连,还是需要借助 MySQL 的驱动,其实就是一个.jar包。直接上MySQL 官网下载 http://dev.mysql.com/downloads/connector/j/ 下载最靠谱。(不过可能有 MySQL 版本和驱动版本不匹配的问题,我是没有遇到,但是根据经验应该会有这样的问题,所以要是 MySQL 版本太老的话还是更新吧,毕竟新版本修复和优化了不少):


 Connector/J 就是 connector for Java 。

        文件解压后如图:


  用的就是这个.jar文件,复制到 WebContent > WEB-INF > lib 文件夹下,并Add to build Path。接下来就可以直接用了。顺便说一下,docs 目录下有文档可以使用,不会了就去看文档,什么都有,包括下面用到的数据库连接代码。
        我们在上次的工程中新建 DBUtil 数据库连接工具类,代码如下:
        DBUtil.java:

package servlet;

import java.sql.DriverManager;
import java.sql.SQLException;

import com.mysql.jdbc.Connection;

public class DBUtil {
	// table
	public static final String Table_Account = "table_user_password";
	public static final String TABLE_USERINFO = "table_user_info";

	// connect to MySql database
	public static Connection getConnect() {
		String url = "jdbc:mysql://localhost:3306/first_mysql_test"; // 数据库的Url
		Connection connecter = null;
		try {
			Class.forName("com.mysql.jdbc.Driver"); // java反射,固定写法
			connecter = (Connection) DriverManager.getConnection(url, "root", "password"); //自己的帐号与密码
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		} catch (SQLException e) {
			System.out.println("SQLException: " + e.getMessage());
			System.out.println("SQLState: " + e.getSQLState());
			System.out.println("VendorError: " + e.getErrorCode());
		}
		return connecter;
	}
}

编写调试打印工具库LogUtil

LogUtil.java

package servlet;

public class LogUtil {
    public static final boolean DEBUG = true;

    public static void e(Object o) {
        if (DEBUG)
        	System.out.println("TAG :打印:------      " + o.toString());
    }

    public static void log(String o) {
        if (DEBUG)
        	System.out.println("TAG :打印:------      " + o);
    }

    public static void e(int i) {
        if (DEBUG)
        	System.out.println("TAG :打印:------      " + i);
    }

    public static void e(float i) {
        if (DEBUG)
        	System.out.println("TAG :打印:------      " + i);
    }

    public static void e(boolean b) {
        if (DEBUG)
        	System.out.println("TAG :打印:------      " + b);
    }
}

这就是最简单的使用,每次访问数据库时获取一个连接,然后进行读写,比如我们新建一个 RegisterServlet ,用来处理用户注册业务:

RegisterServlet.java:

package servlet;

import java.io.IOException;
import java.sql.ResultSet;
import java.sql.SQLException;

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 com.mysql.jdbc.Connection;
import com.mysql.jdbc.Statement;

/**
 * Servlet implementation class RegisterServlet
 */
@WebServlet(description = "用于注册的Servlet", urlPatterns = { "/RegisterServlet" })
public class RegisterServlet extends HttpServlet {  
    private static final long serialVersionUID = 1L;  
  
    /** 
     * Default constructor. 
     */  
    public RegisterServlet() {  
        LogUtil.log("RegisterServlet construct...");  
    }  
  
    @Override  
    protected void service(HttpServletRequest request, HttpServletResponse response)  
            throws ServletException, IOException {  
        String method = request.getMethod();  
        if ("GET".equals(method)) {  
            LogUtil.log("请求方法:GET");  
            doGet(request, response);  
        } else if ("POST".equals(method)) {  
            LogUtil.log("请求方法:POST");  
            doPost(request, response);  
        } else {  
            LogUtil.log("请求方法分辨失败!");  
        }  
    }  
  
    /** 
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse 
     *      response) 
     */  
    protected void doGet(HttpServletRequest request, HttpServletResponse response)  
            throws ServletException, IOException {  
        String code = "";  
        String message = "";  
  
        String account = request.getParameter("account");  
        String password = request.getParameter("password");  
        LogUtil.log(account + ";" + password);  
  
        Connection connect = DBUtil.getConnect();  
        try {  
            Statement statement = (Statement) connect.createStatement();  
            String sql = "select userAccount from " + DBUtil.Table_Account + " where userAccount='" + account + "'";  
            LogUtil.log(sql);  
            ResultSet result = statement.executeQuery(sql);  
            if (result.next()) { // 能查到该账号,说明已经注册过了  
                code = "100";  
                message = "Exit Account";  
            } else {  
                String sqlInsert = "insert into " + DBUtil.Table_Account + "(userAccount, userPassword) values('"  
                        + account + "', '" + password + "')";  
                LogUtil.log(sqlInsert);  
                if (statement.executeUpdate(sqlInsert) > 0) { // 否则进行注册逻辑,插入新账号密码到数据库  
                    code = "200";  
                    message = "Signup Success";  
                } else {  
                    code = "300";  
                    message = "Signup Failed";  
                }  
            }  
        } catch (SQLException e) {  
            e.printStackTrace();  
        }  
  
        response.getWriter().append("code:").append(code).append(";message:").append(message);  
    }  
  
    /** 
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse 
     *      response) 
     */  
    protected void doPost(HttpServletRequest request, HttpServletResponse response)  
            throws ServletException, IOException {  
  
    }  
  
    @Override  
    public void destroy() {  
        LogUtil.log("RegisterServlet destory.");  
        super.destroy();  
    }  
}
我们运行工程,浏览器请求 
http://localhost:8080/TeachingServer/RegisterServlet?account=177&password=123456,看结果:



为了检验我们的注册逻辑,我们试试把同样的请求再发一遍(按预想,应该是返回注册失败,因为已经有一个同样的账号注册过了):


就这样就可以了,最简单的使用!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值