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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【Javaweb】基础开发流程与介绍

JavaWeb基础开发流程


1.确定系统和功能

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

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

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

2.设计数据库

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

q2.png

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

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

我使用的Maven,需要添加

<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.28</version>
</dependency>

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<Pet> 成功返回以宠物对象构成的列表,失败返回null
 */
public static List<Pet> getPetInfo(){
    Connection connection = null;
    PreparedStatement ps = null;
    ResultSet rs =null;
    List<Pet> list = new ArrayList<Pet>() {
    };
    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" %>
<!DOCTYPE html>
<html>
<head>
  <title>宠物管理系统</title>
  <!-- 新 Bootstrap5 核心 CSS 文件 -->
  <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/5.1.1/css/bootstrap.min.css">
  <!-- 最新的 Bootstrap5 核心 JavaScript 文件 -->
  <script src="https://cdn.staticfile.org/twitter-bootstrap/5.1.1/js/bootstrap.bundle.min.js"></script>
  <style>
    img{
      width:200px;
      height: auto;
      margin: 0 auto;
    }
    .control{
      margin:5px;
    }
  </style>
</head>
<body>
<%
  List<Pet> pets = PetUtil.getPetInfo();
  System.out.println(pets);
%>
<nav class="navbar navbar-expand-sm bg-light justify-content-center">
  <h2>宠物管理系统</h2>
</nav>
<div class="control">
<button type="button" class="btn btn-success">刷新</button>
<button type="button" class="btn btn-success">新增</button>
</div>
<table class="table table-striped table-bordered table-hover">
  <thead>
    <th>编号</th>
    <th>类别</th>
    <th>品种</th>
    <th>姓名</th>
    <th>性别</th>
    <th>性格</th>
    <th>健康状况</th>
    <th>生日</th>
    <th>领养状态</th>
    <th>照片</th>
    <th>操作</th>
  </thead>
<%
  for (Pet pet : pets) {
%>
  <tr>
    <td><%=pet.getCode()%>
    </td>
    <td><%=pet.getType()%>
    </td>
    <td><%=pet.getKind()%>
    </td>
    <td><%=pet.getName()%>
    </td>
    <td>
      <%
        String gender="";
        if(pet.getGender()==0){
          gender="雌";
        }
        if(pet.getGender()==1){
          gender="雄";
        }
        if(pet.getGender()==2){
          gender="雌雄共同";
        }
        if(pet.getGender()==3){
          gender="雌雄不分";
        }
      %>
      <%=gender%>
    </td>
    <td><%=pet.getCharacter()%>
    </td>
    <td><%=pet.getHealth()%>
    </td>
    <td><%=pet.getBirth()%>
    </td>
    <td>
      <%
        String state="";
        if(pet.getState()==0){
        state="未被领养";
      }
        if(pet.getState()==1){
          state="已被领养";
        }
      %>
      <%=state%>
    </td>
    <td><img src=<%=pet.getPic()%> >
    </td>
    <td>
      <button type="button" class="btn btn-success">编辑</button>
      <button type="button" class="btn btn-warning">删除</button>
    </td>
  </tr>
  <%
    }
  %>
</table>
</body>
</html>

q1.png

9.美化前端

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

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

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7月前
|
存储 前端开发 JavaScript
基于JavaWeb实现停车场管理系统
基于JavaWeb实现停车场管理系统
122 1
|
7月前
|
前端开发 JavaScript Java
图书借阅管理平台|基于JavaWeb实现图书借阅系统
图书借阅管理平台|基于JavaWeb实现图书借阅系统
157 1
|
4月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
505 37
|
3月前
|
前端开发 Java 应用服务中间件
Javaweb学习
【10月更文挑战第1天】Javaweb学习
40 2
|
7月前
|
前端开发 Java 关系型数据库
JavaWeb开发简介
JavaWeb开发简介
71 0
|
3月前
|
安全 Java Android开发
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
94 5
|
4月前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
|
4月前
|
安全 Java Android开发
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
135 2
|
4月前
|
SQL JSON JavaScript
JavaWeb基础9——VUE,Element&整合Javaweb的商品管理系统
Vue 指令、生命周期、this和$、vue脚手架进行模块化开发/ElementUI框架、综合案例,element商品列表展示增删改查
JavaWeb基础9——VUE,Element&整合Javaweb的商品管理系统
|
7月前
|
SQL Java 数据库连接
JavaWeb Mapper代理开发
JavaWeb Mapper代理开发