UploadAvatar.js 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. const API = require("../../../lib/API");
  2. const db = require("../../../plugin/DataBase/db");
  3. const { BaseStdResponse } = require("../../../BaseStdResponse");
  4. const Redis = require('../../../plugin/DataBase/Redis');
  5. const AccessControl = require("../../../lib/AccessControl");
  6. const multer = require('multer'); // 用于文件上传
  7. const path = require('path'); // 用于处理文件路径
  8. // 配置Multer的存储选项
  9. const storage = multer.diskStorage({
  10. destination: (req, file, cb) => {
  11. cb(null, 'uploads/avatar/');
  12. },
  13. filename: (req, file, cb) => {
  14. const uuid = req.params.uuid;
  15. const fileExtension = path.extname(file.originalname);
  16. cb(null, `${uuid}${fileExtension}`);
  17. }
  18. });
  19. // 限制文件类型
  20. const fileFilter = (req, file, cb) => {
  21. // 只接受以下扩展名的图片文件
  22. const allowedTypes = /jpeg|jpg|png|gif/;
  23. const extname = allowedTypes.test(path.extname(file.originalname).toLowerCase());
  24. const mimetype = allowedTypes.test(file.mimetype);
  25. if (extname && mimetype) {
  26. return cb(null, true);
  27. } else {
  28. cb(new Error('只允许上传图片文件 (jpeg, jpg, png, gif)'));
  29. }
  30. };
  31. // 初始化Multer中间件
  32. const upload = multer({
  33. storage: storage,
  34. fileFilter: fileFilter,
  35. limits: { fileSize: 3 * 1024 * 1024 } // 限制文件大小为3MB
  36. }).single('avatar');
  37. class UploadAvatar extends API {
  38. constructor() {
  39. super();
  40. this.setMethod("POST");
  41. this.setPath("/User/UploadAvatar/:uuid/:session");
  42. }
  43. async onRequest(req, res) {
  44. // 使用Multer中间件处理文件上传
  45. upload(req, res, async (err) => {
  46. if (err) {
  47. this.logger.error(`头像上传失败!${err.stack || ''}`)
  48. return res.json({
  49. ...BaseStdResponse.ERR
  50. });
  51. }
  52. let { uuid, session } = req.params;
  53. if ([uuid, session].some(value => value === '' || value === null || value === undefined)) {
  54. return res.json({
  55. ...BaseStdResponse.MISSING_PARAMETER,
  56. endpoint: 1513126
  57. });
  58. }
  59. if (!await AccessControl.checkSession(uuid, session)) {
  60. return res.json({
  61. ...BaseStdResponse.ACCESS_DENIED,
  62. endpoint: 48153145
  63. });
  64. }
  65. if (!req.file) {
  66. return res.json({
  67. ...BaseStdResponse.MISSING_PARAMETER,
  68. msg: '请上传头像文件'
  69. });
  70. }
  71. const avatarPath = `/avatar/${req.file.filename}`; // 获取文件路径
  72. let sql = 'UPDATE users SET avatar = ? WHERE uuid = ?';
  73. let result = await db.query(sql, [avatarPath, uuid]);
  74. if (result && result.affectedRows > 0) {
  75. sql = 'SELECT username, wxid, avatar, email FROM users WHERE uuid = ?';
  76. let rows = await db.query(sql, [uuid]);
  77. if (!rows || rows.length === 0) {
  78. return res.json({
  79. ...BaseStdResponse.DATABASE_ERR
  80. });
  81. }
  82. res.json({
  83. ...BaseStdResponse.OK,
  84. data: {
  85. uuid,
  86. username: rows[0].username,
  87. wxid: rows[0].wxid,
  88. email: rows[0].email,
  89. avatar: rows[0].avatar,
  90. session
  91. }
  92. });
  93. } else {
  94. res.json({ ...BaseStdResponse.ERR, endpoint: 7894378, msg: '头像更新失败!' });
  95. }
  96. });
  97. }
  98. }
  99. module.exports.UploadAvatar = UploadAvatar;