组件技术--设计--MVC模式+DAO+MySQL+jsp+servlet 简单的购物车案例

news2025/3/4 16:01:04

MVC模式+DAO+MySQL+jsp+servlet 简单的购物车案例

        • 题外话
  • 购物车案例需求
      • 核心
      • 系统组成
    • Javaweb项目框架
      • 基本思想
  • 核心代码
    • Dao
      • BookDao
    • listener
      • SessionListener
    • servlet
      • AddServlet
      • InitServlet
      • RemoveServlet
    • vo
      • Book
    • .jsp
      • buyForm.jsp
      • showAllBook.jsp
      • showCart.jsp
    • target
      • pom.xml
    • WEB-INF
      • web.xml
    • lib
    • 运行

简单的购物车案例)

题外话

项目支持的教材 :Java web程序设计(第3版)微课视频版 主编郭克华老师······
教材的实训部分有好几个应用,这里主要是将私信很多提到的教材中讲到的【购物系统】这一实训核心代码进行整合。 展示结果也属于简单的购物车(复杂一点的购物车后续讲解,先把基本的增删查改了解清楚,美化展示的jsp界面也就不是什么问题)

购物车案例需求

本项目基于MVC模式制作的一个购物程序(简易),可以供用户在网页上订购教材。需要用到数据库,过滤器,监听器。

核心

1.将数据库查询的代码写在DAO内,然后用jsp调用DAO。DAO通过查询得到相应的结果,返回给用户。
2.将VO(value object)配合DAO来使用,在DAO中可以每查询到一条记录就将其封装为ursert对象,该对象属于VO。最后将所有实例化的VO 存放在集合内返回。这样就可以实现层次分开,降低耦合度。

:数据库需要MySQL来检查图书信息以及后续选购等的调用。
MySQL下载配置好后,可以直接在编辑器(我这里用的IDE,eclipse也可以)如下图建立并连接数据库进行编辑。当然也可以在MySQL里面建好架构,然后建表编辑数据也可以。

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

系统组成

本系统主要是3个页面组成:
1.运行系统,出现显示所有书本的界面。本界面中,标题是“欢迎选购图书”。界面上显示所有图书及价格,同时每种图书后面都有一个“购买”链接。
在这里插入图片描述

2.点击“购买”链接,会跳转到购买界面。(数量是手工输入)
在这里插入图片描述

3.输入购买数量并提交,能将所购买的书存入购物车。存入后跳转带显示购物车所有内容的界面。
在这里插入图片描述

Javaweb项目框架

在这里插入图片描述

基本思想

(1)基于MVC模式。思想步骤主要是:
用户在表单中输入,将表单提交给servlet,servlet验证输入,然后实例化Javabean。
Javabean查询数据库,查询结果暂存在Javabean中。
Servlet跳转到jsp,jsp使用Javabean,得到它里面的查询结果,并显示出来。
(2)本项目需要一个DAO来查询图书,一个VO来封装某一种图书信息。
购物车中的图书用集合来存储,这里使用HashMap来保存图书,可以进行比较方便地删除和访问。HashMap以key-value形式保存数据,这样可以将图书的key值设置成该图书的编号,在访问时候可以直接通过key值定位。
(3)设计一个listener监听器来使用户访问网站时购物车就可以进行初始化,也就是对session的内容进行初始化。
(4)用户先访问的是InitServlet,负责查询所有图书,然后跳转到showAllBook.jsp页面。若不先访问InitServlet,直接去访问showAllBook.jsp,会抛出异常。

核心代码

Dao

BookDao

负责查询图书,验证用户的合法身份:

package Dao;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.HashMap;
import vo.Book;

public class BookDao {
    private Connection conn = null;
    public HashMap getAllBook() throws Exception{
        HashMap hm = new HashMap();
        this.initConnection();
        Statement stat = conn.createStatement();
        String sql =
                "SELECT BOOKNO,BOOKNAME,BOOKPRICE FROM T_BOOK";
        ResultSet rs = stat.executeQuery(sql);
        while(rs.next()){
            Book book = new Book();
            book = new Book();
            book.setBookno(rs.getString("bookno"));
            book.setBookname(rs.getString("bookname"));
            book.setBookprice(rs.getFloat("bookprice"));
            hm.put(book.getBookno(),book);
        }
        this.closeConnection();
        return hm;
    }
    public void initConnection() throws Exception{
        Class.forName("com.mysql.cj.jdbc.Driver");
        conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/webdatabase?characterEncoding=utf-8&serverTimezone=GMT%2B8&useSSL=false", "root", "123456");
    }
    public void closeConnection() throws Exception{
        conn.close();
    }

}

