亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

node+vue實(shí)現(xiàn)用戶注冊(cè)和頭像上傳的實(shí)例代碼

 更新時(shí)間:2017年07月20日 14:23:59   作者:HellowWorldZz  
本篇文章主要介紹了node+vue實(shí)現(xiàn)用戶注冊(cè)和頭像上傳的實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下

最近正好空閑,寫了個(gè)實(shí)用注冊(cè)代碼,分享給大家,有需要的朋友可以了解一下

數(shù)據(jù)庫(kù)我使用的是MongoDB。

首先做文件上傳,要保證協(xié)議里面的'Content-Type'為'multipart/form-data'。

注冊(cè)的步驟:

  1. 將用戶名密碼,圖片等提交給node端
  2. node端將圖片保存到服務(wù)器,圖片路徑及注冊(cè)用戶的個(gè)人信息保存到mongodb數(shù)據(jù)庫(kù)。

項(xiàng)目目錄如下,注冊(cè)功能只是其中的第一步:

前端框架使用的是vue.js,ajax使用的是vue的組件vue-resource。

前端上傳代碼如下:

<template>
 <div class="signUp">
  <!--<form id="signForm" enctype="multipart/form-data">-->
   <div>
    <label for="username">用戶名</label>
    <input type="text" name="username" id="username" placeholder="用戶名" v-model="users.username">
    <div v-if="judgeUser">請(qǐng)輸入合適的用戶名</div>
   </div>
   <div>
    <label for="password">密碼</label>
    <input type="text" name="password" id="password" placeholder="密碼" v-model="users.password">
    <div v-if="judgePas">請(qǐng)輸入符合規(guī)范的密碼</div>
   </div>
   <div>
    <label for="usernameReply">重復(fù)密碼</label>
    <input type="text" name="usernameReply" id="usernameReply" placeholder="重復(fù)密碼" v-model="users.passwords">
    <div v-if="judgePass">兩次輸入請(qǐng)保持一致</div>
   </div>
  <div>
   <label for="name">昵稱</label>
   <input type="text" name="name" id="name" placeholder="昵稱" v-model="users.name">
   <div v-if="judgeName">請(qǐng)輸入昵稱</div>
  </div>
   <div>
    <label for="sex">性別</label>
    <select name="" id="sex" v-model="users.sex">
     <option value="男">男</option>
     <option value="女">女</option>
    </select>
   </div>
   <div>
    <label for="photo">頭像</label>
    <input type="file" name="photo" id="photo" @change="onfilechange"> //通過change事件獲取到用戶所要上傳的圖片
   </div>
   <div>
    <label for="Pintroduction">個(gè)人介紹</label>
    <textarea name="Pintroduction" id="Pintroduction" cols="60" rows="8" v-model="users.Pintroduction"></textarea>
   </div>

   <input type="submit" value="注冊(cè)" class="submit" @click="submit()">
  <!--</form>-->
 </div>
</template>

<script>
//首先現(xiàn)在組件中引入vue和vue-resourece   
import Vue from 'vue';
import vueRes from 'vue-resource';
//將vue-resourece注冊(cè)到全局  
Vue.use(vueRes);

export default{
  name:'signUp',
  data(){
    return{
       judgeUser:false,
       judgePas:false,
       judgePass:false,
       judgeName:false,
       users:{
        username:null,
        password:null,
        passwords:null,
        sex:null,
        Pintroduction:null,
        photo:null,
       }
    }
  },
 methods: {
  submit: function () {
   var formdata = new FormData();
   for (var key in this.users) {  //讀取data中所要上傳的內(nèi)容循環(huán)append到fordata中
    if (key) {
     formdata.append(key, this.users[key])
    }
   }

   this.$http.post('/signup', formdata,{ //通過調(diào)取node端定義的接口,切記一定要將請(qǐng)求頭中的Content-Type改為multipart/form-data否則node端獲取到的將是一個(gè)字符串
     headers:{
       'Content-Type':'multipart/form-data'
     }
   })
    .then()
  },
  onfilechange: function (e) { //獲取到圖片文件
    var files = e.target.files ||     e.dataTransfer.files;
   if (!files.length)return;
   this.users.photo = files[0];
  }
 }

}
</script>

node端接收代碼如下:

var express=require('express');
var router = express.Router();
var formidable=require('formidable');//上傳功能的插件
var path=require('path');
var fs=require('fs');
var user=require('../models/users');//注冊(cè)信息插入數(shù)據(jù)庫(kù)的方法

router.post('/',function (req,res) {
 var uploadDir='./public/images/';
 var form=new formidable.IncomingForm();
 //文件的編碼格式
 form.encoding='utf-8';
 //文件的上傳路徑
 form.uploadDir=uploadDir;
 //文件的后綴名
 form.extensions=true;
 //文件的大小限制
 form.maxFieldsSize = 2 * 1024 * 1024;
 form.parse(req, function (err, fields, files) {
 //fields上傳的string類型的信息
 //files為上傳的文件
   var username=fields.username;
   var password=fields.password;
   var passwords=fields.passwords;
   var sex=fields.sex;
   var pintroduction=fields.Pintroduction;
   var name=fields.name;

   var file=files.photo;

   var oldpath =path.normalize(file.path);//返回正確格式的路徑

   var newfilename=username+file.name;
   var newpath=uploadDir+newfilename;

   //寫入數(shù)據(jù)庫(kù)的信息
  var useres={
   username:username,
   password:password,
   sex:sex,
   pintroduction:pintroduction,
   name:name,
  };

  //將老的圖片路徑改為新的圖片路徑
  fs.rename(oldpath,newpath,function(err){
   if(err){
    console.error("改名失敗"+err);
   }
   else {
    useres.filePath=newpath;
     user.create(useres);
     res.send('注冊(cè)成功')
   }
  });
 })
});

