初学node.js-nodejs中实现删除用户路由
2024-08-29 23:55:59
一、users_model.js 功能:定义用户对象模型
var mongoose=require('mongoose'),
Schema=mongoose.Schema;
var UserSchema=new Schema({
username:{type:String,unique:true},
email:String,
color:String,
hashed_password:String
});
mongoose.model('User',UserSchema);
二、users_controller.js 功能:为Express服务器实现删除用户路由
var crypto=require('crypto');
var mongoose=require('mongoose'),User=mongoose.model('User');
function hashPW(pwd){
return crypto.createHash('sha256').update(pwd).
digest('base64').toString();
}
//实现删除用户路由
exports.deleteUser=function(req,res){
User.findOne({_id:req.session.user})
.exec(function(err,user){
if(user){
user.remove(function(err){
if(err){
req.session.msg=err;
}
req.session.destroy(function(){
res.redirect('/login');
});
});
}else{
req.session.msg="User Not Found!";
req.session.destroy(function(){
res.redirect('/login');
});
}
});
};
三、user.html
<!DOCTYPE html>
<html ng-app="myApp">
<head>
<meta charset="UTF-8">
<title>用户修改</title>
<link rel="stylesheet"type="text/css" href="/static/css/styles.css" />
<script src="https://cdn.staticfile.org/angular.js/1.5.8/angular.min.js"></script>
<script src="/static/js/my_app.js"></script>
</head>
<body>
<div class="form-container" ng-controller="myController">
<p class="form-header">用户修改</p>
<form method="POST" action="/user/update">
<label>用户名:</label>
<input type="text" name="username" ng-model="user.username" disabled><br>
<label>Email:</label>
<input type="email" name="email" ng-model="user.email"><br>
<label>肤色:</label>
<input type="text" name="color" ng-model="user.color"><br>
<input type="submit" value="Save">
</form>
</div>
<form method="POST" action="/user/delete">
<input type="submit" value="删除用户">
</form>
<hr><%=msg%>
<hr>{{error}} </body>
</html>
四、routes.js 功能:为Express服务器实现处理Web请求路由
var crypto=require('crypto');
var express=require('express');
module.exports=function(app){
var users=require('./controllers/users_controller');
app.use('/static',express.static('./static')).
use('/lib',express.static('../lib')
);
app.post('/user/delete',users.deleteUser);
五、页面显示效果
最新文章
- linux内核调优参考
- Linux_文档编辑器_简介
- HOCON 了解
- IceGrid负载均衡部署 z
- Fastjson介绍
- php 目录及文件操作
- 一步一步学android之布局管理器——RelativeLayout
- flex 错误信息类型及解决方法
- vpn探测
- Gradle 1.12用户指南翻译——第五十三章. 签名插件
- 从开发者角度解析 Android N 新特性!
- 封装LocalStorage.js
- IDictionary使用/声明
- js项目练习第二课
- egret.Shape渲染集合图形
- 牛客网测试题--小a和黄金街道
- SaaS多租户模式数据存储方案
- UILabel的缩放动画效果
- bzoj2325
- os、os.path、shutil操作文件和文件路径的常用方法总结
热门文章
- 深入理解JAVA虚拟机 程序编译和代码优化
- element-ui + redis + mongo + nuxt
- 详解WebService开发中四个常见问题(2)
- python类库32[序列化和反序列化之pickle]
- javaIO--数据流之IO流与字节流
- 百度地图api的简单应用(二):轻量级路径规划
- 【NOIP2016提高A组模拟8.15】Throw
- springCloud——Dalston.SR5升级到Greenwich.SR2
- CSS自适应布局
- 防火墙firewalld 案例1.内网请求转发到外网