GetGoods.js 1.3 KB

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