实习笔记2

线上实习第二天回顾

今天是线上实习的第二天,在老师的带领下完成了一个简单的servlet项目开发(一个登录界面)。因为是第一次接触,很多地方不熟悉。今天还安装了tomcat服务器。

创建一个简单的Servlet项目(登陆界面)

项目过程

S1、新建一个Web Application项目,选择Tomcat服务器,勾选Create web.xml。
在这里插入图片描述

项目结构如下图在这里插入图片描述
S2、使用Navicat打开数据库,数据库数据和结构如下
在这里插入图片描述
S3、在WEB-INF文件夹中新建lib文件夹,里面放入以下jar包,add as library。
在这里插入图片描述
S4、源码
dao.userDao类源码

package com.zxy0721.dao;

import com.zxy0721.model.User;
import com.zxy0721.util.DBUtil;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class userDao {
    public User selectByName(String name){
        ResultSet rs = null;
        Connection conn = null;
        PreparedStatement pstmt = null;
        DBUtil util = new DBUtil();
        User user = new User();
        try{
            conn = util.getConnection();
            pstmt = conn.prepareStatement("select * from user where name =?");
            pstmt.setString(1,name);
            rs = pstmt.executeQuery();
            while (rs.next()){
                user.setId(rs.getInt(1));
                user.setName(rs.getString(2));
                user.setPassword(rs.getString(3));
                user.setAge(rs.getString(4));
            }
        }catch(Exception e){
            e.printStackTrace();
        }finally {
            try {
                util.closeAll(rs,pstmt,conn);
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        return user;
    }
}

model.User类源码:

package com.zxy0721.model;

public class User {
    private int id;
    private String name;
    private String password;
    private String age;
//alt+insert快捷生成getter setter
    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getAge() {
        return age;
    }

    public void setAge(String age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", password='" + password + '\'' +
                ", age='" + age + '\'' +
                '}';
    }
}

service.UserService类源码:

package com.zxy0721.service;

import com.zxy0721.dao.userDao;
import com.zxy0721.model.User;

public class UserService {
    userDao userdao = new userDao();
    public User selectByName(String name){
        return userdao.selectByName(name);

    }
}

servlet.LoginServlet类源码:

package com.zxy0721.servlet;

import com.zxy0721.model.User;
import com.zxy0721.service.UserService;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class LoginServlet extends HttpServlet {
    UserService userService = new UserService();
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException,IOException {
        String name = req.getParameter("name");
        String password = req.getParameter("password");
        User user = userService.selectByName(name);
        if(password.equals(user.getPassword())){
            resp.getWriter().write("success");
        }else{
            resp.getWriter().write("failed");
        }
    }
}

util.DBUtil类源码:

package com.zxy0721.util;


import java.sql.*;

public class DBUtil {
    public static Connection getConnection() throws ClassNotFoundException, SQLException {
        Class.forName("com.mysql.cj.jdbc.Driver");
        Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/asd?useSSL=false&serverTimezone=UTC","root","123456");
        return connection;
    }

    public static void closeAll(ResultSet rs, Statement stmt,Connection conn) throws SQLException {
        if(rs!=null){
            rs.close();
        }
        if(stmt!=null){
            stmt.close();
        }
        if(conn!=null){
            conn.close();
        }
    }
}

web.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">
    <servlet>
        <servlet-name>loginServlet</servlet-name>
        <servlet-class>com.zxy0721.servlet.LoginServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>loginServlet</servlet-name>
        <url-pattern>/login</url-pattern>
    </servlet-mapping>
</web-app>

index.jsp文件:

<%--
  Created by IntelliJ IDEA.
  User: lenovo
  Date: 2020/7/21
  Time: 8:48
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>$Title$</title>
  </head>
  <body>
  <h1>登陆界面</h1>
  <form action="/login" method = "post">
    name:<input name="name" type = "text">
    password:<input name = "password" type = "password">
    <input type="submit" value = "登录">
  </form>
  </body>
</html>

运行结果

1、登陆界面
在这里插入图片描述
2、登陆成功
在这里插入图片描述
3、登陆失败
在这里插入图片描述

一些知识点

各包的划分

1、model包存储数据库实体对象,此处为User类。
2、util包下DBUtil类用来连接数据库。
3、dao包,包含了各种数据库的操作方法。
4、service包,创建UserService类,提供前台服务。
5、servlet包,创建LoginServlet类,用于实现用户登录判断。

什么是Servlet

Servlet(Server Applet),全称Java Servlet,未有中文译文。是用Java编写的服务器端程序。其主要功能在于交互式地浏览和修改数据,生成动态Web内容。狭义的Servlet是指Java语言实现的一个接口,广义的Servlet是指任何实现了这个Servlet接口的类,一般情况下,人们将Servlet理解为后者。

Servlet运行于支持Java的应用服务器中。从实现上讲,Servlet可以响应任何类型的请求,但绝大多数情况下Servlet只用来扩展基于HTTP协议的Web服务器。
servlet详解

什么是Tomcat

Tomcat是一个实现了JAVA EE标准的最小的WEB服务器,是Apache 软件基金会的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。因为Tomcat 技术先进、性能稳定,而且开源免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。学习JavaWeb开发一般都使用Tomcat服务器,该服务器支持全部JSP以及Servlet规范
1、Tomcat学习总结
2、Tomcat的使用(详细流程)

http常见状态码

当我们从客户端向服务器发送请求时
服务器向我们返回状态码
状态码就是告诉我们服务器响应的状态
通过它,我们就可以知道当前请求是成功了还是出现了什么问题
服务器返回的14种常见HTTP状态码

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值