GetGoods.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  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. \`limit\`,
  25. icon,
  26. isHot,
  27. description,
  28. category,
  29. features
  30. FROM
  31. goods
  32. WHERE id = ? AND state = 1
  33. `
  34. let rows = await db.query(sql, [id])
  35. if (!rows || rows.length === 0)
  36. return res.json({
  37. ...BaseStdResponse.MISSING_FILE,
  38. msg: '获取商品详情失败!'
  39. })
  40. res.json({
  41. ...BaseStdResponse.OK,
  42. data: rows[0]
  43. })
  44. sql = 'UPDATE goods SET views = views + 1 WHERE id = ?'
  45. await db.query(sql, [id])
  46. }
  47. }
  48. module.exports.GetProduct = GetProduct;