在Ubuntu上使用JavaScript实现用户认证,通常会涉及到以下几个步骤:
选择框架:首先,你需要选择一个适合的Node.js框架来帮助你快速开发。Express.js是最流行的Node.js框架之一,它简化了很多常见的Web开发任务。
设置项目:在你的Ubuntu系统上创建一个新的Node.js项目,并安装必要的依赖。
mkdir my-auth-app
cd my-auth-app
npm init -y
npm install express mongoose bcryptjs jsonwebtoken express-session
这里我们安装了express(Web框架),mongoose(MongoDB对象建模工具),bcryptjs(用于密码加密),jsonwebtoken(用于生成和验证JWT),以及express-session(用于会话管理)。
创建服务器:使用Express.js创建一个基本的Web服务器。
const express = require('express');
const app = express();
const port = 3000;
app.use(express.json());
app.listen(port, () => {
console.log(`Server running on port ${port}`);
});
用户模型:定义一个用户模型,通常会包含用户名、密码等字段。
const mongoose = require('mongoose');
const bcrypt = require('bcryptjs');
const userSchema = new mongoose.Schema({
username: { type: String, unique: true },
password: String,
});
userSchema.pre('save', async function (next) {
if (this.isModified('password') || this.isNew) {
const salt = await bcrypt.genSalt(10);
this.password = await bcrypt.hash(this.password, salt);
}
next();
});
const User = mongoose.model('User', userSchema);
注册路由:创建一个注册路由,用户可以通过这个路由注册新账户。
app.post('/register', async (req, res) => {
try {
const { username, password } = req.body;
const newUser = new User({ username, password });
await newUser.save();
res.status(201).send('User created');
} catch (error) {
res.status(500).send(error.message);
}
});
登录路由:创建一个登录路由,用户可以通过这个路由登录并获取JWT。
app.post('/login', async (req, res) => {
try {
const { username, password } = req.body;
const user = await User.findOne({ username });
if (!user || !(await bcrypt.compare(password, user.password))) {
return res.status(401).send('Invalid credentials');
}
const token = jwt.sign({ userId: user._id }, 'your_jwt_secret', { expiresIn: '1h' });
res.json({ token });
} catch (error) {
res.status(500).send(error.message);
}
});
认证中间件:创建一个中间件来验证JWT。
const jwt = require('jsonwebtoken');
const authenticateToken = (req, res, next) => {
const authHeader = req.headers['authorization'];
const token = authHeader && authHeader.split(' ')[1];
if (token == null) return res.sendStatus(401);
jwt.verify(token, 'your_jwt_secret', (err, user) => {
if (err) return res.sendStatus(403);
req.user = user;
next();
});
};
受保护的路由:创建一个受保护的路由,只有认证用户才能访问。
app.get('/protected', authenticateToken, (req, res) => {
res.json({ message: 'This is a protected route', user: req.user });
});
连接数据库:在应用启动时连接到MongoDB数据库。
mongoose.connect('mongodb://localhost:27017/my-auth-app', {
useNewUrlParser: true,
useUnifiedTopology: true,
});
运行服务器:最后,运行你的Node.js服务器。
node app.js
请注意,这里的代码只是一个基本的示例,实际应用中你需要考虑更多的安全性措施,比如使用HTTPS、更安全的JWT密钥管理、输入验证、错误处理等。此外,密码不应该以明文形式存储在任何地方,这里使用bcryptjs进行加密是为了演示目的。在生产环境中,你应该使用环境变量或其他安全的方式来管理敏感信息。