listener

SessionListener

监听器,负责对session内容进行初始化:

package listener;

import java.util.HashMap;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;

public class SessionListener implements HttpSessionListener{
    public void sessionCreated(HttpSessionEvent event) {
        HttpSession session = event.getSession();
        //初始化购物车
        HashMap books = new HashMap();
        session.setAttribute("books",books);
        //初始化总钱数
        session.setAttribute("money",0F);
    }
    public void sessionDestroyed(HttpSessionEvent arg0) {}
}

servlet

AddServlet

将购买的图书存入购物车,跳转到showCart.jsp页面:

package servlet;

import java.io.IOException;
import java.util.HashMap;
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 javax.servlet.http.HttpSession;
import vo.Book;

@WebServlet("/AddServlet")

public class AddServlet extends HttpServlet {
	@Override
	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		// TODO Auto-generated method stub
		request.setCharacterEncoding("gb2312");
		HttpSession session = request.getSession();
		HashMap books = (HashMap) session.getAttribute("books");
		// 获取提交的内容
		String bookno = request.getParameter("bookno");
		String bookname = request.getParameter("bookname");
		String strBookprice = request.getParameter("bookprice");
		String strBooknumber = request.getParameter("booknumber");
		// 存入购物车
		Book book = new Book();
		book.setBookno(bookno);
		book.setBookname(bookname);
		float bookprice = Float.parseFloat(strBookprice);
		book.setBookprice(bookprice);
		int booknumber = Integer.parseInt(strBooknumber);
		book.setBooknumber(booknumber);
		books.put(bookno, book);
		// 总钱数增加
		float money = (Float) session.getAttribute("money");
		money = money + bookprice * booknumber;
		session.setAttribute("money", money);
		response.sendRedirect("showCart.jsp");
	}

}

InitServlet

查询所有图书,然后跳转到showAllBook.jsp页面:

package servlet;

import java.io.IOException;
import java.util.HashMap;
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 Dao.BookDao;
import vo.Book;

@WebServlet("/InitServlet")

public class InitServlet extends HttpServlet {
	@Override
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		BookDao bdao = new BookDao();
		HashMap allbook = null;
		try {
			allbook = bdao.getAllBook();
		} catch (Exception e) {
			e.printStackTrace();
		}
		request.getSession().setAttribute("allbook", allbook);
		response.sendRedirect("showAllBook.jsp");
	}
}

RemoveServlet

从购物车中删除某种图书,并跳转到showCart.jsp页面:

package servlet;

import java.io.IOException;
import java.util.HashMap;

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 javax.servlet.http.HttpSession;
import vo.Book;
@WebServlet("/RemoveServlet")

public class RemoveServlet extends HttpServlet {
	@Override
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		request.setCharacterEncoding("gb2312");
		String bookno = request.getParameter("bookno");

		HttpSession session = request.getSession();
		HashMap books = (HashMap)session.getAttribute("books");
		Book book = (Book)books.get(bookno);
		//总钱数减少
		float money = (Float)session.getAttribute("money");
		money = money - book.getBooknumber()*book.getBookprice();
		session.setAttribute("money", money);
		//移除相应图书
		books.remove(bookno);
		response.sendRedirect("showCart.jsp");
	}
}

vo

Book

VO类封装图书的信息:

package vo;

public class Book {
    private String bookno;
    private String bookname;
    private float bookprice;
    private int booknumber;
    public String getBookno() {
        return bookno;
    }
    public void setBookno(String bookno) {
        this.bookno = bookno;
    }
    public String getBookname() {
        return bookname;
    }
    public void setBookname(String bookname) {
        this.bookname = bookname;
    }
    public float getBookprice() {
        return bookprice;
    }
    public void setBookprice(float bookprice) {
        this.bookprice = bookprice;
    }
    public int getBooknumber() {
        return booknumber;
    }
    public void setBooknumber(int booknumber) {
        this.booknumber = booknumber;
    }
}

.jsp

buyForm.jsp

显示买书页面:

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@page import="vo.Book"%>
<html>
<head>
	<title>buyForm</title>
</head>
<body>
<%
	String bookno = request.getParameter("bookno");
	HashMap allbook = (HashMap)session.getAttribute("allbook");
	Book book = (Book)allbook.get(bookno);
