小程序+node+mysql做的小项目
git源码地址: https://github.com/songkangle/weixin_node
小程序页面





数据库
user表

dream表

node的express框架index.js
var express = require('express');
var http= require("http");
var request = require('request');
var router = express.Router();
var index = require('../model/index.js');
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : 'root', //你的密码(就是这个该死的密码坑死我了)
database : 'dream' //你的数据库
});
connection.connect();
// 用户授权 -- 登录
router.post('/login',function(req,res,next){
if(req.body.code){
var url = 'https://api.weixin.qq.com/sns/jscode2session?appid=你的APPID&secret=你的密钥&grant_type=authorization_code&js_code='+req.body.code;
request(url, function (error, response, body) {
if (!error && response.statusCode == 200) {
var bodyData = JSON.parse(body)
res.send({
code: '0',
messages: '处理成功',
data: bodyData
});
}
})
}
})
// 存入用户数据
router.post('/insertUserData', function(req, res, next) {
if(!req.body.openid || !req.body.nickName || !req.body.avatarUrl){
res.send({
code: '1001',
messages: '参数不完整',
data: null
});
return
}
var openid = req.body.openid;
var nickName = req.body.nickName;
var province = req.body.province;
var city = req.body.city;
var country = req.body.country;
var avatarUrl = req.body.avatarUrl;
var gender = req.body.gender;
connection.query("select * from user where openid ='"+req.body.openid+"';",function(err,result){
if(err){
res.render("查找失败"+err.message);
return
}else {
if(result){
res.send({
code: '0',
messages: '已授权',
data: null
});
}else{
const addUserSql = "insert into user(id,openid,nickName,province,city,country,avatarUrl,gender) values(?,?,?,?,?,?,?,?)";
var addUserData = [0,openid,nickName,province,city,country,avatarUrl,gender];
connection.query(addUserSql,addUserData,function(err,result){
if(err){
res.render("插入失败"+err.message);
}else {
res.send({
code: '0',
messages: '处理成功',
data: null
});
}
});
}
}
});
})
// 获取用户数据
router.get('/getUserData', function(req, res, next) {
if(!req.query.openid){
res.send({
code: '1001',
messages: '参数错误',
data: null
});
return
}else{
connection.query("select * from user where openid ='"+req.query.openid+"';",function(err,result){
if(err){
res.render("查找失败"+err.message);
return
}else{
if(result){
res.send({
code: '0',
messages: '处理成功',
data: result[0]
});
}
}
})
}
});
//
router.post('/addDream', function(req, res, next) {
var userId = req.body.userId;
var dreamTitle = req.body.dreamTitle;
var dreamDesc = req.body.dreamDesc;
var startTime = req.body.startTime;
var endTime = req.body.endTime;
var isDelete = 0;
const addUserSql = "insert into dream(id,userId,dreamTitle,dreamDesc,startTime,endTime,isDelete) values(?,?,?,?,?,?,?)";
var addUserData = [0,userId,dreamTitle,dreamDesc,startTime,endTime,isDelete];
connection.query(addUserSql,addUserData,function(err,result){
if(err){
console.log(err)
res.render("插入失败"+err.message);
}else {
res.send({
code: '0',
messages: '添加成功',
data: null
});
}
});
});
router.get('/getDreamData', function(req, res, next) {
if(req.query.id){
connection.query("select * from dream where userId ='"+req.query.id+"' and isDelete=0;",function(err,result){
console.log(err)
if(err){
res.render("查找失败"+err.message);
return
}else{
if(result){
res.send({
code: '0',
messages: '处理成功',
data: result
});
}
}
})
}
});
router.post('/deleteDreamData', function(req, res, next) {
if(!req.body.id || !req.body.userId){
res.send({
code: '0',
messages: '参数不完整',
data: null
});
return
}else{
connection.query("delete from dream where userId ='"+req.body.userId+"'and id='"+req.body.id+"';",function(err,result){
if(err){
res.render("查找失败"+err.message);
return
}else{
console.log(result)
if(result){
res.send({
code: '0',
messages: '处理成功',
data: null
});
}
}
})
}
});
router.post('/completeDreamData', function(req, res, next) {
if(!req.body.id || !req.body.userId){
res.send({
code: '0',
messages: '参数不完整',
data: null
});
return
}else{
connection.query("update dream set isDelete=1 where userId ='"+req.body.userId+"'and id='"+req.body.id+"';",function(err,result){
console.log(err)
if(err){
res.render("查找失败"+err.message);
return
}else{
if(result){
res.send({
code: '0',
messages: '处理成功',
data: result
});
}
}
})
}
});
router.get('/getCompleteDreamData', function(req, res, next) {
if(req.query.id){
connection.query("select * from dream where userId ='"+req.query.id+"' and isDelete=1;",function(err,result){
console.log(err)
if(err){
res.render("查找失败"+err.message);
return
}else{
if(result){
res.send({
code: '0',
messages: '处理成功',
data: result
});
}
}
})
}
});
module.exports = router;
小程序+node+mysql做的小项目的更多相关文章
- 记录一次用宝塔部署微信小程序Node.js后端接口代码的详细过程
一直忙着写毕设,上一次写博客还是元旦,大半年过去了.... 后面会不断分享各种新项目的源码与技术.欢迎关注一起学习哈! 记录一次部署微信小程序Node.js后端接口代码的详细过程,使用宝塔来部署. 我 ...
- 基于spring-boot的社区社交微信小程序,适合做脚手架、二次开发
基于spring-boot的社区社交微信小程序,适合做脚手架.二次开发 代码地址如下:http://www.demodashi.com/demo/13867.html 1 概述 笔者做的一个后端基于s ...
- 微信小程序来了,小程序都能做些什么
2017年的微信大动作就是微信小程序了,到底小程序都能做些什么?这是很多人关注的热点,小程序开发对企业又有什么帮助呢?下面让厦门微信小程序开发公司来为你就分析下. 微信小程序与APP的关系 ...
- 微信小程序 (node) warning: possible EventEmitter memory leak detected
小程序 (node) warning: possible EventEmitter memory leak detected. %d listeners added. Use emitter.setM ...
- 微信小程序 springboot nginx 做图片存储 上传 浏览
微信小程序前端-springboot后端-nginx图片存储 前言 本人小白一名,这是第一次学习微信小程序,特此做个记录. 首先准备nginx做图片存储 选择一个地址存放图片 #我的地址 [root@ ...
- 微信小程序之微信登陆 —— 微信小程序教程系列(20)
简介: 微信登陆,在新建一个微信小程序Hello World项目的时候,就可以看到项目中出现了我们的微信头像,其实这个Hello World项目,就有一个简化版的微信登陆.只不过是,还没有写入到咱们自 ...
- 微信小程序开发——前端如何区分小程序运行环境
前言: 之前用vue做h5项目,对于接口请求,都是根据前端访问域名来判断运行环境,然后自动适配对应的服务器地址的.这样的好处就是在开发.测试及发布上线全程都不需要手动去改接口请求地址,只要提前配置好就 ...
- 微信小程序——【百景游戏小攻略】
微信小程序--[百景游戏小攻略] 本次课程小项目中的图片以及文章还未获得授权!请勿商用!未经授权,请勿转载! 博客班级 https://edu.cnblogs.com/campus/zjcsxy/SE ...
- 微信小程序全选,微信小程序checkbox,微信小程序购物车
微信小程序,这里实现微信小程序checkbox,有需要此功能的朋友可以参考下. 摘要: 加减商品数量,汇总价格,全选与全不选 设计思路: 一.从网络上传入以下Json数据格式的数组 1.标题titl ...
随机推荐
- 特殊计数序列——第一类斯特林(stirling)数
第一类斯特林数 在这里我因为懒所以还是用\(S(n,m)\)表示第一类斯特林数,但一定要和第二类斯特林数区分开来 递推式 \(S(n,m)=S(n-1.m-1)+S(n-1,m)*(n-1)\) 其中 ...
- python学习日记(异常)
异常和错误 错误 1.语法错误 这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正 #语法错误示范一 if #语法错误示范二 def test: pass #语法错误示范三 pr ...
- nowcoder300J Mex
题目链接 题意 给出一个长度为\(n(n \le 10^5)\)序列,求其每个子序列之和所组成的集合的\(mex\) 思路 这么水的题都没想出来,感觉自己脑子瓦特了. 假设前\(i\)位可以组成区间\ ...
- head里两个重要标签base和meta
base标签 <base href="../"> 我们并不常用的一个标签,但是一旦用得不当会带来灾难性的影响. 它会影响到所有页面上的href和src属性相对路劲的定位 ...
- (三) 查看USB设备
目录 查看USB设备 lsusb ll /sys/bus/usb/devices cat /sys/kernel/debug/usb/devices dmesg title: 查看USB设备 date ...
- 解决beego1.12新版本没有log.info
去https://github.com/astaxie/beego/中,找到旧的版本下载其log.go 至本地beego目录中
- 【小白学Lua】之Lua变长参数和unpack函数
一.简介 Lua的变长参数和unpack函数在实际的开发中应用的还挺多的,比如在设计print函数的时候,需要支持对多个变量进行打印输出,这时我们就需要用到Lua中的变长参数和unpack函数了. 二 ...
- 2018-2019-2 《Java程序设计》第9周学习总结
20175319 2018-2019-2 <Java程序设计>第9周学习总结 教材学习内容总结 本周学习任务: 下载安装MySQL数据库管理系统. 教材介绍在官网下载安装Mysql服务,启 ...
- table自适应大小,以及内容换行
在table的样式中加入以下两个样式: table-layout: fixed; word-wrap:break-word;
- 将驱动编译进Linux内核
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...