IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Web开发—简单的点餐管理系统 -> 正文阅读

[JavaScript知识库]Web开发—简单的点餐管理系统

本系统由bootstrap,eclipse和Mysql共同开发完成。其主要功能根据角色大致可分为

基于用户的登录注册,浏览菜品,添加修改购物车,查看以下单的订单信息,留言评论并查看所有人评论,查看并修改个人信息及密码等

基于管理员的有添加和修改菜品,查看所有用户订单信息,查看并管理所有用户的评论,查看所用用户信息,管理个人管理员信息等

1.数据库

作为一个点餐管理系统,大致建表如图

列数据这里贴出用户表的和购物车表

用户表

?购物车表

?2.前端

前端重要运用bootstrap框架以及font-awesome一些小插件来整体构建,这里只列出用户登录,和首页代码

登陆界面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%> 
<%
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+request.getContextPath()+"/";
%>
<!DOCTYPE html>
<html>
<head>
<base href="<%=basePath %>">
<meta charset="UTF-8">
<title>登陆</title>
<script type="text/javascript"
	src="<%=basePath%>/webjars/jquery/3.4.1/dist/jquery.min.js"></script>
<script type="text/javascript"
	src="<%=basePath%>/webjars/bootstrap/4.6.0/js/bootstrap.min.js"></script>
<link rel="stylesheet"
	href="<%=basePath%>/css/font-awesome-4.7.0/css/font-awesome.min.css">
<link rel="stylesheet" href="<%=basePath%>/css/img/Login.css" type="text/css">
<link rel="stylesheet"
	href="<%=basePath%>/webjars/bootstrap/4.6.0/css/bootstrap.min.css" type="text/css">
</head>
<body>
<script type="text/javascript">
	
</script>
<div class="container">
		<div style="position:absolute;top:20%;left:70%;height:400px;border-radius:25px" class="form row m-auto">
			<form action="<%=basePath %>/UserServlet" method="post" class="form-horizontal col-md-12">
				<p style="text-align:center">
				<a style='text-decoration:none;font-size:30px;color:black' href="#">欢迎登陆</a>
				<div class="col-md-12 col-md-12">	
					<div class="form-group">
						<i class="fa fa-user" aria-hidden="true"></i> <input
							class="form-control" type="text" name="username" 
							placeholder="请输入账号" onchange="this.value" required autofocus>
					</div>
					<div class="form-group">
						<i class="fa fa-keyboard-o" aria-hidden="true"></i> <input
							class="form-control" type="password" name="password"
						    placeholder="请输入密码" onchange="this.value" required>
					</div>
					<!--提示密码输入信息(输错了)-->
					<div class="form-group">
						<span id="msg" style="font-size: 15px; color: red">${requestScope.msg}</span>
					</div>	
					
					<div class="form-group">
						<br> <a style='text-decoration:none' href="<%=basePath%>/jsp/Register.jsp">没有账号?立即注册</a>
						<br>
						<br> <a style='text-decoration:none' href="<%=basePath%>/jsp/Login2.jsp">管理员登陆点这里</a>
					</div>
					<div class="form-group">
						<input type="submit" value="登陆" class="btn btn-success pull-right">
					</div>
				</div>
			</form>
		</div>
	</div>
</body>
</html>

实际效果

???????

首页代码

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>首页</title>
<%
    String path = request.getContextPath();
    String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/";
%>
<base href="<%=basePath%>">
<meta charset="UTF-8">
<script type="text/javascript"
	src="<%=basePath%>/webjars/jquery/3.4.1/dist/jquery.min.js"></script>
<script type="text/javascript"
	src="<%=basePath%>/webjars/bootstrap/4.6.0/js/bootstrap.min.js"></script>
<link rel="stylesheet"
	href="<%=basePath%>/css/font-awesome-4.7.0/css/font-awesome.min.css">
<link rel="stylesheet" href="<%=basePath%>/css/img/Index.css" type="text/css">
<link rel="stylesheet"
	href="<%=basePath%>/webjars/bootstrap/4.6.0/css/bootstrap.min.css" type="text/css">