module.exports = router;

// models/users.js

var User=require('../lib/mongo');
module.exports={

 create:function (useres) {
  User.create(useres);
 }
};

// lib/mongo.js
const moogoose=require('mongoose');


moogoose.connect('mongodb://localhost/myblog');

moogoose.Promise = global.Promise;

const db=moogoose.connection;


// exports.db=db;
// db.once('open',function () {
//
// });

var userSchema=new moogoose.Schema({
  username:{type:'string',unique:true},
  password:{type:'string'},
  sex:{type:'string'},
  pintroduction:{type:'string'},
  name:{type:'string'},
  filePath:{type:'string'}
 },
 {collection:'user'}
);

var user=moogoose.model('user',userSchema);

exports.create=function (useres) {
 new user(useres).save(function (err,data) {
 })
};

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • express.js中間件說(shuō)明詳解

    express.js中間件說(shuō)明詳解

    這篇文章主要介紹了express.js中間件說(shuō)明詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • node自定義安裝更改npm全局模塊默認(rèn)安裝路徑的步驟

    node自定義安裝更改npm全局模塊默認(rèn)安裝路徑的步驟

    有段時(shí)間沒用npm了,新建個(gè)項(xiàng)目,需要改變npm全局包默認(rèn)安裝的路徑,本文就來(lái)介紹一下node自定義安裝更改npm全局模塊默認(rèn)安裝路徑的步驟,感興趣的可以了解下
    2021-09-09
  • 快速搭建Node.js(Express)用戶注冊(cè)、登錄以及授權(quán)的方法

    快速搭建Node.js(Express)用戶注冊(cè)、登錄以及授權(quán)的方法

    這篇文章主要介紹了快速搭建Node.js(Express)用戶注冊(cè)、登錄以及授權(quán),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2019-05-05
  • node文件資源管理器的圖片預(yù)覽從零實(shí)現(xiàn)

    node文件資源管理器的圖片預(yù)覽從零實(shí)現(xiàn)

    這篇文章主要為大家介紹了node文件資源管理器的圖片預(yù)覽從零實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • Node.js中調(diào)用mysql存儲(chǔ)過程示例

    Node.js中調(diào)用mysql存儲(chǔ)過程示例

    這篇文章主要介紹了Node.js中調(diào)用mysql存儲(chǔ)過程示例,本文在windows環(huán)境測(cè)試通過,本文一并給出了創(chuàng)建數(shù)據(jù)庫(kù)、錄入數(shù)據(jù)、創(chuàng)建存儲(chǔ)過程、調(diào)用存儲(chǔ)過程等例子,需要的朋友可以參考下
    2014-12-12
  • 使用PM2實(shí)現(xiàn)高效的應(yīng)用監(jiān)控與管理功能

    使用PM2實(shí)現(xiàn)高效的應(yīng)用監(jiān)控與管理功能

    PM2?是一個(gè)流行的進(jìn)程管理器,用于?Node.js?應(yīng)用程序,它支持應(yīng)用程序的負(fù)載均衡、自動(dòng)重啟、日志管理、監(jiān)控以及多環(huán)境管理等功能,本文給大家介紹了如何使用PM2實(shí)現(xiàn)高效的應(yīng)用監(jiān)控與管理功能,需要的朋友可以參考下
    2024-02-02
  • nodejs如何在typescript項(xiàng)目中申明全局變量

    nodejs如何在typescript項(xiàng)目中申明全局變量

    這篇文章主要介紹了nodejs在typescript項(xiàng)目中申明全局變量,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2024-05-05
  • Node.js assert斷言原理與用法分析

    Node.js assert斷言原理與用法分析

    這篇文章主要介紹了Node.js assert斷言原理與用法,結(jié)合實(shí)例形式分析了assert模塊斷言函數(shù)與使用技巧,需要的朋友可以參考下
    2019-01-01
  • 基于html5和nodejs相結(jié)合實(shí)現(xiàn)websocket即使通訊

    基于html5和nodejs相結(jié)合實(shí)現(xiàn)websocket即使通訊

    HTML5 擁有許多引人注目的新特性,如 Canvas、本地存儲(chǔ)、多媒體編程接口、WebSocket 等等。雖然現(xiàn)在大家把它捧的很火的樣子,但是個(gè)人認(rèn)為它還需要其他平臺(tái)的支持才能真正的"火起來(lái)"
    2015-11-11
  • 詳解nodejs微信公眾號(hào)開發(fā)——1.接入微信公眾號(hào)

    詳解nodejs微信公眾號(hào)開發(fā)——1.接入微信公眾號(hào)

    本篇文章主要介紹了詳解nodejs微信公眾號(hào)開發(fā)——1.接入微信公眾號(hào),非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2017-04-04

最新評(píng)論