%>
欢迎购买:<%=book.getBookname()%>
<form action="AddServlet" method="post">
	<!-- 表单提交到AddServlet.java -->
	书本价格:<%=book.getBookprice()%><BR>
	<input name="bookno" type="hidden" value="<%=book.getBookno()%>">
	<input name="bookname" type="hidden" value="<%=book.getBookname()%>">
	<input name="bookprice" type="hidden" value="<%=book.getBookprice()%>">
	数量:
	<input name="booknumber" type="text">
	<input type="submit" value="购买">
</form>
</body>
</html>

showAllBook.jsp

显示所有图书:

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@page import="vo.Book"%>
<html>
<body>
欢迎选购图书<br>

<table border="1">
	<tr bgcolor="pink">
		<td>书本名称</td>
		<td>书本价格</td>
		<td>购买</td>
	</tr>
	<%
		HashMap allbook = (HashMap)session.getAttribute("allbook");

		Set set = allbook.keySet();
		Iterator ite = set.iterator();
		while(ite.hasNext()){
			String bookno = (String)ite.next();
			Book book = (Book)allbook.get(bookno);
	%>
	<tr bgcolor="yellow">
		<td><%=book.getBookname()%></td>
		<td><%=book.getBookprice()%></td>
		<td><a href="buyForm.jsp?bookno=<%=bookno%>">购买</a></td>
	</tr>
	<%} %>
</table>
<a href="showCart.jsp">查看购物车</a>
</body>
</html>

showCart.jsp

显示购物车中所有内容:

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@page import="vo.Book"%>
<html>
<body>
<table border="1">
	<tr bgcolor="pink">
		<td>书本名称</td>
		<td>书本价格</td>
		<td>数量</td>
		<td>删除</td>
	</tr>
	<%
		HashMap books = (HashMap)session.getAttribute("books");
		Set set = books.keySet();
		Iterator ite = set.iterator();
		while(ite.hasNext()){
			String bookno = (String)ite.next();
			Book book = (Book)books.get(bookno);
	%>
	<tr bgcolor="yellow">
		<td><%=book.getBookname()%></td>
		<td><%=book.getBookprice()%></td>
		<td><%=book.getBooknumber()%></td>
		<td><a href="RemoveServlet?bookno=<%=book.getBookno()%>">删除</a></td>
	</tr>
	<%
		}
	%>
</table>
现金总额:<%=session.getAttribute("money")%><HR>
<a href="showAllBook.jsp">继续买书</a>
</body>
</html>

target

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
   https://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.companyname.bank</groupId>
    <artifactId>consumerBanking</artifactId>
    <packaging>jar</packaging>
    <version>1.0-SNAPSHOT</version>
    <name>consumerBanking</name>
    <url>https://maven.apache.org</url>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.38</version>
        </dependency>


        <!-- https://mvnrepository.com/artifact/javax.servlet.jsp.jstl/jstl-api -->
        <!--JSTL表达式的依赖-->
        <dependency>
            <groupId>javax.servlet.jsp.jstl</groupId>
            <artifactId>jstl-api</artifactId>
            <version>1.2</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/taglibs/standard -->
        <!--standard标签库-->
        <dependency>
            <groupId>taglibs</groupId>
            <artifactId>standard</artifactId>
            <version>1.1.2</version>
        </dependency>
    </dependencies>
</project>

WEB-INF

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"
         metadata-complete="true">


    <display-name>Welcome to Tomcat</display-name>
    <description> Welcome to Tomcat </description>
    <!--在该位置添加关于一个信息 -->

    <listener>
        <listener-class>listener.SessionListener</listener-class>
    </listener>
    <servlet>
        <description>This is the description of my J2EE component</description>
        <display-name>This is the display name of my J2EE component</display-name>
        <servlet-name>InitServlet</servlet-name>
        <servlet-class>servlet.InitServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>InitServlet</servlet-name>
        <url-pattern>/InitServlet</url-pattern>
    </servlet-mapping>
    <servlet>
        <description>This is the description of my J2EE component</description>
        <display-name>This is the display name of my J2EE component</display-name>
        <servlet-name>AddServlet</servlet-name>
        <servlet-class>servlet.AddServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>AddServlet</servlet-name>
        <url-pattern>/AddServlet</url-pattern>
    </servlet-mapping>

    <servlet>
        <description>This is the description of my J2EE component</description>
        <display-name>This is the display name of my J2EE component</display-name>
        <servlet-name>RemoveServlet</servlet-name>
        <servlet-class>servlet.RemoveServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>RemoveServlet</servlet-name>
        <url-pattern>/RemoveServlet</url-pattern>
    </servlet-mapping>



    <welcome-file-list>
        <welcome-file>buyForm.jsp</welcome-file>
    </welcome-file-list>
    <welcome-file-list>
        <welcome-file>showAllBook.jsp</welcome-file>
    </welcome-file-list>
    <welcome-file-list>
        <welcome-file>showCart.jsp</welcome-file>
    </welcome-file-list>
