1. 응답으로 디텍션=true 받은 경우 해당 프레임 데이터를 이미지로 저장
2. save image api 추가(방문자 사진 업로드 기능)
Showing
16 changed files
with
236 additions
and
60 deletions
... | @@ -4,8 +4,6 @@ const ffmpeg = require('ffmpeg'); | ... | @@ -4,8 +4,6 @@ const ffmpeg = require('ffmpeg'); |
4 | const request = require('request') | 4 | const request = require('request') |
5 | 5 | ||
6 | const router = express.Router(); | 6 | const router = express.Router(); |
7 | -const path = require('path'); | ||
8 | -//================================================================ | ||
9 | 7 | ||
10 | router.post('/videoResult', function (req, res) { | 8 | router.post('/videoResult', function (req, res) { |
11 | 9 | ||
... | @@ -15,7 +13,6 @@ router.post('/videoResult', function (req, res) { | ... | @@ -15,7 +13,6 @@ router.post('/videoResult', function (req, res) { |
15 | str = preview.replace(/^data:(.*?);base64,/, ""); | 13 | str = preview.replace(/^data:(.*?);base64,/, ""); |
16 | str = str.replace(/ /g, '+'); | 14 | str = str.replace(/ /g, '+'); |
17 | 15 | ||
18 | - | ||
19 | fs.writeFileSync(`./data/temp.mp4`, str, 'base64', function (err) { | 16 | fs.writeFileSync(`./data/temp.mp4`, str, 'base64', function (err) { |
20 | if (err) throw err; | 17 | if (err) throw err; |
21 | console.log("video saved"); | 18 | console.log("video saved"); |
... | @@ -24,8 +21,6 @@ router.post('/videoResult', function (req, res) { | ... | @@ -24,8 +21,6 @@ router.post('/videoResult', function (req, res) { |
24 | 21 | ||
25 | let process = new ffmpeg(`./data/temp.mp4`); | 22 | let process = new ffmpeg(`./data/temp.mp4`); |
26 | 23 | ||
27 | - | ||
28 | - detectedImgFile = "test.jpg"; // null로 바꿀 것 | ||
29 | process.then(function (video) { | 24 | process.then(function (video) { |
30 | video.fnExtractFrameToJPG(__dirname + "/data", | 25 | video.fnExtractFrameToJPG(__dirname + "/data", |
31 | { | 26 | { |
... | @@ -33,31 +28,26 @@ router.post('/videoResult', function (req, res) { | ... | @@ -33,31 +28,26 @@ router.post('/videoResult', function (req, res) { |
33 | file_name: 'frame_%s' | 28 | file_name: 'frame_%s' |
34 | }, function (error, files) { | 29 | }, function (error, files) { |
35 | if (!error) | 30 | if (!error) |
36 | - console.log('###1 Frames =>' + files); | ||
37 | - console.log("###2 갯수 => " + files.length) | ||
38 | - | ||
39 | - | ||
40 | - console.log("###3 첫번째 파일 => " + files[0]); // 마지막 파일은 영상임 | ||
41 | - let base64str = base64_encode(files[0]); | ||
42 | - console.log("###4 base64str => " + base64str); | ||
43 | - console.log("##### for") | ||
44 | for(var i=0;i<files.length-1;i++){ | 31 | for(var i=0;i<files.length-1;i++){ |
32 | + let base64str = base64_encode(files[i]); | ||
45 | request.post({ | 33 | request.post({ |
46 | url: 'http://101.101.210.73/process', | 34 | url: 'http://101.101.210.73/process', |
47 | form: { | 35 | form: { |
48 | - 'data': base64_encode(files[0]) | 36 | + 'data': base64str, |
37 | + 'index': i | ||
49 | }, | 38 | }, |
50 | json: true | 39 | json: true |
51 | }, (err, response, body) => { | 40 | }, (err, response, body) => { |
52 | console.log(body) | 41 | console.log(body) |
42 | + var index=body['index']; | ||
43 | + if(body['unknown_person'] == true){ | ||
44 | + save_Result_image((files[index]), 'unknown', index); | ||
45 | + } | ||
46 | + if(body['fire_broken'] == true){ | ||
47 | + save_Result_image((files[index]), 'fire', index); | ||
48 | + } | ||
53 | }) | 49 | }) |
54 | } | 50 | } |
55 | - /** | ||
56 | - * TODO | ||
57 | - * 반복문돌면서 각 프레임 파이썬 api 요청하고 응답받아서 | ||
58 | - * 하나라도 true나오면 프론트에 감지된 이미지파일주소 응답 | ||
59 | - */ | ||
60 | - detectedImgFile=null; | ||
61 | } | 51 | } |
62 | ) | 52 | ) |
63 | }) | 53 | }) |
... | @@ -66,7 +56,28 @@ router.post('/videoResult', function (req, res) { | ... | @@ -66,7 +56,28 @@ router.post('/videoResult', function (req, res) { |
66 | console.error(err); | 56 | console.error(err); |
67 | } | 57 | } |
68 | 58 | ||
69 | - return res.json({ data: detectedImgFile }); | 59 | + return res.json({ data: true }); |
60 | +}); | ||
61 | + | ||
62 | +router.post('/saveImage', function (req, res) { | ||
63 | + try { | ||
64 | + let preview = req.body[0].preview; | ||
65 | + str = preview.replace(/^data:(.*?);base64,/, ""); | ||
66 | + base64str = str.replace(/ /g, '+'); | ||
67 | + request.post({ | ||
68 | + url: 'http://101.101.210.73/save', | ||
69 | + form: { | ||
70 | + 'data': base64str, | ||
71 | + 'name': 'temp' | ||
72 | + }, | ||
73 | + json: true | ||
74 | + }, (err, response, body) => { | ||
75 | + console.log(body); | ||
76 | + }) | ||
77 | + } catch (err) { | ||
78 | + console.error(err); | ||
79 | + } | ||
80 | + return res.json({ data: true }); | ||
70 | }); | 81 | }); |
71 | 82 | ||
72 | function base64_encode(file) { | 83 | function base64_encode(file) { |
... | @@ -76,4 +87,12 @@ function base64_encode(file) { | ... | @@ -76,4 +87,12 @@ function base64_encode(file) { |
76 | return new Buffer(bitmap).toString('base64'); | 87 | return new Buffer(bitmap).toString('base64'); |
77 | } | 88 | } |
78 | 89 | ||
90 | +function save_Result_image(file, type, index){ | ||
91 | + var bitmap = fs.readFileSync(file); | ||
92 | + var filePath = './' + type + '/' + index + '.jpg'; | ||
93 | + fs.writeFile(filePath, bitmap, function(err){ | ||
94 | + console.log('save'); | ||
95 | + }); | ||
96 | +} | ||
97 | + | ||
79 | module.exports = router; | 98 | module.exports = router; |
... | \ No newline at end of file | ... | \ No newline at end of file | ... | ... |
Back-end/data/frame_268x480_1.jpg
0 → 100644
16.3 KB
Back-end/data/frame_268x480_2.jpg
0 → 100644
21.9 KB
Back-end/data/frame_268x480_3.jpg
0 → 100644
25.9 KB
Back-end/data/frame_268x480_4.jpg
0 → 100644
21.2 KB
Back-end/data/frame_268x480_5.jpg
0 → 100644
17.6 KB
Back-end/data/temp.mp4
0 → 100644
No preview for this file type
... | @@ -4,11 +4,31 @@ | ... | @@ -4,11 +4,31 @@ |
4 | "lockfileVersion": 1, | 4 | "lockfileVersion": 1, |
5 | "requires": true, | 5 | "requires": true, |
6 | "dependencies": { | 6 | "dependencies": { |
7 | + "@types/concat-stream": { | ||
8 | + "version": "1.6.0", | ||
9 | + "resolved": "https://registry.npmjs.org/@types/concat-stream/-/concat-stream-1.6.0.tgz", | ||
10 | + "integrity": "sha1-OU2+C7X+5Gs42JZzXoto7yOQ0A0=", | ||
11 | + "requires": { | ||
12 | + "@types/node": "*" | ||
13 | + } | ||
14 | + }, | ||
15 | + "@types/form-data": { | ||
16 | + "version": "0.0.33", | ||
17 | + "resolved": "https://registry.npmjs.org/@types/form-data/-/form-data-0.0.33.tgz", | ||
18 | + "integrity": "sha1-yayFsqX9GENbjIXZ7LUObWyJP/g=", | ||
19 | + "requires": { | ||
20 | + "@types/node": "*" | ||
21 | + } | ||
22 | + }, | ||
7 | "@types/node": { | 23 | "@types/node": { |
8 | "version": "14.0.14", | 24 | "version": "14.0.14", |
9 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.0.14.tgz", | 25 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.0.14.tgz", |
10 | - "integrity": "sha512-syUgf67ZQpaJj01/tRTknkMNoBBLWJOBODF0Zm4NrXmiSuxjymFrxnTu1QVYRubhVkRcZLYZG8STTwJRdVm/WQ==", | 26 | + "integrity": "sha512-syUgf67ZQpaJj01/tRTknkMNoBBLWJOBODF0Zm4NrXmiSuxjymFrxnTu1QVYRubhVkRcZLYZG8STTwJRdVm/WQ==" |
11 | - "optional": true | 27 | + }, |
28 | + "@types/qs": { | ||
29 | + "version": "6.9.3", | ||
30 | + "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.3.tgz", | ||
31 | + "integrity": "sha512-7s9EQWupR1fTc2pSMtXRQ9w9gLOcrJn+h7HOXw4evxyvVqMi4f+q7d2tnFe3ng3SNHjtK+0EzGMGFUQX4/AQRA==" | ||
12 | }, | 32 | }, |
13 | "accepts": { | 33 | "accepts": { |
14 | "version": "1.3.7", | 34 | "version": "1.3.7", |
... | @@ -54,6 +74,11 @@ | ... | @@ -54,6 +74,11 @@ |
54 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", | 74 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", |
55 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" | 75 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" |
56 | }, | 76 | }, |
77 | + "asap": { | ||
78 | + "version": "2.0.6", | ||
79 | + "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", | ||
80 | + "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=" | ||
81 | + }, | ||
57 | "asn1": { | 82 | "asn1": { |
58 | "version": "0.2.4", | 83 | "version": "0.2.4", |
59 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", | 84 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", |
... | @@ -107,6 +132,11 @@ | ... | @@ -107,6 +132,11 @@ |
107 | "type-is": "~1.6.17" | 132 | "type-is": "~1.6.17" |
108 | } | 133 | } |
109 | }, | 134 | }, |
135 | + "buffer-from": { | ||
136 | + "version": "1.1.1", | ||
137 | + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", | ||
138 | + "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==" | ||
139 | + }, | ||
110 | "bytes": { | 140 | "bytes": { |
111 | "version": "3.1.0", | 141 | "version": "3.1.0", |
112 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", | 142 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", |
... | @@ -130,6 +160,17 @@ | ... | @@ -130,6 +160,17 @@ |
130 | "delayed-stream": "~1.0.0" | 160 | "delayed-stream": "~1.0.0" |
131 | } | 161 | } |
132 | }, | 162 | }, |
163 | + "concat-stream": { | ||
164 | + "version": "1.6.2", | ||
165 | + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", | ||
166 | + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", | ||
167 | + "requires": { | ||
168 | + "buffer-from": "^1.0.0", | ||
169 | + "inherits": "^2.0.3", | ||
170 | + "readable-stream": "^2.2.2", | ||
171 | + "typedarray": "^0.0.6" | ||
172 | + } | ||
173 | + }, | ||
133 | "console-control-strings": { | 174 | "console-control-strings": { |
134 | "version": "1.1.0", | 175 | "version": "1.1.0", |
135 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", | 176 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", |
... | @@ -341,6 +382,11 @@ | ... | @@ -341,6 +382,11 @@ |
341 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", | 382 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", |
342 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" | 383 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" |
343 | }, | 384 | }, |
385 | + "fs": { | ||
386 | + "version": "0.0.1-security", | ||
387 | + "resolved": "https://registry.npmjs.org/fs/-/fs-0.0.1-security.tgz", | ||
388 | + "integrity": "sha1-invTcYa23d84E/I4WLV+yq9eQdQ=" | ||
389 | + }, | ||
344 | "gauge": { | 390 | "gauge": { |
345 | "version": "2.7.4", | 391 | "version": "2.7.4", |
346 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", | 392 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", |
... | @@ -356,6 +402,11 @@ | ... | @@ -356,6 +402,11 @@ |
356 | "wide-align": "^1.1.0" | 402 | "wide-align": "^1.1.0" |
357 | } | 403 | } |
358 | }, | 404 | }, |
405 | + "get-port": { | ||
406 | + "version": "3.2.0", | ||
407 | + "resolved": "https://registry.npmjs.org/get-port/-/get-port-3.2.0.tgz", | ||
408 | + "integrity": "sha1-3Xzn3hh8Bsi/NTeWrHHgmfCYDrw=" | ||
409 | + }, | ||
359 | "getpass": { | 410 | "getpass": { |
360 | "version": "0.1.7", | 411 | "version": "0.1.7", |
361 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", | 412 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", |
... | @@ -383,6 +434,17 @@ | ... | @@ -383,6 +434,17 @@ |
383 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", | 434 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", |
384 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" | 435 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" |
385 | }, | 436 | }, |
437 | + "http-basic": { | ||
438 | + "version": "8.1.3", | ||
439 | + "resolved": "https://registry.npmjs.org/http-basic/-/http-basic-8.1.3.tgz", | ||
440 | + "integrity": "sha512-/EcDMwJZh3mABI2NhGfHOGOeOZITqfkEO4p/xK+l3NpyncIHUQBoMvCSF/b5GqvKtySC2srL/GGG3+EtlqlmCw==", | ||
441 | + "requires": { | ||
442 | + "caseless": "^0.12.0", | ||
443 | + "concat-stream": "^1.6.2", | ||
444 | + "http-response-object": "^3.0.1", | ||
445 | + "parse-cache-control": "^1.0.1" | ||
446 | + } | ||
447 | + }, | ||
386 | "http-errors": { | 448 | "http-errors": { |
387 | "version": "1.7.2", | 449 | "version": "1.7.2", |
388 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", | 450 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", |
... | @@ -395,6 +457,21 @@ | ... | @@ -395,6 +457,21 @@ |
395 | "toidentifier": "1.0.0" | 457 | "toidentifier": "1.0.0" |
396 | } | 458 | } |
397 | }, | 459 | }, |
460 | + "http-response-object": { | ||
461 | + "version": "3.0.2", | ||
462 | + "resolved": "https://registry.npmjs.org/http-response-object/-/http-response-object-3.0.2.tgz", | ||
463 | + "integrity": "sha512-bqX0XTF6fnXSQcEJ2Iuyr75yVakyjIDCqroJQ/aHfSdlM743Cwqoi2nDYMzLGWUcuTWGWy8AAvOKXTfiv6q9RA==", | ||
464 | + "requires": { | ||
465 | + "@types/node": "^10.0.3" | ||
466 | + }, | ||
467 | + "dependencies": { | ||
468 | + "@types/node": { | ||
469 | + "version": "10.17.26", | ||
470 | + "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.26.tgz", | ||
471 | + "integrity": "sha512-myMwkO2Cr82kirHY8uknNRHEVtn0wV3DTQfkrjx17jmkstDRZ24gNUdl8AHXVyVclTYI/bNjgTPTAWvWLqXqkw==" | ||
472 | + } | ||
473 | + } | ||
474 | + }, | ||
398 | "http-signature": { | 475 | "http-signature": { |
399 | "version": "1.2.0", | 476 | "version": "1.2.0", |
400 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", | 477 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", |
... | @@ -533,6 +610,11 @@ | ... | @@ -533,6 +610,11 @@ |
533 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", | 610 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", |
534 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" | 611 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" |
535 | }, | 612 | }, |
613 | + "node-fetch": { | ||
614 | + "version": "2.6.0", | ||
615 | + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.0.tgz", | ||
616 | + "integrity": "sha512-8dG4H5ujfvFiqDmVu9fQ5bOHUC15JMjMY/Zumv26oOvvVJjM67KF8koCWIabKQ1GJIa9r2mMZscBq/TbdOcmNA==" | ||
617 | + }, | ||
536 | "npmlog": { | 618 | "npmlog": { |
537 | "version": "4.1.2", | 619 | "version": "4.1.2", |
538 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", | 620 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", |
... | @@ -587,6 +669,11 @@ | ... | @@ -587,6 +669,11 @@ |
587 | "opencv-build": "^0.1.9" | 669 | "opencv-build": "^0.1.9" |
588 | } | 670 | } |
589 | }, | 671 | }, |
672 | + "parse-cache-control": { | ||
673 | + "version": "1.0.1", | ||
674 | + "resolved": "https://registry.npmjs.org/parse-cache-control/-/parse-cache-control-1.0.1.tgz", | ||
675 | + "integrity": "sha1-juqz5U+laSD+Fro493+iGqzC104=" | ||
676 | + }, | ||
590 | "parseurl": { | 677 | "parseurl": { |
591 | "version": "1.3.3", | 678 | "version": "1.3.3", |
592 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", | 679 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", |
... | @@ -621,6 +708,14 @@ | ... | @@ -621,6 +708,14 @@ |
621 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", | 708 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", |
622 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" | 709 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" |
623 | }, | 710 | }, |
711 | + "promise": { | ||
712 | + "version": "8.1.0", | ||
713 | + "resolved": "https://registry.npmjs.org/promise/-/promise-8.1.0.tgz", | ||
714 | + "integrity": "sha512-W04AqnILOL/sPRXziNicCjSNRruLAuIHEOVBazepu0545DDNGYHz7ar9ZgZ1fMU8/MA4mVxp5rkBWRi6OXIy3Q==", | ||
715 | + "requires": { | ||
716 | + "asap": "~2.0.6" | ||
717 | + } | ||
718 | + }, | ||
624 | "proxy-addr": { | 719 | "proxy-addr": { |
625 | "version": "2.0.6", | 720 | "version": "2.0.6", |
626 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", | 721 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", |
... | @@ -819,6 +914,49 @@ | ... | @@ -819,6 +914,49 @@ |
819 | "ansi-regex": "^2.0.0" | 914 | "ansi-regex": "^2.0.0" |
820 | } | 915 | } |
821 | }, | 916 | }, |
917 | + "sync-request": { | ||
918 | + "version": "6.1.0", | ||
919 | + "resolved": "https://registry.npmjs.org/sync-request/-/sync-request-6.1.0.tgz", | ||
920 | + "integrity": "sha512-8fjNkrNlNCrVc/av+Jn+xxqfCjYaBoHqCsDz6mt030UMxJGr+GSfCV1dQt2gRtlL63+VPidwDVLr7V2OcTSdRw==", | ||
921 | + "requires": { | ||
922 | + "http-response-object": "^3.0.1", | ||
923 | + "sync-rpc": "^1.2.1", | ||
924 | + "then-request": "^6.0.0" | ||
925 | + } | ||
926 | + }, | ||
927 | + "sync-rpc": { | ||
928 | + "version": "1.3.6", | ||
929 | + "resolved": "https://registry.npmjs.org/sync-rpc/-/sync-rpc-1.3.6.tgz", | ||
930 | + "integrity": "sha512-J8jTXuZzRlvU7HemDgHi3pGnh/rkoqR/OZSjhTyyZrEkkYQbk7Z33AXp37mkPfPpfdOuj7Ex3H/TJM1z48uPQw==", | ||
931 | + "requires": { | ||
932 | + "get-port": "^3.1.0" | ||
933 | + } | ||
934 | + }, | ||
935 | + "then-request": { | ||
936 | + "version": "6.0.2", | ||
937 | + "resolved": "https://registry.npmjs.org/then-request/-/then-request-6.0.2.tgz", | ||
938 | + "integrity": "sha512-3ZBiG7JvP3wbDzA9iNY5zJQcHL4jn/0BWtXIkagfz7QgOL/LqjCEOBQuJNZfu0XYnv5JhKh+cDxCPM4ILrqruA==", | ||
939 | + "requires": { | ||
940 | + "@types/concat-stream": "^1.6.0", | ||
941 | + "@types/form-data": "0.0.33", | ||
942 | + "@types/node": "^8.0.0", | ||
943 | + "@types/qs": "^6.2.31", | ||
944 | + "caseless": "~0.12.0", | ||
945 | + "concat-stream": "^1.6.0", | ||
946 | + "form-data": "^2.2.0", | ||
947 | + "http-basic": "^8.1.1", | ||
948 | + "http-response-object": "^3.0.1", | ||
949 | + "promise": "^8.0.0", | ||
950 | + "qs": "^6.4.0" | ||
951 | + }, | ||
952 | + "dependencies": { | ||
953 | + "@types/node": { | ||
954 | + "version": "8.10.61", | ||
955 | + "resolved": "https://registry.npmjs.org/@types/node/-/node-8.10.61.tgz", | ||
956 | + "integrity": "sha512-l+zSbvT8TPRaCxL1l9cwHCb0tSqGAGcjPJFItGGYat5oCTiq1uQQKYg5m7AF1mgnEBzFXGLJ2LRmNjtreRX76Q==" | ||
957 | + } | ||
958 | + } | ||
959 | + }, | ||
822 | "toidentifier": { | 960 | "toidentifier": { |
823 | "version": "1.0.0", | 961 | "version": "1.0.0", |
824 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", | 962 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", |
... | @@ -855,6 +993,11 @@ | ... | @@ -855,6 +993,11 @@ |
855 | "mime-types": "~2.1.24" | 993 | "mime-types": "~2.1.24" |
856 | } | 994 | } |
857 | }, | 995 | }, |
996 | + "typedarray": { | ||
997 | + "version": "0.0.6", | ||
998 | + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", | ||
999 | + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" | ||
1000 | + }, | ||
858 | "unpipe": { | 1001 | "unpipe": { |
859 | "version": "1.0.0", | 1002 | "version": "1.0.0", |
860 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", | 1003 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", | ... | ... |
... | @@ -14,8 +14,11 @@ | ... | @@ -14,8 +14,11 @@ |
14 | "cors": "^2.8.5", | 14 | "cors": "^2.8.5", |
15 | "express": "^4.17.1", | 15 | "express": "^4.17.1", |
16 | "ffmpeg": "0.0.4", | 16 | "ffmpeg": "0.0.4", |
17 | + "fs": "0.0.1-security", | ||
18 | + "node-fetch": "^2.6.0", | ||
17 | "opencv4nodejs": "^5.6.0", | 19 | "opencv4nodejs": "^5.6.0", |
18 | "path": "^0.12.7", | 20 | "path": "^0.12.7", |
19 | - "request": "^2.88.2" | 21 | + "request": "^2.88.2", |
22 | + "sync-request": "^6.1.0" | ||
20 | } | 23 | } |
21 | } | 24 | } | ... | ... |
... | @@ -12,5 +12,5 @@ app.use(bodyParser.urlencoded({limit: '100mb', extended: true})); | ... | @@ -12,5 +12,5 @@ app.use(bodyParser.urlencoded({limit: '100mb', extended: true})); |
12 | app.use(bodyParser()); | 12 | app.use(bodyParser()); |
13 | app.use('/api', api); | 13 | app.use('/api', api); |
14 | 14 | ||
15 | -const port = 3003; | 15 | +const port = 3004; |
16 | app.listen(port, () => console.log(`노드서버 시작 : ${port}`)); | 16 | app.listen(port, () => console.log(`노드서버 시작 : ${port}`)); | ... | ... |
Back-end/unknown/0.jpg
0 → 100644
16.3 KB
Back-end/unknown/1.jpg
0 → 100644
21.9 KB
Back-end/unknown/2.jpg
0 → 100644
25.9 KB
1 | import React from 'react'; | 1 | import React from 'react'; |
2 | import PropTypes from 'prop-types'; | 2 | import PropTypes from 'prop-types'; |
3 | import { connect } from 'react-redux'; | 3 | import { connect } from 'react-redux'; |
4 | -import { Switch, Route, withRouter, Redirect } from 'react-router'; | 4 | +import { Switch, Route, withRouter } from 'react-router'; |
5 | import { TransitionGroup, CSSTransition } from 'react-transition-group'; | 5 | import { TransitionGroup, CSSTransition } from 'react-transition-group'; |
6 | import Hammer from 'rc-hammerjs'; | 6 | import Hammer from 'rc-hammerjs'; |
7 | 7 | ... | ... |
... | @@ -7,7 +7,6 @@ import { | ... | @@ -7,7 +7,6 @@ import { |
7 | Button, | 7 | Button, |
8 | Form, | 8 | Form, |
9 | FormGroup, | 9 | FormGroup, |
10 | - Label, | ||
11 | } from 'reactstrap'; | 10 | } from 'reactstrap'; |
12 | 11 | ||
13 | class Subject extends PureComponent { | 12 | class Subject extends PureComponent { |
... | @@ -36,12 +35,24 @@ class Subject extends PureComponent { | ... | @@ -36,12 +35,24 @@ class Subject extends PureComponent { |
36 | 35 | ||
37 | onClickSaveImage(e) { | 36 | onClickSaveImage(e) { |
38 | e.preventDefault(); | 37 | e.preventDefault(); |
39 | - console.log(this.state.imageFiles); | ||
40 | console.log("save image"); | 38 | console.log("save image"); |
41 | - this.setState({ | ||
42 | - imageFiles:[], | ||
43 | - }); | ||
44 | // post request | 39 | // post request |
40 | + fetch('http://localhost:3004/api/saveImage',{ | ||
41 | + method: 'POST', | ||
42 | + mode: 'cors', | ||
43 | + cache: 'no-cache', | ||
44 | + credentials: 'same-origin', | ||
45 | + headers: { | ||
46 | + 'Content-Type': 'application/json', | ||
47 | + }, | ||
48 | + redirect: 'follow', | ||
49 | + referrer: 'no-referrer', | ||
50 | + body: JSON.stringify(this.state.imageFiles) | ||
51 | + }) | ||
52 | + .then(res=>res.json()) | ||
53 | + .then(data=>this.setState({videoAnalysisResult:data})) | ||
54 | + | ||
55 | + console.log(this.state.videoAnalysisResult); | ||
45 | } | 56 | } |
46 | 57 | ||
47 | render() { | 58 | render() { |
... | @@ -66,7 +77,7 @@ class Subject extends PureComponent { | ... | @@ -66,7 +77,7 @@ class Subject extends PureComponent { |
66 | /> | 77 | /> |
67 | {this.state.imageFiles.length > 0 ? <div> | 78 | {this.state.imageFiles.length > 0 ? <div> |
68 | {this.state.imageFiles.map((file, idx) => ( | 79 | {this.state.imageFiles.map((file, idx) => ( |
69 | - <img alt="..." src={file.preview} key={`img-id-${idx.toString()}`} />))} | 80 | + <img style={{height: '200px'}}alt="..." src={file.preview} key={`img-id-${idx.toString()}`} />))} |
70 | </div> : <img | 81 | </div> : <img |
71 | alt="..." | 82 | alt="..." |
72 | src="" | 83 | src="" | ... | ... |
... | @@ -10,6 +10,8 @@ import { | ... | @@ -10,6 +10,8 @@ import { |
10 | } from 'reactstrap'; | 10 | } from 'reactstrap'; |
11 | 11 | ||
12 | import Widget from '../../components/Widget/Widget'; | 12 | import Widget from '../../components/Widget/Widget'; |
13 | +var fireResultImages=[]; | ||
14 | +var unknownResultImages=[]; | ||
13 | 15 | ||
14 | class Dashboard extends React.Component { | 16 | class Dashboard extends React.Component { |
15 | constructor(props) { | 17 | constructor(props) { |
... | @@ -19,9 +21,13 @@ class Dashboard extends React.Component { | ... | @@ -19,9 +21,13 @@ class Dashboard extends React.Component { |
19 | // this.analysisVideo = this.analysisVideo.bind(this); | 21 | // this.analysisVideo = this.analysisVideo.bind(this); |
20 | this.state = { | 22 | this.state = { |
21 | videoFiles: [], | 23 | videoFiles: [], |
22 | - videoAnalysisResult:null | 24 | + videoAnalysisResult:null, |
23 | }; | 25 | }; |
24 | } | 26 | } |
27 | + | ||
28 | + importAll(r){ | ||
29 | + return r.keys().map(r); | ||
30 | + } | ||
25 | 31 | ||
26 | onChangeInputVideo(e) { | 32 | onChangeInputVideo(e) { |
27 | const files = []; | 33 | const files = []; |
... | @@ -39,11 +45,9 @@ class Dashboard extends React.Component { | ... | @@ -39,11 +45,9 @@ class Dashboard extends React.Component { |
39 | 45 | ||
40 | onClickSaveVideo(e) { | 46 | onClickSaveVideo(e) { |
41 | e.preventDefault(); | 47 | e.preventDefault(); |
42 | - console.log(this.state.videoFiles); | ||
43 | console.log("upload video"); | 48 | console.log("upload video"); |
44 | - | ||
45 | // post request | 49 | // post request |
46 | - fetch('http://localhost:3002/api/videoResult',{ | 50 | + fetch('http://localhost:3004/api/videoResult',{ |
47 | method: 'POST', | 51 | method: 'POST', |
48 | mode: 'cors', | 52 | mode: 'cors', |
49 | cache: 'no-cache', | 53 | cache: 'no-cache', |
... | @@ -66,9 +70,13 @@ class Dashboard extends React.Component { | ... | @@ -66,9 +70,13 @@ class Dashboard extends React.Component { |
66 | performance: PropTypes.any, | 70 | performance: PropTypes.any, |
67 | }; | 71 | }; |
68 | 72 | ||
73 | + componentWillMount(){ | ||
74 | + fireResultImages= this.importAll(require.context('../../../../Back-end/fire/', false, /\.(png|jpg|svg)$/)) | ||
75 | + unknownResultImages= this.importAll(require.context('../../../../Back-end/unknown/', false, /\.(png|jpg|svg)$/)) | ||
76 | + } | ||
77 | + | ||
69 | render() { | 78 | render() { |
70 | - console.log("render") | 79 | + console.log(this.state.videoAnalysisResult); |
71 | - console.log(this.state.videoFiles) | ||
72 | return ( | 80 | return ( |
73 | <div> | 81 | <div> |
74 | <h1 className="page-title">Video Analysis <small><small>Performance</small></small></h1> | 82 | <h1 className="page-title">Video Analysis <small><small>Performance</small></small></h1> |
... | @@ -100,9 +108,20 @@ class Dashboard extends React.Component { | ... | @@ -100,9 +108,20 @@ class Dashboard extends React.Component { |
100 | title={<h5><span className="fw-semi-bold">Results</span></h5>} | 108 | title={<h5><span className="fw-semi-bold">Results</span></h5>} |
101 | > | 109 | > |
102 | <div> | 110 | <div> |
103 | - <div className="text-center" style={{ height: '300px' }} /> | 111 | + {fireResultImages.length > 0 ? <div> |
104 | - <p className="fs-mini text-muted"> | 112 | + <p className="fw-semi-bold"> 불났어요!! |
105 | </p> | 113 | </p> |
114 | + {fireResultImages.map( | ||
115 | + (image, index) => <img style={{height: '200px', margin: '10px 10px 10px 10px'}}alt="..." key={index} src={image}/>)} | ||
116 | + </div> : <div/>} | ||
117 | + </div> | ||
118 | + <div> | ||
119 | + {unknownResultImages.length > 0 ? <div> | ||
120 | + <p className="fw-semi-bold"> 침입자 발생!! | ||
121 | + </p> | ||
122 | + {unknownResultImages.map( | ||
123 | + (image, index) => <img style={{height: '200px', margin: '10px 10px 10px 10px'}}alt="..." key={index} src={image}/>)} | ||
124 | + </div> : <div/>} | ||
106 | </div> | 125 | </div> |
107 | </Widget> | 126 | </Widget> |
108 | </Col> | 127 | </Col> |
... | @@ -118,23 +137,4 @@ function mapStateToProps(state) { | ... | @@ -118,23 +137,4 @@ function mapStateToProps(state) { |
118 | } | 137 | } |
119 | } | 138 | } |
120 | 139 | ||
121 | - | ||
122 | -export default connect(mapStateToProps)(Dashboard); | ||
123 | - | ||
124 | -function postData(url = '', data = {}) { | ||
125 | - // Default options are marked with * | ||
126 | - return fetch(url, { | ||
127 | - method: 'POST', // *GET, POST, PUT, DELETE, etc. | ||
128 | - mode: 'cors', // no-cors, cors, *same-origin | ||
129 | - cache: 'no-cache', // *default, no-cache, reload, force-cache, only-if-cached | ||
130 | - credentials: 'same-origin', // include, *same-origin, omit | ||
131 | - headers: { | ||
132 | - 'Content-Type': 'application/json', | ||
133 | - // 'Content-Type': 'application/x-www-form-urlencoded', | ||
134 | - }, | ||
135 | - redirect: 'follow', // manual, *follow, error | ||
136 | - referrer: 'no-referrer', // no-referrer, *client | ||
137 | - body: JSON.stringify(data), // body data type must match "Content-Type" header | ||
138 | - }) | ||
139 | - .then(response => response.json()); // parses JSON response into native JavaScript objects | ||
140 | -} | ||
... | \ No newline at end of file | ... | \ No newline at end of file |
140 | +export default connect(mapStateToProps)(Dashboard); | ||
... | \ No newline at end of file | ... | \ No newline at end of file | ... | ... |
-
Please register or login to post a comment