【Javaweb】基础开发流程与介绍

本文档写于2022年7月29日,由于个人水平有限,可能存在一些问题,因此仅供参考 @萌狼蓝天

JavaWeb基础开发流程

1.确定系统和功能

在此以“宠物管理系统”为例,要开发一个简单的宠物管理系统,功能如下:

(1)管理员需要通过登陆进入系统

(2)支持宠物信息的增加、查询、修改、删除

2.设计数据库

根据功能,分析应该存在两个数据表:一个用户信息表(此处的用户,指的是系统的使用者,也就是管理员)、一个宠物信息表

【Javaweb】基础开发流程与介绍_第1张图片

3.在IDEA中创建项目,导入所需Jar包

可以手动导入Jar包,如果使用了Maven管理工具的可以编辑pom.xml

我使用的Maven,需要添加



    mysql
    mysql-connector-java
    8.0.28

【Javaweb】基础开发流程与介绍_第2张图片

4.使用IDEA自带数据库工具的自带扩展脚本自动生成对象代码

https://www.bilibili.com/video/BV1od4y1m7vh

5.编辑配置文件,连接数据库

(1)在resource下创建jdbc.properties,内容如下

driverClass=com.mysql.cj.jdbc.Driver
jdbcUrl=jdbc:mysql://域名:3306/数据库名?zeroDateTimeBehavior=convertToNull
user=用户名
password=密码

zeroDateTimeBehavior=convertToNull是为了处理Date数据无效时产生的错误,写了这个之后,无效Date数据会自动转为Null

(2)创建JDBC工具类,用于连接数据库

package cc.mllt.jdbc;


import java.sql.*;
import java.util.ResourceBundle;

public class JDBCUtils {
    //私有化构造函数
    //防止外界直接创建对象
    private JDBCUtils(){}
    //提供静态方法getConnection
    //用来对外提供数据库连接对象

    /**
     *Connection 用来对外提供数据库连接对象
     * @return
     */
    public static Connection getConnection(){
        try{
            //0.读取文件属性
            ResourceBundle conf = ResourceBundle.getBundle("jdbc");
            //1.注册驱动
            Class.forName(conf.getString("driverClass"));
            //2.获取数据库连接
            String url = conf.getString("jdbcUrl");
            String user = conf.getString("user");
            String password = conf.getString("password");
            Connection conn = DriverManager.getConnection(url,user,password);
            return conn;
        }catch (Exception e){
            e.printStackTrace();
        }
        return null;
    }
    //提供静态方法close,用来释放资源

    /**
     *close 用来释放资源
     * @param rs
     * @param st
     * @param conn
     */
    public static void close(ResultSet rs, Statement st,Connection conn){
        //关闭结果资源集
        if(rs!=null){
            //防止空指针异常
            try{
                rs.close();
            }catch (SQLException e){
                e.printStackTrace();
            }finally {
                rs=null;//手动置空,等待GC回收
            }
        }
        //关闭传输器资源
        if(st!=null){
            //防止空指针异常
            try {
                st.close();
            }catch (SQLException e){
                e.printStackTrace();
            }finally {
                st = null;//手动置空,等待GC回收
            }
        }
        //关闭数据库连接资源
        if(conn!=null){
            //防止空指针异常
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }finally {
                conn=null;//手动置空,等待GC回收
            }
        }
    }

}

6.编写功能模块

在此以查询为例,编写查询数据的代码

/**
 * 获取所有宠物信息
 * @return List 成功返回以宠物对象构成的列表,失败返回null
 */
public static List getPetInfo(){
    Connection connection = null;
    PreparedStatement ps = null;
    ResultSet rs =null;
    List list = new ArrayList() {
    };
    try {
        connection = JDBCUtils.getConnection();
        String sql = "select * from pet";
        ps = connection.prepareStatement(sql);
        rs = ps.executeQuery();
        while (rs.next()){
            Pet pet = new Pet();
            pet.setCode(rs.getString(1));
            //1对应的是数据表中第一列的数据
            pet.setType(rs.getString(2));
            //1对应的是数据表中第二列的数据
            pet.setName(rs.getString(3));
            pet.setKind(rs.getString(4));
            pet.setGender(rs.getLong(5));
            pet.setCharacter(rs.getString(6));
            pet.setHealth(rs.getString(7));
            pet.setBirth(rs.getDate(8));
            pet.setPic(rs.getString(9));
            pet.setState(rs.getLong(10));
            list.add(pet);
        }
    } catch (SQLException e) {
        System.out.println(e);
        return null;
    }
    return list;
}

7.编写前端页面

可以先使用HTML写好模板,再迁移入JSP

8.前端获取后端数据并显示

<%@ page import="cc.mllt.Util.PetUtil" %>
<%@ page import="java.util.List" %>
<%@ page import="cc.mllt.dao.Pet" %>
<%@ page contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" %>



  宠物管理系统
  
  

  
  
  


<%
  List pets = PetUtil.getPetInfo();
  System.out.println(pets);
%>

<% for (Pet pet : pets) { %> <% } %>
编号 类别 品种 姓名 性别 性格 健康状况 生日 领养状态 照片 操作
<%=pet.getCode()%> <%=pet.getType()%> <%=pet.getKind()%> <%=pet.getName()%> <% String gender=""; if(pet.getGender()==0){ gender="雌"; } if(pet.getGender()==1){ gender="雄"; } if(pet.getGender()==2){ gender="雌雄共同"; } if(pet.getGender()==3){ gender="雌雄不分"; } %> <%=gender%> <%=pet.getCharacter()%> <%=pet.getHealth()%> <%=pet.getBirth()%> <% String state=""; if(pet.getState()==0){ state="未被领养"; } if(pet.getState()==1){ state="已被领养"; } %> <%=state%> >

【Javaweb】基础开发流程与介绍_第3张图片

9.美化前端

可以使用Bootstrap或者自己编写样式美化前端。

10.优化后端代码(逻辑算法等)

你可能感兴趣的:(#,【萌狼原创】Javaweb,java,mysql,mybatis,intellij-idea,数据库)