欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Node.js連接mongo數(shù)據(jù)庫(kù)上傳文件的方法步驟

 更新時(shí)間:2022年05月09日 14:45:31   作者:鵬程933  
本文主要介紹了Node.js連接mongo數(shù)據(jù)庫(kù)上傳文件的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

效果

請(qǐng)?zhí)砑訄D片描述

初始化

  • 創(chuàng)建項(xiàng)目文件夾mondo-express
  • 安裝包 npm i express-generator -g(作用一鍵生成項(xiàng)目列表)
  • 在項(xiàng)目文件夾mondo-express用終端打開(kāi)輸入npx express-generator自動(dòng)生成項(xiàng)目目錄
  • 安裝包
    • 終端進(jìn)入默認(rèn)創(chuàng)建的package.json輸入 npm i下載依賴(lài)包
    • 再下載用于連接數(shù)據(jù)庫(kù)包輸入 npm i mongoose
    • 用于上傳文件的包 npm i formidable
    • 用于加密的包npm i bcryptjs
  • 更改下package.json里的文件信息,以方便再終端啟動(dòng)“scripts”: { “start”: “nodemon ./bin/www” }
  • 終端啟動(dòng)時(shí)輸入npm start

model 下創(chuàng)建index.js用于連接數(shù)據(jù)庫(kù)時(shí)的信息

const mongo=require("mongoose");
const userSchema=new mongo.Schema({
    username:String,
    password:String,
    gender:String,
    tel:String,
    avatarUrl:String
})
const userModel=mongo.model('runoob',userSchema,'users')
module.exports=userModel

修改app.js文件里的信息

  • 引入數(shù)據(jù)庫(kù)連接
  • 引入路由模塊
var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');

var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');

var app = express();

// 連接數(shù)據(jù)庫(kù)
const mongoose = require('mongoose'); // 引入 mongoose,用于連接數(shù)據(jù)庫(kù)
mongoose.connect('mongodb://localhost:27017/runoob'); // 連接數(shù)據(jù)庫(kù)

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

//掛載路由
app.use('/users', usersRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});

// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

router下修改user.js文件

這里是處理客戶(hù)端請(qǐng)求的核心,遵循REST架構(gòu)風(fēng)格

  • GET-查詢(xún)
  • POST-增加
  • PUT-修改
  • DELETE刪除

查找

  • 通過(guò):_id?判斷是否有id傳入并執(zhí)行相應(yīng)響應(yīng),?表示可能有id也可能沒(méi)有id
  • 如果有id傳入,按照id在數(shù)據(jù)庫(kù)查找并返回對(duì)應(yīng)的值
  • 沒(méi)有則查找數(shù)據(jù)庫(kù)所有的內(nèi)容并返回

增加

  • 先初始化下form這里有三個(gè)參數(shù)代表允許上傳一個(gè)文件,文件存放路徑,保存原始文件后綴
  • form.parse(請(qǐng)求,回調(diào))表示將req中內(nèi)容交給form回調(diào)函數(shù)處理
  • fields里面包含普通文本信息,結(jié)構(gòu)出來(lái),files里面有文件信息,對(duì)象.的形式拿出來(lái)
  • 進(jìn)行下非空驗(yàn)證,和用戶(hù)名是否存在驗(yàn)證
  • 保存時(shí)需要對(duì)密碼加密,這里采用bcrypt.hashSync(password,10)第一個(gè)參數(shù)要加密對(duì)象,第二個(gè)加密強(qiáng)度
  • 向數(shù)據(jù)庫(kù)保存信息,成功后返回給客戶(hù)端

修改

  • 通過(guò)/:_id拿到要修改對(duì)象的id信息
  • 執(zhí)行修改,成功后返回成功信息

刪除

  • 通過(guò)/:_id拿到刪除對(duì)象id信息
  • 執(zhí)行刪除,成功后返回成功信息
var express = require('express');
const db=require('../model/index')
const formidable=require('formidable')
const path=require('path')
var router = express.Router();
const bcrypt=require('bcryptjs')

// /* GET users listing. */

//查找
router.get('/:_id?',(req,res)=>{
  const {_id}=req.params;
  if(_id){
    console.log(_id);
    db
    // .findOne({_id:'6274ee9d620974ebd2122df8'})
    // .find({_id:_id})
    .findById(_id)
    .then(data=>{
      res.json({
        code:200,
        status:1,
        data,
      })
    })
  }else {
    db
        .find()
        .then(data=>{
          res.json({
            code:200,
            status:0,
            data
          })
        })
  }
})
//增加
router.post('/api/upload',(req,res,next)=>{

  const form=formidable({
    multiples: true,
    uploadDir: path.join(__dirname, '../static/upload'),
    keepExtensions: true,

  })
  form.parse(req,(err,fields, files)=>{
    if(err) {
      next(err);
      return;
    }
    const {name,password,gender,tel}=fields;
    const avatarUrl="/upload/"+ files.avatar.newFilename;//文件夾,包含上傳文件
    if(!name || !password){
      res.json({
        code:200,
        status:1,
        message:"用戶(hù)名或密碼不能為空"
      })
    }else {
        db.findOne({username:name}).then(data=>{
        if(data==null){
          const hash=bcrypt.hashSync(password,10)
          new db({username:name,password:hash,gender,tel,avatarUrl})
              .save()
              .then(data=>{
                res.json({
                  code:200,
                  status:0,
                  message:data
                })
              })

        }else {
          res.json({
            code:200,
            status:1,
            message:"用戶(hù)名已存在"
          })
        }
      })
    }
  })
   
})
 //修改