</web-app>

lib

需要的lib包请在Tomcat下的lib包里复制,没有的去网上下载。
在这里插入图片描述
在这里插入图片描述

运行

URL:http://localhost:8080/InitServlet

(用户首先访问的是InitServlet)
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/104298.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

python绘图——坐标轴

1. 2D坐标轴 1.1 绘制简单的曲线 import matplotlib.pyplot as plt import numpy as np xnp.linspace(-1,1,50)#-1到1中画50个点 yx**2 plt.plot(x,y,colorgreen) plt.tick_params(axisx,colorsblue) plt.tick_params(axisy,colorsred) plt.show()作图&#xff1a; 1.2 坐标…

游戏开发 LinkedList

inkedList底层是双向链表&#xff0c;一个节点挂着一个节点LinkedList不需要设定长度&#xff0c;不需要扩容LinkedList 的优缺点 优点 ① 往里面插入一些元素的时候不需要像ArrayList数组那样需要挪动大量的元素了&#xff0c;直接在链表里加入一个节点就可以了 ② 如果要不断…

【数据结构】LinkedList与双向链表

目录 一、认识集合类LinkedList 1、认识 2、构造方法 二、实现双向非循环链表 1、准备 2、方法的实现 1.遍历 2.有效节点个数 3.是否包含key 4.清空链表 5.头插法 6.尾插法 7.指定位置插入 8.删除第一次出现的key 9.删除所有的key 一、认识集合类LinkedList 1、认…

第01讲:Linux系统下Redis的安装及配置

本文所安装的Redis版本为5.0.4&#xff0c;请自行到官网下载&#xff0c;或者私信博主 前言&#xff1a;什么是Redis 介绍Redis之前&#xff0c;先了解下NoSQL &#xff08;Not only SQL&#xff09;不仅仅是SQL属于非关系型数据库&#xff1b;Redis就属于非关系型数据库传统的…

【AJAX】入门AJAX

入门AJAXAJAX概述AJAX的使用XMLHttpRequest创建XMLHttpRequest对象XMLHttpRequest对象的常用方法XMLHttpRequest对象的常用属性使用AJAX POST请求实现‘判断用户名’案例实现步骤模拟数据库表单前端代码后端程序效果展示AJAX概述 什么是AJAX&#xff1f; AJAX全称&#xff08;…

聊聊如何利用redis实现多级缓存同步

前言 前阵子参加业务部门的技术方案评审&#xff0c;故事的背景是这样&#xff1a;业务部门上线一个专为公司高管使用的系统。这个系统技术架构形如下图 按理来说这个系统因为受众很小&#xff0c;可以说基本上没并发&#xff0c;业务也没很复杂&#xff0c;但就是这么一个系…

【Java】做了个 Java 简洁版身材计算

前言 &#xff08;当前文章仅说明做了这个 身材计算 简洁版。&#xff09; 为了参加比赛 码上掘金编程后端挑战赛 (juejin.cn)… 我选择了做一个简洁版的身材计算… 效果展示 code - juejin 地址&#xff1a;身材计算&#xff08;Java版&#xff09; - 码上掘金 完整代码 …

RK3568平台开发系列讲解(环境篇)kernel编译及打包

🚀返回专栏总目录 文章目录 一、编译步骤二、编译脚本沉淀、分享、成长,让自己和他人都能有所收获!😄 📢此方法常用于 kernel 的开发和调试,以下的方法既编译 kernel 部分时, 同时打包成 boot.img, 这样加快了我们开发的速度; 一、编译步骤 进入内核目录下, 输入…

进阶中级前端必备知识点

1、从输入url到页面显示出来发生了什么 1.DNS解析 2.TCP连接 3.发送HTTP请求 4.服务器处理请求并返回需要的数据 5.浏览器解析渲染页面 解析HTML&#xff0c;生成DOM树&#xff0c;解析CSS&#xff0c;生成CSSOM树 将DOM树和CSSOM树结合&#xff0c;生成渲染树(Render T…

