GetGoods.js 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. const API = require("../../lib/API");
  2. const db = require("../../plugin/DataBase/db");
  3. const { BaseStdResponse } = require("../../BaseStdResponse");
  4. // 获取产品
  5. class GetProduct extends API {
  6. constructor() {
  7. super();
  8. this.setPath('/Goods')
  9. this.setMethod('GET')
  10. }
  11. async onRequest(req, res) {
  12. let { id } = req.query
  13. if ([id].some(value => value === '' || value === null || value === undefined))
  14. return res.json({
  15. ...BaseStdResponse.MISSING_PARAMETER
  16. })
  17. let sql = `
  18. SELECT
  19. id,
  20. name,
  21. content,
  22. price,
  23. num
  24. FROM
  25. goods
  26. WHERE id = ? AND state = 1
  27. `
  28. let rows = await db.query(sql, [id])
  29. if (!rows || rows.length === 0)
  30. return res.json({
  31. ...BaseStdResponse.MISSING_FILE,
  32. msg: '获取商品详情失败!'
  33. })
  34. res.json({
  35. ...BaseStdResponse.OK,
  36. data: rows
  37. })
  38. sql = 'UPDATE goods SET views = views + 1 WHERE id = ?'
  39. await db.query(sql, [id])
  40. }
  41. }
  42. module.exports.GetProduct = GetProduct;