router.put('/:_id',(req,res)=>{
    const _id=req.params;
    const {username,password,gender,tel,avatarUrl}=req.body;
    db
    .updateOne({_id},{username,password,gender,tel,avatarUrl})
    .then((data)=>{
      res.json({
        code:200,
        status:0,
        message:"修改成功" 
      })
    })
 

})
//刪除
router.delete('/:_id',(req,res)=>{
  const _id=req.params;
  db.deleteOne({_id}).then((data)=>{
    res.send({
      code:200,
      status:0,
      message:"刪除成功"
    })
  })
})
module.exports = router;

創(chuàng)建上傳文件保存文件夾

文件夾mondo-express下新建一個(gè)static/upload

在public下新建一個(gè)index.html 用于請(qǐng)求時(shí)的主頁(yè)面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h2>With <code>"express"</code> npm package</h2>
    <form action="users/api/upload" enctype="multipart/form-data" method="post">
        <div>name: <input type="text" name="name" /></div>
        <div>password:<input type="password" name="password"></div>
        <div>gender:<input type="text" name="gender"></div>
        <div> tel:<input type="text" name="tel"></div>
        <div>File: <input type="file" name="avatar" multiple="multiple" /></div>
      <input type="submit" value="Upload" />
    </form>
</body>
</html>

到此這篇關(guān)于Node.js連接mongo數(shù)據(jù)庫(kù)上傳文件的方法步驟的文章就介紹到這了,更多相關(guān)Node.js連接mongo上傳文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • node.js命令行教程圖文詳解

    node.js命令行教程圖文詳解

    本文先介紹原生的node.js實(shí)現(xiàn)命令行交互,了解原生的api,然后通過(guò)commander.js和inquirer.js實(shí)現(xiàn)一個(gè)完整的交互命令行工具。感興趣的朋友跟隨小編一起看看吧
    2019-05-05
  • 詳解基于 Node.js 的輕量級(jí)云函數(shù)功能實(shí)現(xiàn)

    詳解基于 Node.js 的輕量級(jí)云函數(shù)功能實(shí)現(xiàn)

    這篇文章主要介紹了詳解基于 Node.js 的輕量級(jí)云函數(shù)功能實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Node.js中的模塊化,npm包管理器詳解

    Node.js中的模塊化,npm包管理器詳解

    這篇文章主要介紹了node模塊與npm包管理工具,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2021-09-09
  • Node.js Koa2使用JWT進(jìn)行鑒權(quán)的方法示例

    Node.js Koa2使用JWT進(jìn)行鑒權(quán)的方法示例

    這篇文章主要介紹了Node.js Koa2使用JWT進(jìn)行鑒權(quán)的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • 使用Express處理請(qǐng)求和托管靜態(tài)資源方式

    使用Express處理請(qǐng)求和托管靜態(tài)資源方式

    這篇文章主要介紹了使用Express處理請(qǐng)求和托管靜態(tài)資源方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Node.js進(jìn)行文件操作(讀取/寫(xiě)入/修改/刪除)詳解

    Node.js進(jìn)行文件操作(讀取/寫(xiě)入/修改/刪除)詳解

    Node.js是一個(gè)神奇的東西,它可以讓JavaScript在服務(wù)器端運(yùn)行,讓我們的很多前端程序員也能在后端大展身手了!本文就來(lái)講講如何在Node.js中進(jìn)行文件操作:讀取、寫(xiě)入、修改和刪除文件吧
    2023-03-03
  • Windows下快速搭建NodeJS本地服務(wù)器的步驟

    Windows下快速搭建NodeJS本地服務(wù)器的步驟

    本篇文章主要介紹了Windows下快速搭建NodeJS本地服務(wù)器的步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-08-08
  • 解決Mac node版本升級(jí)失敗的問(wèn)題

    解決Mac node版本升級(jí)失敗的問(wèn)題

    今天小編就為大家分享一篇解決Mac node版本升級(jí)失敗的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • node使用mysql獲取數(shù)據(jù)庫(kù)數(shù)據(jù)中文亂碼問(wèn)題的解決

    node使用mysql獲取數(shù)據(jù)庫(kù)數(shù)據(jù)中文亂碼問(wèn)題的解決

    這篇文章主要介紹了node使用mysql獲取數(shù)據(jù)庫(kù)數(shù)據(jù)中文亂碼問(wèn)題的解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 詳解一個(gè)基于套接字實(shí)現(xiàn)長(zhǎng)連接的express

    詳解一個(gè)基于套接字實(shí)現(xiàn)長(zhǎng)連接的express

    這篇文章主要介紹了詳解一個(gè)基于套接字實(shí)現(xiàn)長(zhǎng)連接的express,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03

最新評(píng)論