nodejs+express+mongodb写api接口的简单尝试
1:启动mongodb服务
我的mongoDB的安装目录:E:\mongoDB\bin,版本:3.4.9
打开cmd -> e:(进入e盘) -> cd mongoDB/bin(进入mongoDB下的bin文件夹下) -> mongod.exe(先启动mongod) -> mongo(再启动mongo)


2: 启动mongoDB的可视化工具adminMongo
adminMongo的安装目录E:\adminMongo,执行目录下的app.js文件,启动服务

文件的目录树:
├── mongodb
│ └── db.js
├── router
│ └── list.js
├── app.js
db.js
let dbData = {
selectall: function(name, callback){
let mongoose = require('mongoose');
let database_name = 'mongodb://localhost:27017/abc';
mongoose.connect(database_name, (err, db) => {
let collection = db.collection(name);
collection.find({
links: {
$gt: 10000 //筛选links值大于10000的数据
}
}).toArray((err, result) => {
if(err){
console.log('error:' + err);
return;
}
callback(result);
})
});
}
}
module.exports = dbData;
list.js
const express = require('express')
const router = express()
const dbData=require('../mongodb/db.js');
router.post('/', (req, res, next) => {
dbData.selectall('movie', function(result){
console.log(result, )
res.send(result);
})
})
module.exports = router
app.js
const express = require("express");
const app = express();
// 跨域设置
app.all("*", function(req, res, next) {
res.header("Access-Control-Allow-Credentials", true);
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "X-Requested-With");
res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS");
res.header("Content-Type", "application/json;charset=utf-8");
next();
});
// 获取内容
app.use("/list", require("./router/list"));
app.get('/', (req, res) => {
res.send('api');
});
const port = process.env.PORT || ;
app.listen(port, () => {
console.log('Express server listening on port ' + port);
});
module.exports = app;
mongodb的数据库文件结构:

表movie里的数据:

在app.js文件夹下执行 node app.js,启动node服务
项目文件中进行数据请求:
最近在使用vue,通过axios进行的数据请求
请求文件login.vue
<template>
<div class="login">
<header-title text="登录" @back="back"></header-title> <!--<mt-navbar v-model="selected">
<mt-tab-item id="">登录</mt-tab-item>
<mt-tab-item id="">注册</mt-tab-item>
</mt-navbar> <mt-tab-container v-model="selected"> <mt-tab-container-item id="" class="login-wrapper">
<mt-field label="用户名" placeholder="请输入用户名" v-model="login_username"></mt-field>
<mt-field label="密码" placeholder="请输入密码" type="password" v-model="login_password"></mt-field> <mt-button type="primary" size="large" @click.native="login">登录</mt-button>
</mt-tab-container-item> <mt-tab-container-item id="" class="register-wrapper">
<mt-field label="用户名" placeholder="请输入用户名" v-model="register_username"></mt-field>
<mt-field label="邮箱" placeholder="请输入邮箱" type="email" v-model="register_email"></mt-field>
<mt-field label="密码" placeholder="请输入密码" type="password" v-model="register_password1"></mt-field>
<mt-field label="确认密码" placeholder="请确认密码" type="password" v-model="register_password2"></mt-field> <mt-button type="primary" size="large" @click.native="register">注册</mt-button>
</mt-tab-container-item>
</mt-tab-container>
-->
<div class="main">
<mt-field label="用户名" placeholder="请输入手机号" type="tel" v-model="login_username"></mt-field>
<mt-field label="密码" placeholder="请输入密码" type="password" v-model="login_password"></mt-field> <!--<mt-button type="primary" size="large" @click.native="login">登录</mt-button> <mt-button type="primary" size="large" @click.native="register">注册</mt-button>--> <div class="login_1 active" @click="login">登录</div> <div class="register" @click="register">注册</div> <div class="forgetPassword" @click="forgetPassword">忘记密码?</div>
</div> <tab-bar></tab-bar>
</div>
</template> <script type="text/ecmascript-6">
import TabBar from '@/components/base/tab-bar/tab-bar'
import HeaderTitle from '@/components/base/header-bar/header-title'
import HeaderBar from '@/components/base/header-bar/header-bar'
import axios from 'axios'
import qs from 'qs'
export default {
components: {
TabBar,
HeaderTitle,
HeaderBar
},
data () {
return {
selected: '',
login_username: '',
login_password: '',
register_username: '',
register_email: '',
register_password1: '',
register_password2: '',
}
},
props: {},
watch: {},
methods: {
back () {
this.$router.push({
path: '/mine'
})
},
login () { // 在这里进行的模拟请求
axios.post('http://localhost:3001/list', {}, {headers:{'Content-Type':'application/x-www-form-urlencoded'}})
.then(function(res){
console.log(res)
})
.catch(function(err){
console.log(err)
}); },
register () {
this.$router.push({
path: '/register'
})
},
forgetPassword () {
this.$router.push({
path: '/forgetPassword'
})
}
},
filters: {},
computed: {},
created () { },
mounted () {},
destroyed () {}
}
</script> <style lang="less" scoped>
.login {
color: #;
margin-top: 40px;
background-color: #fff;
overflow: visible;
.main{
padding: 10px;
.forget-password{
background-color: transparent;
font-size: 12px;
color: #;
}
.login_1,.register{
width: %;
height: 40px;
line-height: 40px;
text-align: center;
font-size: 18px;
color: #3598fe;
border: 1px solid #3598fe;
border-radius: 20px;
margin-top: 20px;
}
.active{
background-color: #3598fe;
color: #fff;
}
.forgetPassword{
width: %;
height: 30px;
line-height: 30px;
text-align: center;
font-size: 12px;
margin-top: 10px;
}
}
.login-wrapper {
margin-top: 20px;
overflow: hidden;
.mint-button {
margin-top: 30px;
}
}
.register-wrapper {
margin-top: 20px;
overflow: hidden;
.mint-button {
margin-top: 30px;
}
}
}
</style>
请求的详细信息:

