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

JavaWeb基础开发流程

1.确定系统和功能

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

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

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

2.设计数据库

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

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>

9.美化前端

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

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

【Javaweb】基础开发流程与介绍的更多相关文章

  1. Qt开发Activex笔记(一):环境搭建、基础开发流程和演示Demo

    前言   使用C#开发动画,绘图性能跟不上,更换方案使用Qt开发Qt的控件制作成OCX以供C#调用,而activex则是ocx的更高级形式.  QtCreator是没有Active控件项目的,所有需要 ...

  2. javaweb基础(10)_HttpServletRequest原理介绍

    一.HttpServletRequest介绍 HttpServletRequest对象代表客户端的请求,当客户端通过HTTP协议访问服务器时,HTTP请求头中的所有信息都封装在这个对象中,通过这个对象 ...

  3. [JavaWeb基础] 029.OGNL表达式介绍

    1.OGNL概述 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性,它旨在提供一个更高的更抽象的层次来对 ...

  4. AOS应用基础平台-模块开发流程

    AOS平台简单介绍 AOS应用基础平台基于JavaEE技术体系,以"标准功能可复用.通用模块可配置.行业需求高速开发.异构系统无缝集成"为目标.为软件开发团队提供高效可控.随需应变 ...

  5. javaweb基础(21)_两种开发模式

    SUN公司推出JSP技术后,同时也推荐了两种web应用程序的开发模式,一种是JSP+JavaBean模式,一种是Servlet+JSP+JavaBean模式. 一.JSP+JavaBean开发模式 1 ...

  6. 【转载】salesforce 零基础开发入门学习(二)变量基础知识,集合,表达式,流程控制语句

    salesforce 零基础开发入门学习(二)变量基础知识,集合,表达式,流程控制语句 salesforce如果简单的说可以大概分成两个部分:Apex,VisualForce Page. 其中Apex ...

  7. Linux下服务器端开发流程及相关工具介绍(C++)

    去年刚毕业来公司后,做为新人,发现很多东西都没有文档,各种工具和地址都是口口相传的,而且很多时候都是不知道有哪些工具可以使用,所以当时就想把自己接触到的这些东西记录下来,为后来者提供参考,相当于一个路 ...

  8. salesforce 零基础开发入门学习(九)Approval Process 介绍

    在阅读此篇文章前,可以先参考阅读一个前辈总结的关于Approval Process的操作.以下为参考的链接: http://www.cnblogs.com/mingmingruyuedlut/p/37 ...

  9. Android OpenSL ES 开发:Android OpenSL 介绍和开发流程说明

    一.Android OpenSL ES 介绍 OpenSL ES (Open Sound Library for Embedded Systems)是无授权费.跨平台.针对嵌入式系统精心优化的硬件音频 ...

  10. 以用户注册功能模块为例浅谈MVC架构下的JavaWeb开发流程

    JavaWeb应用开发,撇开分布式不谈,只讨论一个功能服务应用的开发,无论是使用原生的Servlet/JSP方案,还是时下的SSM架构,都有一套经过工程实践考验的最佳实践,这综合考虑了团队协作.项目管 ...

随机推荐

  1. 推荐一款轻量级 eBPF 前端工具 ply

    1 Overview ply 是 eBPF 的 front-end 前端工具之一,专为 embedded Linux systems 开发,采用 C 语言编写,只需 libc 和内核支持 BPF 就可 ...

  2. 墨天轮访谈 | IvorySQL王志斌—IvorySQL,一个基于PostgreSQL的兼容Oracle的开源数据库

    分享嘉宾:王志斌 瀚高IvorySQL产品经理 整理:墨天轮社区 导读 大家好,我是瀚高IvorySQL产品经理王志斌,IvorySQL是基于PostgreSQL的衍生开源项目. 我今天分享的内容主要 ...

  3. KubeSphere 社区双周报 | Java functions framework 支持 SkyWalking | 2023.8.4-8.17

    KubeSphere 社区双周报主要整理展示新增的贡献者名单和证书.新增的讲师证书以及两周内提交过 commit 的贡献者,并对近期重要的 PR 进行解析,同时还包含了线上/线下活动和布道推广等一系列 ...

  4. HTML标签 b 和 strong 的区别

    <b>标签和<strong>标签都表示加粗,效果通常是一样的: <b>:义演丁真<strong>:义演丁真 类似的还有<em>和<i& ...

  5. AOT漫谈专题(第七篇): 聊一聊给C#打造的节点依赖图

    一:背景 1. 讲故事 上一篇我们聊过AOT编程中可能会遇到的三大件问题,而这三大件问题又是考验你对AOT中节点图的理解,它是一切的原点,接下来我就画几张图以个人的角度来解读下吧,不一定对. 二:理解 ...

  6. 在centos7系统上安装docker环境

    基于 CentOS 7 安装 官网安装参考手册:https://docs.docker.com/install/linux/docker-ce/centos/ 确定你是CentOS7及以上版本 [ro ...

  7. nginx关于正向代理与反向代理的概念区分

    正向代理:如果把局域网外的 Internet 想象成一个巨大的资源库,则局域网中的客户端要访问 Internet,则需要通过代理服务器来访问,这种代理服务就称为正向代理. 反向代理 反向代理中客户端对 ...

  8. 洛谷 P1540 [NOIP2010 提高组] 机器翻译

    题目概括 给定 N 个整数,和一个容量为 M 的"字典",从头到尾依次翻译,每次翻译先看自家字典,没有的话再看别人的字典并存到自家字典,如果自家字典满了,当前单词的翻译会代替最早进 ...

  9. reg文件书写规则

    reg文件可以很方便地用来修改注册表,这里记录一下reg文件的书写规则. 注释 分号(;)后面的内容是注释,导入时会忽略这些内容. 文件基本格式 首行写: Windows Registry Edito ...

  10. Mysql篇-Buffer Pool中的三大链表

    为什么要有 Buffer Pool? 虽然说 MySQL 的数据是存储在磁盘里的,但是也不能每次都从磁盘里面读取数据,这样性能是极差的. 要想提升查询性能,那就加个缓存.所以,当数据从磁盘中取出后,缓 ...