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