index.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422
  1. const express = require('../node_modules/express')
  2. const bodyParser = require('../node_modules/body-parser')
  3. const path = require('path')
  4. const net = require('net');
  5. const { getDevicesId, regeditKey, validate } = require(path.join(__dirname, '../dll/index'))
  6. const cors = require('cors');
  7. const fs = require('fs')
  8. const app = express()
  9. const http = require('http');
  10. const server = http.createServer(app);
  11. const {exec} = require('child_process');
  12. const { getHtml, getXorKeyByFileName } = require(path.join(__dirname, './xorFileContent'))
  13. app.use(cors())
  14. app.use(express.static(path.join(__dirname, '../dist')));
  15. app.use(express.static(path.join(__dirname, '../images')));
  16. app.use(express.static(path.join(__dirname, '../files')));
  17. app.use(bodyParser.urlencoded({ extended: false }));
  18. app.use(bodyParser.json());
  19. const { category: categorySql } = require(path.join(__dirname, './dataJson/category'))
  20. const { slides: slidesSql } = require(path.join(__dirname, './dataJson/slides'))
  21. const { idObject } = require(path.join(__dirname, '../id'))
  22. app.get('/html', function(req, res) {
  23. res.setHeader('Content-Type', 'text/html');
  24. res.sendFile(path.join(__dirname, '../dist/index.html'))
  25. })
  26. app.get('/file', function(req, res) {
  27. const { id } = req.query
  28. console.log(id);
  29. const target = idObject.find(item =>item.catId == Number(id))
  30. console.log(target);
  31. res.setHeader('Content-Type', 'text/html');
  32. // res.send(getHtml(target.fileName))
  33. res.send(getHtml(target.fileName))
  34. })
  35. app.get('/devicesId', function(req, res ) {
  36. const id = getDevicesId()
  37. res.send({
  38. code: 200,
  39. data: id,
  40. msg: 'DevicesId'
  41. })
  42. })
  43. app.post('/login', async function (req, res) {
  44. const devicesId = req.body.devicesId
  45. const code = req.body.code
  46. const r = await regeditKey(devicesId, code)
  47. console.log('r:', r == 1);
  48. res.send({
  49. code: 200,
  50. data: r,
  51. msg: r == 1 ? '激活成功' : '激活失败'
  52. })
  53. })
  54. app.post('/validate', async function(req, res ) {
  55. const r = await validate()
  56. res.send({
  57. code: 200,
  58. data: r,
  59. msg: r == 1 ? '校验通过' : '校验失败'
  60. })
  61. })
  62. app.get('/data/common/script.js', function(req, res) {
  63. const regex = /id=([^&]+)/;
  64. const match = req.headers.referer.match(regex);
  65. const target = idObject.find(item =>item.catId == Number(match[1]))
  66. let filename = target.fileName
  67. const strs = [...fs.readFileSync(path.join(__dirname, '../files', filename, '/data/common/script.js'))]
  68. res.set('Content-Type', 'application/javascript');
  69. res.send(Buffer.from(strs))
  70. })
  71. app.get('/data/player/player.js', function(req, res) {
  72. const regex = /id=([^&]+)/;
  73. const match = req.headers.referer.match(regex);
  74. const target = idObject.find(item =>item.catId == Number(match[1]))
  75. let filename = target.fileName
  76. const strs = [...fs.readFileSync(path.join(__dirname,`../files/${filename}/data/player/player.js`))]
  77. res.set('Content-Type', 'application/javascript');
  78. res.send(Buffer.from(strs))
  79. })
  80. app.get('/data/player/pre.gif', function(req, res) {
  81. const regex = /id=([^&]+)/;
  82. const match = req.headers.referer.match(regex);
  83. const target = idObject.find(item =>item.catId == Number(match[1]))
  84. let filename = target.fileName
  85. const strs = [...fs.readFileSync(path.join(__dirname,`../files/${filename}/data/player/pre.gif`))]
  86. res.set('Content-Type', 'image/gif');
  87. res.send(Buffer.from(strs))
  88. })
  89. // :filename(png|mp3|mp4|jpg)
  90. app.get('/data/pres/*', async function(req, res, next) {
  91. const regex = /id=([^&]+)/;
  92. const match = req.headers.referer.match(regex);
  93. const target = idObject.find(item =>item.catId == Number(match[1]))
  94. let filename = target.fileName
  95. if (req.path.includes('.js')) {
  96. const strs = fs.readFileSync(path.join(__dirname,`../files/${filename}${req.path}`))
  97. res.set('Content-Type', 'application/javascript');
  98. res.send(Buffer.from(strs))
  99. // next()
  100. return
  101. }
  102. if (req.path.includes('.css')) {
  103. const strs = fs.readFileSync(path.join(__dirname,`../files/${filename}${req.path}`))
  104. res.set('Content-Type', 'text/css');
  105. res.send(Buffer.from(strs))
  106. return
  107. }
  108. if (req.path.includes('.woff')) {
  109. try {
  110. const strs = fs.readFileSync(path.join(__dirname,`../files/${filename}${req.path}`))
  111. res.set('Content-Type', 'font/woff');
  112. res.send(Buffer.from(strs))
  113. return
  114. } catch (error) {
  115. return
  116. }
  117. }
  118. if (req.path.includes('.gif')) {
  119. const strs = fs.readFileSync(path.join(__dirname,`../files/${filename}${req.path}`))
  120. res.set('Content-Type', 'image/gif');
  121. res.send(Buffer.from(strs))
  122. return
  123. }
  124. // 字符数组
  125. const strs = fs.readFileSync(path.join(__dirname,`../files/${filename}${req.path}`))
  126. for (let i = 0; i < 100; i++) {
  127. strs[i] ^= getXorKeyByFileName(filename); // 异或操作
  128. }
  129. try {
  130. if (req.path.includes('.png')) {
  131. res.set('Content-Type', 'image/png');
  132. res.send(Buffer.from(strs))
  133. } else if (req.path.includes('.mp3')) {
  134. res.set('Content-Type', 'audio/mpeg');
  135. res.send(Buffer.from(strs))
  136. } else if (req.path.includes('.mp4')) {
  137. res.set('Content-Type', 'video/mp4');
  138. res.send(Buffer.from(strs))
  139. } else if (req.path.includes('.jpg')) {
  140. res.set('Content-Type', 'image/jpg');
  141. res.send(Buffer.from(strs))
  142. } else if (req.path.includes('.js')) {
  143. res.set('Content-Type', 'image/jpg');
  144. res.send(Buffer.from(strs))
  145. }
  146. } catch (error) {
  147. next()
  148. }
  149. })
  150. let port = ''
  151. const baseUrl = () => 'http://localhost:' + port + '/'
  152. // 以下为页面所需要的业务代码
  153. app.get('/home/:catId', async function(req, res) {
  154. const { catId } = req.params
  155. const categorys = categorySql.filter(item => catId === item.parent_id)
  156. const result = categorys.map( category => {
  157. return {
  158. classLevelId: category.class_level_id,
  159. classLevelName: category.class_level_name,
  160. categoryDTOS: [
  161. {
  162. catId: category.cat_id,
  163. catLevel: category.cat_level,
  164. catName: category.cat_name,
  165. classLevelId: category.class_level_id,
  166. classLevelImg: null,
  167. classLevelName: category.class_level_name,
  168. createTime: category.create_time,
  169. description: category.description,
  170. imgUrl: baseUrl() + category.img_url,
  171. longImgUrl:baseUrl() + category.long_img_url,
  172. parentId: category.parent_id,
  173. slidesAmount: category.slidesAmount,
  174. categoryTreeDTO: categorySql.filter(item => item.parent_id === category.cat_id && category.cat_level !== '100000').map(_ => {
  175. return {
  176. catId: _.cat_id,
  177. catLevel: _.cat_level,
  178. catName: _.cat_name,
  179. classLevelId: _.class_level_id,
  180. classLevelImg: null,
  181. classLevelName: _.class_level_name,
  182. createTime: _.create_time,
  183. description: _.description,
  184. imgUrl: baseUrl() + _.img_url,
  185. longImgUrl: baseUrl() + _.long_img_url,
  186. parentId: _.parent_id,
  187. slidesAmount: _.slidesAmount,
  188. }
  189. })
  190. }
  191. ]
  192. }
  193. })
  194. res.send( {
  195. status: 200,
  196. data: result,
  197. msg: '获取成功'
  198. })
  199. })
  200. app.get('/category/queryCourse/list/:catId/:page/:pageSize', async function(req, res) {
  201. const {catId, page, pageSize} = req.params
  202. console.log('catId, page, pageSize:', catId, page, pageSize);
  203. const category = categorySql.find( item => item.cat_id === catId )
  204. const slidesList = slidesSql.filter( item => item.cat_id === catId && item.is_delete !== '1')
  205. const total = slidesList.length
  206. const result = {
  207. catId: category.catId,
  208. catLevel: category.cat_level,
  209. catName: category.cat_name,
  210. classLevelId: category.class_level_id,
  211. classLevelName: category.class_level_name,
  212. description: category.description,
  213. imgUrl: baseUrl() + category.img_url,
  214. parentId: category.parent_id,
  215. parentName: category.parentName,
  216. slidesDOPage: {
  217. currentPage: Number(page),
  218. pageSize: Number(pageSize),
  219. total: Number(total),
  220. entityList: slidesList.slice((page - 1) * pageSize, page * pageSize > total ? total % pageSize + (page - 1) * pageSize : page * pageSize).map(_ => {
  221. return {
  222. "slidesId": _.slides_id,
  223. "slidesName": _.slides_name,
  224. "slidesSize": null,
  225. "description": null,
  226. "createTime": null,
  227. "updateTime": null,
  228. "slidesUrl": null,
  229. "catId": _.cat_id,
  230. "classLevelId": null,
  231. "classLevelName": null,
  232. "emptyPos": null,
  233. "isDelete": null,
  234. "typeName": null,
  235. "sort": null,
  236. "article": null,
  237. "fileId": null,
  238. "fileVersionId": null,
  239. "videoUrl": null,
  240. "imgUrl": null
  241. }
  242. })
  243. }
  244. }
  245. res.send({
  246. status: 200,
  247. data: result,
  248. msg: '获取成功'
  249. })
  250. })
  251. app.get('/slides/queryInfo/7', function (req, res) {
  252. const result = {
  253. slidesUrl: getHtml
  254. }
  255. res.send({
  256. status: 200,
  257. data: result,
  258. msg: '获取成功'
  259. })
  260. })
  261. if (process.argv[2] === 'test') {
  262. async function createPort () {
  263. const _port = await findAvailablePort(3000); // 从3000端口开始查找空闲端口
  264. port = _port
  265. server.close()
  266. server.listen(port, () => {
  267. console.log('Server is running on port in ' + port);
  268. })
  269. }
  270. createPort()
  271. // let port = 13004
  272. // server.close()
  273. // server.listen(port, () => {
  274. // console.log('Server is running on port in server/index.js ' + port);
  275. // })
  276. }
  277. // 创建函数来关闭指定端口的进程
  278. function closePort(port) {
  279. // 使用 netstat 查找占用端口的进程
  280. exec(`netstat -ano | findstr :${port}`, (error, stdout, stderr) => {
  281. if (error) {
  282. console.error(`执行错误: ${error}`);
  283. return;
  284. }
  285. if (!stdout) {
  286. console.log(`端口 ${port} 没有被占用`);
  287. return;
  288. }
  289. // 输出的最后一列是 PID
  290. const lines = stdout.trim().split('\n');
  291. lines.forEach(line => {
  292. const parts = line.trim().split(/\s+/);
  293. const pid = parts[parts.length - 1];
  294. console.log(`端口 ${port} 被 PID 为 ${pid} 的进程占用`);
  295. // 使用 taskkill 命令终止进程
  296. exec(`taskkill /F /PID ${pid}`, (error, stdout, stderr) => {
  297. if (error) {
  298. console.error(`无法终止进程 PID: ${pid} - ${error}`);
  299. return;
  300. }
  301. server.listen(port, () => {
  302. console.log('Server is running on port ' + port);
  303. })
  304. console.log(`成功终止进程 PID: ${pid}`);
  305. });
  306. });
  307. });
  308. }
  309. // 查找可用端口的函数
  310. function findAvailablePort(startPort) {
  311. return new Promise((resolve, reject) => {
  312. const server = net.createServer();
  313. server.listen(startPort, () => {
  314. // 端口可用
  315. server.close(() => resolve(startPort));
  316. });
  317. server.on('error', (err) => {
  318. if (err.code === 'EADDRINUSE') {
  319. // 如果端口被占用,递归查找下一个端口
  320. resolve(findAvailablePort(startPort + 1));
  321. } else {
  322. reject(err);
  323. }
  324. });
  325. });
  326. }
  327. module.exports = {
  328. getRunPort: () => port,
  329. nodeServer: server,
  330. createPort: async (cb) => {
  331. const _port = await findAvailablePort(3000); // 从3000端口开始查找空闲端口
  332. port = _port
  333. server.close()
  334. server.listen(port, () => {
  335. cb(port)
  336. console.log('Server is running on port in ' + port);
  337. })
  338. }
  339. }