</head>
<body>
		<nav class="navbar navbar-expand-md flex-top bg-dark navbar-dark" role="navigation">
		
				<div class="navbar-header col-md-12">
						<a href="#" class="navbar-brand">吃啥都香不信你就来</a>
						
						<ul class="nav navbar-nav pull-right">
							<li class="nav-item" role="presentation">
								<a style='color:white;text-decoration:none' class="white" href="#">当前用户:<span>${sessionScope.username}</span></a>
							</li>
						
							<li class="nav-item">
								<a style='color:white;text-decoration:none' href="<%=basePath%>/ExitServlet"><i class="fa fa-user-times"></i>退出登录</a><!-- 此处应该为退出注销类的调用 -->
							</li>
					</ul>
				</div>	
		</nav>
		
		<div class="container-fluid">
			<div class="row">
			
				<div style="padding:0;margin:0;height:147%" class="col-md-2 pageSidebar">
					<div class="list-group">
							<p style="text-align:center">
							<a href="<%=basePath%>/HotServlet" target="mainFrame" class="list-group-item list-group-item-action"><i class="fa fa-bars"></i>菜品信息</a>
							<a href="<%=basePath%>/PersonInfoServlet" target="mainFrame" class="list-group-item list-group-item-action"><i class="fa fa-address-card-o"></i>用户信息</a>
							<a href="<%=basePath%>/ShowBuycarServlet" target="mainFrame" class="list-group-item list-group-item-action"><i class="fa fa-shopping-cart"></i>购物车</a>
							<a href="<%=basePath%>/ShowReviewServlet" target="mainFrame" class="list-group-item list-group-item-action"><i class="fa fa-commenting"></i>留言板</a>
							<a href="<%=basePath%>/ShowOrderingListServlet" target="mainFrame" class="list-group-item list-group-item-action"><i class="fa fa-list-alt"></i>订单信息</a>
					</div>
					
				</div>
				
				<div style="padding:0;margin:0;height:147%" class="pageContent col-md-10 pull-right">
					<!-- 实时更新的菜品/信息/购物车网页 -->
					<iframe src="<%=basePath%>/HotServlet" id="mainFrame" name="mainFrame"></iframe>
				</div>
			</div>
		</div>
</body>
</html>

实际效果

?

?3.后台

关于后台主要按照分层思想,分为controller层,dao层以及service层

列出登录的servlet代码以及与数据库交互的sql语句和serivce代码

package cn.java.controller;

import java.io.IOException;
import java.io.UnsupportedEncodingException;

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 cn.java.service.UserService;
import cn.java.service.impl.UserServiceImpl;

@WebServlet("/UserServlet")
public class UserServlet extends HttpServlet {
	protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		//解决POST请求方式的中文乱码问题
		try {
			UserService us = new UserServiceImpl();
			request.setCharacterEncoding("utf-8");
			response.setCharacterEncoding("utf-8");
			response.setContentType("text/html; charset=utf-8");
			String username = request.getParameter("username");
			String password = request.getParameter("password");
			if(us.isUserExist(username, password))
			{
				request.getSession().setAttribute("username", username);
				request.getRequestDispatcher("/jsp/Index.jsp").forward(request, response);
			}
			else {
				request.setAttribute("msg", "用户名密码错误!");
				request.getRequestDispatcher("/Login.jsp").forward(request, response);
			}
		} catch (UnsupportedEncodingException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (ServletException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

	protected void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}
package cn.java.dao;

import java.util.List;
import java.util.Map;

public interface UserDao {

	Map<String, Object> getNum(String username, String password) throws Exception;

	Map<String, Object> isInsertable(String username) throws Exception;

	int insertRecord(String username, String password, String realname, String email, String address, String phonenum) throws Exception;

	Map<String, Object> showPersInfo(String username) throws Exception;

	Map<String, Object> isInsertable2(String username) throws Exception;

	Map<String, Object> getNum2(String username, String password) throws Exception;

	int insertRecord2(String username, String password, String realname, String email, String address, String phonenum)
			throws Exception;

	Map<String, Object> showPersInfo2(String username) throws Exception;

	int updateUserInfo(String username, String phonenum, String email, String address) throws Exception;

	int updateUserPwd(String username, String password) throws Exception;

	int updateUserInfo2(String username, String phonenum, String email, String address) throws Exception;

	int updateUserPwd2(String username, String password) throws Exception;

	Map<String, Object> showManagerInfo(String username) throws Exception;

	List<Map<String, Object>> getAllUsers() throws Exception;

}
package cn.java.dao;

import java.util.List;
import java.util.Map;

public interface UserDao {

	Map<String, Object> getNum(String username, String password) throws Exception;

	Map<String, Object> isInsertable(String username) throws Exception;

	int insertRecord(String username, String password, String realname, String email, String address, String phonenum) throws Exception;

	Map<String, Object> showPersInfo(String username) throws Exception;

	Map<String, Object> isInsertable2(String username) throws Exception;

	Map<String, Object> getNum2(String username, String password) throws Exception;

	int insertRecord2(String username, String password, String realname, String email, String address, String phonenum)
			throws Exception;

	Map<String, Object> showPersInfo2(String username) throws Exception;

	int updateUserInfo(String username, String phonenum, String email, String address) throws Exception;

	int updateUserPwd(String username, String password) throws Exception;

	int updateUserInfo2(String username, String phonenum, String email, String address) throws Exception;

	int updateUserPwd2(String username, String password) throws Exception;

	Map<String, Object> showManagerInfo(String username) throws Exception;

	List<Map<String, Object>> getAllUsers() throws Exception;

}

4.最终效果

添加菜品的购物车实现

?支付下单后的订单信息更新

?点击查看详情的效果

?留言板功能

用户修改个人信息

?管理员登录界面

?管理员首页以及当日菜品统计

?添加菜品效果

所有订单信息效果

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-18 11:06:33  更:2021-11-18 11:07:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 4:42:57-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码