nodejs+express+mongodb写api接口的简单尝试的更多相关文章
- nodejs+express+mongodb实现登录注册
nodejs+express+mongodb实现登录注册 1 简介 登录注册功能使用nodejs+express+mongodb完成,其中对mongodb的操作使用mongoose完成,对mongod ...
- NodeJS+Express+MongoDB
一.MongoDB MongoDB是开源,高性能的NoSQL数据库:支持索引.集群.复制和故障转移.各种语言的驱动程序丰富:高伸缩性:MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言 ...
- 【重点突破】—— Nodejs+Express+MongoDB的使用基础
前言:最近学习vue和react的高阶项目,都需要和Nodejs+Express+MongoDB结合实现全栈开发.这里结合实例Demo和所学项目集中总结一下这部分服务端的基础知识. 一.Express ...
- web api写api接口时返回
web api写api接口时默认返回的是把你的对象序列化后以XML形式返回,那么怎样才能让其返回为json呢,下面就介绍两种方法: 方法一:(改配置法) 找到Global.asax文件,在Applic ...
- NodeJS+Express+MongoDB 简单实现数据录入及回显展示【适合新人刚接触学习】
近期在看NodeJS相关 不得不说NodeJS+Express 进行网站开发是很不错,对于喜欢玩JS的来说真是很好的一种Web开发组合 在接触NodeJS时受平时Java或者C#中API接口等开发的思 ...
- nodejs+express+mongodb简单的例子
简单的介绍下node+express+mongodb这三个东西.node:是运行在服务器端的程序语言,表面上看过去就是javascript一样的东西,但是呢,确实就是服务器语言,个人觉得在一定层次上比 ...
- NodeJS+Express+MongoDB 简单个人博客系统【Study笔记】
Blog 个人博客系统 iBlog是在学习NodeJs时候一个练手项目Demo 系统支持用户注册/登录,内容文章查看,评论,后台管理(定制显示的分类版块,进行文章内容添加)超级管理员还可进行用户管理等 ...
- 【Node.js】二、基于Express框架 + 连接MongoDB + 写后端接口
在上节,我们讲了如何搭建express环境,现在我们说说如何通过node.js写服务接口给前端调用 1. 首先通过MongoDB建好数据库与表格 例如,我的数据库名字为db_demo,数据库表格为go ...
- 一步一步学swift之:自己写Api接口-PHP
想要自己一个人完成app,那么后台接口也必须自己动动手.不用担心,其实很简单的,给自己信心!下面就以登录注册为例,做一个api接口 首先在mac上搭建PHP环境,下载 MAMP Pro for Mac ...
随机推荐
- ansible基础-理解篇
1. 介绍 要说现在的部署工具,ansible可以说家喻户晓了. ansible是一个开源软件,用于软件供应.配置管理.应用部署.ansible可以通过SSH.remote PowerShell.其他 ...
- [Swift]LeetCode946. 验证栈序列 | Validate Stack Sequences
Given two sequences pushed and popped with distinct values, return true if and only if this could ha ...
- three.js全景漫游实践
Hello 小伙伴们,如果觉得本文还不错,记得给个 star , 小伙伴们的 star 是我持续更新的动力!GitHub 地址 简介 全景图分两种 由六张正方形图片组成的SkyBox 一整张的宽高比为 ...
- 【Spark篇】---Spark中资源和任务调度源码分析与资源配置参数应用
一.前述 Spark中资源调度是一个非常核心的模块,尤其对于我们提交参数来说,需要具体到某些配置,所以提交配置的参数于源码一一对应,掌握此节对于Spark在任务执行过程中的资源分配会更上一层楼.由于源 ...
- 【Spark篇】---Spark初始
一.前述 Spark是基于内存的计算框架,性能要优于Mapreduce,可以实现hadoop生态圈中的多个组件,是一个非常优秀的大数据框架,是Apache的顶级项目.One stack rule ...
- Hive篇---Hive与Hbase整合
一.前述 Hive会经常和Hbase结合使用,把Hbase作为Hive的存储路径,所以Hive整合Hbase尤其重要. 二.具体步骤 hive和hbase同步https://cwiki.apache ...
- c 编译器大全
c 编译器大全 看了下nginx的auto/cc下的目录,nginx对多种c语言的编辑器都进行了支持.才知道c语言有那么多编辑器. 编译器原理 所谓编译器,就是执行下面的三步骤: 1 将目标语言转换为 ...
- Windows Server 2012安装mysql5.7.24记录
系统环境: 一.下载mysql5.7.24安装包 地址:https://dev.mysql.com/downloads/mysql/5.7.html#downloads 下载解压到相应的目录,我的路径 ...
- C# 《编写高质量代码改善建议》整理&笔记 --(一)基本语言篇
题记:这是自己的观后感,工作两年了,本来打算好好学习设计模式,或者作为客户端深入了解GPU编程的,但是突然发现还有这么一本书. <编写高质量代码改善建议>,感觉这正是自己需要的. 我是做 ...
- 【CSS】按钮的禁用与可用 CSS Cursor 属性
禁用时的样式 可用时的样式 样式很简单,禁用就设置为灰色,可用就设置为红色,今天这个不是重点,重点的是,光标的样子 一般,禁用时候,光标移动到按钮的上方,光标如下 而在启用按钮的时候,光标移动到按钮上 ...