智能无障碍轮椅——DX-BT05 4.0蓝牙模块

文章目录常用的蓝牙模块有哪几种&#xff1f;蓝牙的透传蓝牙的运行模式开发方式AT指令集开发方式AT指令集BT-05调试硬件图DX-BT05 4.0蓝牙模块介绍连接步骤&#xff1a;常用的几个AT指令主模式的AT指令常用的蓝牙模块有哪几种&#xff1f; 蓝牙主要有HC-05、HC-06、BT-04、BT-…

SpringBoot整合mybatis实现增删改查、分页查询

前提&#xff1a; 先搭建出最基本的SpringBoot项目 SpringBoot框架快速入门搭建Hello World&#xff0c;请点击下面链接&#xff1a;https://blog.csdn.net/KangYouWei6/article/details/127018638 一、建立数据库 /*Navicat Premium Data TransferSource Server : 本地…

搜狗SEO优化技巧,搜狗收录批量查询技巧

搜狗SEO优化技巧 首先要知道搜索引擎的搜索原理&#xff0c;简而言之就是蜘蛛怎么爬取你的新网站&#xff0c;一般新的企业网站蜘蛛采取的是横向抓取&#xff0c;先收录首页&#xff0c;然后栏目页、子网页&#xff0c;这样一级一级的往下走&#xff0c;建网站用com域名。新…

设计测试用例的方法

设计测试用例的方法有很多&#xff0c;等价类划分法是重点&#xff0c;边界值分析法次之&#xff0c;对于因果图法知道概念就行&#xff0c;老师说考试不会考&#xff0c;但是历年考试中貌似考过一次&#xff0c;这就不知道了&#xff0c;反正考试大题基本课本例题&#xff0c;…

(十八)Vue之生命周期

文章目录引出生命周期外部的定时器实现生命周期实现生命周期详解挂载流程更新流程销毁流程总结Vue学习目录 上一篇&#xff1a;&#xff08;十七&#xff09;Vue之自定义指令 引出生命周期 先看一个需求&#xff1a;一上来就让一段文字的透明度循环从1-0-1的过程&#xff0c…

Fabric.js 文本自动换行的实现方式

本文简介 点赞 关注 收藏 学会了 在 fabric.js 提供的文本组件中&#xff0c;默认状态是不会自动换行。如果你的使用场景中需要自动文本自动换行&#xff0c;可以使用 Textbox &#xff0c;并将 splitByGrapheme 设置为 true 即可。 文本自动换行 如果需要实现本文自动换行…

盘点:保护企业数据安全的10种方法

即便是大型企业也无法防止网络攻击导致的数据泄露&#xff0c;但有多种保护数据安全的方法。 许多公司谨慎处理敏感信息&#xff0c;包括客户个人信息、企业财务记录和账户&#xff0c;以及企业暂时不想泄露的绝密项目&#xff0c;保持数据的安全至关重要。 全球知名企业发生了…

Java(十五)----Stream流

1 Stream流 1.1 Stream流的优势 Java8中有两大最为重要的改变。第一个是 Lambda 表达式&#xff1b;另外一个则是 Stream API。 Stream API ( java.util.stream) 把真正的函数式编程风格引入到Java中。这是目前为止对Java类库最好的补充&#xff0c;因为Stream API可以极大提…

11 深入了解InnoDB引擎

1. Innodb逻辑存储结构 表空间&#xff1a;ibd文件段segment&#xff1a;区extent&#xff1a;一个区大小为1m&#xff0c;里面有64个page页&#xff1b;为了保证页的连续性innodb会一次从磁盘申请4-5个区页page&#xff1a;一个page页大小为默认为16k行row&#xff1a;Trx id、…

深入探究Python上下文管理器

引子 上下文管理器是一种简化代码的有力方式&#xff0c;其内部也蕴含了很多Python的编程思想&#xff0c;今天我们就来探究一下Python的上下文管理器。 大家之前都知道&#xff0c;使用Python打开文件的时候最好要使用with语句&#xff0c;因为这样就算在文件操作中出现了异常…

基于java的校园共享自行车系统的设计与实现/校园共享单车管理系统

摘 要 伴随着社会以及科学技术的发展&#xff0c;互联网已经渗透在人们的身边&#xff0c;网络慢慢的变成了人们的生活必不可少的一部分&#xff0c;紧接着网络飞速的发展&#xff0c;管理系统这一名词已不陌生&#xff0c;越来越多的学校、公司等机构都会定制一款属于自己个…