使用express实现一个简易的学生管理系统(使用文件存储)

使用express实现一个简易的学生管理系统

使用express实现一个简易的学生管理系统,增删改查学生数据(使用的是文件存储学生数据,之后还会使用mysql进行存储
mysql版本地址: https://blog.csdn.net/qq_40639292/article/details/107341182.

项目代码结构

在这里插入图片描述

项目使用到的插件package.json

{
  "name": "2express-students",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "dependencies": {
    "art-template": "^4.13.2",
    "body-parser": "^1.19.0",
    "bootstrap": "^3.4.1",
    "express": "^4.17.1",
    "express-art-template": "^1.0.1",
    "jquery": "^3.5.1"
  }
}

项目准备

​生成package.json文件 【npm init】

安装express,使用命令【npm install express】

安装 art-template
	npm install --save art-template
	npm install --save express-art-template

安装body-parser npm i body-parser -s
该项目使用的是 bootStrap 所以需要安装bootstrap
	npm install bootstrap@3

页面显示

首页

界面展示

在这里插入图片描述

代码

<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
    <title>学生管理</title>

    <!-- Bootstrap -->
    <link href="/node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
</head>

<body>
    <div style="padding: 20px;">
        <div style="padding: 10px 0;">
            <a href="/students/new" type="button" class="btn btn-primary btn-sm">添加学生</a>
        </div>
        <table class="table table-striped table-bordered table-hover">
            <tr>
                <th>姓名</th>
                <th>年龄</th>
                <th>性别</th>
                <th>操作</th>
            </tr>
            {{each students}}
            <tr>
                <td>{{$value.name}}</td>
                <td>{{$value.age}}</td>
                <td>{{$value.sex}}</td>
                <td style="display: none">{{$value.id}}</td>
                <td>
                    <a href="/students/delete?id={{$value.id}}" type="button" class="btn btn-danger btn-xs" >删除</a>
                    <a href="/students/edit?id={{$value.id}}" type="button" class="btn btn-info btn-xs"> 编辑</a>
                </td>
            </tr>
            {{/each}}
        </table>
    </div>


    <!-- jQuery (Bootstrap 的所有 JavaScript 插件都依赖 jQuery,所以必须放在前边) -->
    <script src="/node_modules/jquery/dist/jquery.min.js"></script>
    <!-- 加载 Bootstrap 的所有 JavaScript 插件。你也可以根据需要只加载单个插件。 -->
    <script src="/node_modules/bootstrap/dist/js/bootstrap.min.js"></script>
</body>
</html>
<script>
</script>

添加学生页

界面展示

在这里插入图片描述

代码

<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
    <title>Bootstrap 101 Template</title>

    <!-- Bootstrap -->
    <link href="/node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
</head>

<body>
    <div style="padding: 20px;">
        <form action="/students" method="POST">
            <div class="form-group">
                <label for="exampleInputEmail1">姓名:</label>
                <input type="text" name="name" class="form-control" id="exampleInputEmail1" placeholder="姓名">
            </div>
            <div class="form-group">
                <label for="exampleInputPassword1">年龄:</label>
                <input type="text" name="age" class="form-control" id="exampleInputPassword1" placeholder="年龄">
            </div>
            <div class="radio">
                <label>
                    <input type="radio" name="sex" id="optionsRadios1" value="" checked></label>
                <label>
                    <input type="radio" name="sex" id="optionsRadios2" value=""></label>
            </div>
            <button type="submit" class="btn btn-default">提交</button>
        </form>
    </div>
    <!-- jQuery (Bootstrap 的所有 JavaScript 插件都依赖 jQuery,所以必须放在前边) -->
    <script src="/node_modules/jquery/dist/jquery.min.js"></script>
    <!-- 加载 Bootstrap 的所有 JavaScript 插件。你也可以根据需要只加载单个插件。 -->
    <script src="/node_modules/bootstrap/dist/js/bootstrap.min.js"></script>
</body>

</html>

修改页

界面展示

在这里插入图片描述

代码

<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
    <title>Bootstrap 101 Template</title>

    <!-- Bootstrap -->
    <link href="/node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
</head>

<body>
<div style="padding: 20px;">

    <form action="/students/edit" method="POST">
        <div class="form-group">
            <label for="exampleInputEmail1" name="name">姓名:</label>
            <input type="text" name="name" class="form-control" id="exampleInputEmail1" placeholder="姓名"
                   value="{{student.name}}">
        </div>
        <div class="form-group">
            <label for="exampleInputPassword1">年龄:</label>
            <input type="text" name="age" class="form-control" id="exampleInputPassword1" placeholder="年龄"
                   value="{{student.age}}">
        </div>
        <div class="radio">
            <label>
                <input type="radio" name="sex" id="optionsRadios1" value="男" {{student.sex === '男' ? 'checked':''}}>男
            </label>
            <label>
                <input type="radio" name="sex" id="optionsRadios2" value="女"{{student.sex === '女' ? 'checked':''}}> 女
            </label>
           <!--            用于保存用户id方便提交的时候顺便把id一起提交-->
            <input type="number" name="id" value="{{student.id}}" style="display: none">
        </div>
        <button type="submit" class="btn btn-default">提交</button>
    </form>

</div>
<!-- jQuery (Bootstrap 的所有 JavaScript 插件都依赖 jQuery,所以必须放在前边) -->
<script src="/node_modules/jquery/dist/jquery.min.js"></script>
<!-- 加载 Bootstrap 的所有 JavaScript 插件。你也可以根据需要只加载单个插件。 -->
<script src="/node_modules/bootstrap/dist/js/bootstrap.min.js"></script>
</body>
</html>

后台代码

db.json数据(存放初始数据)

{
  "students": [
    {
      "name": "Miku",
      "age": "22",
      "sex": "女",
      "id": "1"
    }
  ]
}

入口函数代码

由于入口函数的代码应该尽量简洁,所把路由封装到单独的js文件中

const express = require('express')
const app = new express()
const router =require('./router')
const bodyParser = require('body-parser')
// 使用body-parser
app.use(bodyParser.urlencoded({extended: false}))
app.use(bodyParser.json())

// 把模板引擎加载到express
app.engine('html', require('express-art-template'))

// 处理静态文件
app.use('/node_modules/', express.static('./node_modules/'))
app.use('/public/', express.static('./public/'))
// 使用路由
app.use(router)
// 项目启动端口设置
app.listen(3000, () => {
  console.log('启动成功 127.0.0.1:3000')
})

路由代码

将增删改查的操作全部封装到studen.js文件中 路由只需要导入调用即可

const express = require('express')
const Student = require('./student')
// 创建路由容器
const router = express.Router()

// 挂载路由
// 显示所有的学生数据
router.get('/students', function (req, res) {
  Student.find(function (err, data) {
    if (err) {
      res.status(500).send('Server Error')
      return
    }
    res.render('index.html', {
      students: data
    })
  })
})
// 页面跳转到添加学生的页面
router.get('/students/new', function (req, res) {
  res.render('newStudent.html')
})
// 添加学生页面提交数据以后将数据保存到json文件中,然后跳转到主页面
router.post('/students', function (req, res) {
  console.log('post', req.body);

  Student.save(req.body, function (err) {
    if (err) {
      return res.status(500).send('Server Error')
    }
    res.redirect('/students')
  })
})
// 点击编辑的时候跳转到编辑页面 同时根据点击的学生进行查询信息 显示在页面上
router.get('/students/edit', function (req, res) {
  const id = req.query.id
  Student.find(function (err, data) {
   // 进行过滤 查找到id符合的学生信息
    const student = data.filter(item => parseInt(item.id) === parseInt(id))
    res.render('updateStudent.html', {
      student: student[0]
    })

  })

})
// 修改学生数据提交后,修改学生在json文件中的数据 然后跳转到主页面
router.post('/students/edit', function (req, res) {
  Student.update(req.body, function (err) {
    if (err) {
      return res.status(500).send('Server Error')
    }
    res.redirect('/students')
  })
})
// 点击删除以后根据学生id进行删除数据
router.get('/students/delete', function (req, res) {
  const id = req.query.id
  Student.delete(id, function (err) {
    if (err) {
      return res.status(500).send('Server Error')
    }
    res.redirect('/students')
  })
})

// 导出
module.exports = router

student.js的代码

通过回调函数返回结果

// 操作db文件的API, 不关心业务
const fs = require('fs')
const dbPath = './db.json'

/**
 * 获取所有学生
 */
exports.find = function (callback) {
  // 读取数据
  // 第一种方法:data.toString()
  // 第二种方法:添加第二个参数为utf8
  fs.readFile(dbPath, 'utf8', function (err, data) {
    // console.log(data);
    if (err) {
      callback(err)
      return
    }
    callback(null, JSON.parse(data).students)
  })
}

/**
 * 添加学生
 */
exports.save = function (student, callback) {
  fs.readFile(dbPath, 'utf8', function (err, data) {
    if (err) {
      callback(err)
      return
    }
    // 读取db数据,转成对象
    // 往对象里面添加新的数据
    // 再把对象转化成字符串,存入db
    const students = JSON.parse(data).students
    if(students.length < 1){
      student.id = 1
    }else {
      student.id = parseInt(students[students.length - 1].id)  + 1
    }
    students.push(student)
    const fileData = JSON.stringify({
      // students:students
      students
    })

    fs.writeFile(dbPath, fileData, function (err) {
      if (err) {
        return callback(err)
      }
      callback(null)
    })
  })
}

/**
 * 修改学生
 */
exports.update = function (student, callback) {
  fs.readFile(dbPath, 'utf8', function (err, data) {
    if (err) {
      callback(err)
      return
    }
    // 读取db数据,转成对象
    // 往对象里面添加新的数据
    // 再把对象转化成字符串,存入db
    let students = JSON.parse(data).students
     // 根据id修改对应学生的信息
    const updateStudents = students.map(item=>{
      if (parseInt(item.id) === parseInt(student.id)){
        return student
      }
      return item
    })
    const fileData = JSON.stringify({
      students:updateStudents
    })

    fs.writeFile(dbPath, fileData, function(err) {
      if(err) {
        return callback(err)
      }
      callback(null)
    })
  })
}

/**
 * 删除学生
 */
exports.delete = function (id, callback) {
  fs.readFile(dbPath, 'utf8', function (err, data) {
    if (err) {
      callback(err)
      return
    }
    let students = JSON.parse(data).students

    students = students.filter(item => parseInt(item.id) !== parseInt(id))

    const fileData = JSON.stringify({
      students
    })

    fs.writeFile(dbPath, fileData, function(err) {
      if(err) {
        return callback(err)
      }
      callback(null)
    })
  })


}

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
【资源介绍】 该项目是个人毕设项目,答辩评审分达到95分,代码都经过调试测试,确保可以运行!欢迎下载使用,可用于小白学习、进阶。 该资源主要针对计算机、通信、自动化等相关专业的学生、老师或从业者下载使用,亦可作为期末课程设计、课程大作业、毕业设计等。 项目整体具有较高的学习借鉴价值!基础能力强的可以在此基础上修改调整,以实现不同的功能。 一 mongodb使用 1)命令函: (mongo:代表进入mongo环境) (show dbs :显示数据库) (db当前) (use goods :切换到goods) 2)Token令牌 : 就是一个加密的字符串 加密算法在。 权限管理 当第一次登陆以后生成一个令牌 (这个令牌是加密的) 设置有效期 用户第一次使用用户名登陆成功后,后端生成病返回给前端保存 令牌是有有限期的 亦可以伪造 所以要校验 nodejs 有加密和解-解密 步骤一:项目准备工作 1 vue create myprojct 创建项目 (myprojct 项目名字) 2 淘宝镜像源npm install -g cnpm(使用下载更快) 1)myproject安装 项目所需的各种依赖 1 npm install vue-resource --save -dev 2 npm install axios --save 3 npm install element-ui -S 4 npm install vuex --save 5 npm install animate.css --save 6 npm install -g babel 7 npm i core-js 2)mongodb安装 上传头像 mongo 先下载Npm i mullter 1mongodb文件夹:在mongodb index文件的作用引用 注意点当每次编写接口都需要在index.js 引入路由文件 以及router.use(文件路径,文件名) 3)引入公共css在public (reset文件夹名字)第二要使用在public里面的index.html 引入css <link rel="stylesheet" href="css/reset.css"> <link href="//cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.css" rel="stylesheet"> 这一个是引入boootcss这个css 4)router.js 路由 1 定义(路由)组件 2 定义路由 3 创建 router 实例, 4 然后传 `routes` 配置 创建和挂载根实例。导出路由然后在min.js引入 在这个项目里面使用了嵌套路由注意和 LeftMenu.vue 关系 children 里面是路由嵌套 leftmenu后面细说 5)配置min.js store在后台管理系统里面是没有使用的 ``` 6)图片assets 7)在views创建 Register.vue Login.vue 404.vue项目 index.vue 1 注册页面 接口是user.js 登录页面 有有联系页面是myproject 的 http.js 和login.vue Authorization就是token当code===1时候 let targetUrl = this.$route.query.targetUrl || './Index' 代码解释:声明一个目标路由如果有目标地址就跳转到目标地址 没有就跳转到首页面Index.vue 保存token 2创建htttp.js 引入 loading和引入axios 使用loading和请求拦截和相应拦截环节和使用loading 当 请求数据code==1 就跳转到index.vue token校验 跳转到index.vue 后components里面再创建leftMenu.vue 和HeadNav.vue 具体看leftMenu以里面的嵌套路由 这两个文件夹引入到views的 Index.vue里面 使用import .. from ..引入切注册组件 HeadNav.vue :取出token校验 解码(没写此步骤)当点击退出删除token leftMenu.vue 里面有嵌套路由 足以逻辑的使用 children增加子路由步骤 1在 leftMenu.vue 下面cheildren 的 ·{ path: "FoundEdit", name: "编辑商品" }, 2找到router.js
【资源介绍】 基于nodejs+express+vue+mysql的前后端分离在线订餐系统源码+sql数据库.zip 该项目是个人毕设项目,答辩评审分达到95分,代码都经过调试测试,确保可以运行!欢迎下载使用,可用于小白学习、进阶。 该资源主要针对计算机、通信、自动化等相关专业的学生、老师或从业者下载使用,亦可作为期末课程设计、课程大作业、毕业设计等。 项目整体具有较高的学习借鉴价值!基础能力强的可以在此基础上修改调整,以实现不同的功能。 基于Vue+Vuex+Axios+NodeJs+Express+MySQL的前后端分离在线订餐系统, 原本使用的是javaweb技术进行后端开发,后经过学习用nodejs重新写了后端接口。 ## 前端架构 - 页面结构(H5,CSS3,原生JS) - 框架(基于Vue脚手架:vue-cli)进行搭建 - 数据请求处理框架(Axios) - Vue-Router进行路由处理 - Vuex进行公共数据与方法的存储 ## 服务端架构 - 选用NodeJs进行后台开发 - Express中间件进行服务的配置,路由、请求的处理 - 官网 http://www.expressjs.com.cn/ - Mysql中间件处理与数据库的"通信" - Body-Parser中间件进行前端请求参数的获取 - 使用jwt对token进行加密 - multer中间件用于文件的上传与存储 ## 数据库选取 - 采用MySQL进行相关数据库的设计与实现 ## 目前项目已实现功能 1. 首页数据的展示 2. 购物车 3. 注册 4. 登录 5. 商品详情页 6. 商品搜索 7. 用户订单管理 8. 商家详情页 9. 商家搜索页 10. 商家发布,查询,修改,删除菜品 11. 商家管理订单 12. 管理员管理商家与用户 ## 安装 已安装MySQL数据库,然后导入mysql文件夹下的mysql.sql文件 然后通过`npm`安装本地服务第三方依赖模块(需要已安装[Node.js](https://nodejs.org/)) 打开Vue2文件夹,执行命令 ``` npm install 或 cnpm install npm run serve ``` 最后打开nodejs文件夹,执行命令 ``` cd .\myapp\ npm install 或 cnpm install nodemon index.js

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值