xwwww commited on
Commit
d007ed6
1 Parent(s): 8c28aed

Upload 13 files

Browse files
.vscode/settings.json ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ {
2
+ "nuxt.isNuxtApp": false
3
+ }
LICENSE ADDED
@@ -0,0 +1,201 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ Apache License
2
+ Version 2.0, January 2004
3
+ http://www.apache.org/licenses/
4
+
5
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6
+
7
+ 1. Definitions.
8
+
9
+ "License" shall mean the terms and conditions for use, reproduction,
10
+ and distribution as defined by Sections 1 through 9 of this document.
11
+
12
+ "Licensor" shall mean the copyright owner or entity authorized by
13
+ the copyright owner that is granting the License.
14
+
15
+ "Legal Entity" shall mean the union of the acting entity and all
16
+ other entities that control, are controlled by, or are under common
17
+ control with that entity. For the purposes of this definition,
18
+ "control" means (i) the power, direct or indirect, to cause the
19
+ direction or management of such entity, whether by contract or
20
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
21
+ outstanding shares, or (iii) beneficial ownership of such entity.
22
+
23
+ "You" (or "Your") shall mean an individual or Legal Entity
24
+ exercising permissions granted by this License.
25
+
26
+ "Source" form shall mean the preferred form for making modifications,
27
+ including but not limited to software source code, documentation
28
+ source, and configuration files.
29
+
30
+ "Object" form shall mean any form resulting from mechanical
31
+ transformation or translation of a Source form, including but
32
+ not limited to compiled object code, generated documentation,
33
+ and conversions to other media types.
34
+
35
+ "Work" shall mean the work of authorship, whether in Source or
36
+ Object form, made available under the License, as indicated by a
37
+ copyright notice that is included in or attached to the work
38
+ (an example is provided in the Appendix below).
39
+
40
+ "Derivative Works" shall mean any work, whether in Source or Object
41
+ form, that is based on (or derived from) the Work and for which the
42
+ editorial revisions, annotations, elaborations, or other modifications
43
+ represent, as a whole, an original work of authorship. For the purposes
44
+ of this License, Derivative Works shall not include works that remain
45
+ separable from, or merely link (or bind by name) to the interfaces of,
46
+ the Work and Derivative Works thereof.
47
+
48
+ "Contribution" shall mean any work of authorship, including
49
+ the original version of the Work and any modifications or additions
50
+ to that Work or Derivative Works thereof, that is intentionally
51
+ submitted to Licensor for inclusion in the Work by the copyright owner
52
+ or by an individual or Legal Entity authorized to submit on behalf of
53
+ the copyright owner. For the purposes of this definition, "submitted"
54
+ means any form of electronic, verbal, or written communication sent
55
+ to the Licensor or its representatives, including but not limited to
56
+ communication on electronic mailing lists, source code control systems,
57
+ and issue tracking systems that are managed by, or on behalf of, the
58
+ Licensor for the purpose of discussing and improving the Work, but
59
+ excluding communication that is conspicuously marked or otherwise
60
+ designated in writing by the copyright owner as "Not a Contribution."
61
+
62
+ "Contributor" shall mean Licensor and any individual or Legal Entity
63
+ on behalf of whom a Contribution has been received by Licensor and
64
+ subsequently incorporated within the Work.
65
+
66
+ 2. Grant of Copyright License. Subject to the terms and conditions of
67
+ this License, each Contributor hereby grants to You a perpetual,
68
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
69
+ copyright license to reproduce, prepare Derivative Works of,
70
+ publicly display, publicly perform, sublicense, and distribute the
71
+ Work and such Derivative Works in Source or Object form.
72
+
73
+ 3. Grant of Patent License. Subject to the terms and conditions of
74
+ this License, each Contributor hereby grants to You a perpetual,
75
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76
+ (except as stated in this section) patent license to make, have made,
77
+ use, offer to sell, sell, import, and otherwise transfer the Work,
78
+ where such license applies only to those patent claims licensable
79
+ by such Contributor that are necessarily infringed by their
80
+ Contribution(s) alone or by combination of their Contribution(s)
81
+ with the Work to which such Contribution(s) was submitted. If You
82
+ institute patent litigation against any entity (including a
83
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
84
+ or a Contribution incorporated within the Work constitutes direct
85
+ or contributory patent infringement, then any patent licenses
86
+ granted to You under this License for that Work shall terminate
87
+ as of the date such litigation is filed.
88
+
89
+ 4. Redistribution. You may reproduce and distribute copies of the
90
+ Work or Derivative Works thereof in any medium, with or without
91
+ modifications, and in Source or Object form, provided that You
92
+ meet the following conditions:
93
+
94
+ (a) You must give any other recipients of the Work or
95
+ Derivative Works a copy of this License; and
96
+
97
+ (b) You must cause any modified files to carry prominent notices
98
+ stating that You changed the files; and
99
+
100
+ (c) You must retain, in the Source form of any Derivative Works
101
+ that You distribute, all copyright, patent, trademark, and
102
+ attribution notices from the Source form of the Work,
103
+ excluding those notices that do not pertain to any part of
104
+ the Derivative Works; and
105
+
106
+ (d) If the Work includes a "NOTICE" text file as part of its
107
+ distribution, then any Derivative Works that You distribute must
108
+ include a readable copy of the attribution notices contained
109
+ within such NOTICE file, excluding those notices that do not
110
+ pertain to any part of the Derivative Works, in at least one
111
+ of the following places: within a NOTICE text file distributed
112
+ as part of the Derivative Works; within the Source form or
113
+ documentation, if provided along with the Derivative Works; or,
114
+ within a display generated by the Derivative Works, if and
115
+ wherever such third-party notices normally appear. The contents
116
+ of the NOTICE file are for informational purposes only and
117
+ do not modify the License. You may add Your own attribution
118
+ notices within Derivative Works that You distribute, alongside
119
+ or as an addendum to the NOTICE text from the Work, provided
120
+ that such additional attribution notices cannot be construed
121
+ as modifying the License.
122
+
123
+ You may add Your own copyright statement to Your modifications and
124
+ may provide additional or different license terms and conditions
125
+ for use, reproduction, or distribution of Your modifications, or
126
+ for any such Derivative Works as a whole, provided Your use,
127
+ reproduction, and distribution of the Work otherwise complies with
128
+ the conditions stated in this License.
129
+
130
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
131
+ any Contribution intentionally submitted for inclusion in the Work
132
+ by You to the Licensor shall be under the terms and conditions of
133
+ this License, without any additional terms or conditions.
134
+ Notwithstanding the above, nothing herein shall supersede or modify
135
+ the terms of any separate license agreement you may have executed
136
+ with Licensor regarding such Contributions.
137
+
138
+ 6. Trademarks. This License does not grant permission to use the trade
139
+ names, trademarks, service marks, or product names of the Licensor,
140
+ except as required for reasonable and customary use in describing the
141
+ origin of the Work and reproducing the content of the NOTICE file.
142
+
143
+ 7. Disclaimer of Warranty. Unless required by applicable law or
144
+ agreed to in writing, Licensor provides the Work (and each
145
+ Contributor provides its Contributions) on an "AS IS" BASIS,
146
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
147
+ implied, including, without limitation, any warranties or conditions
148
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
149
+ PARTICULAR PURPOSE. You are solely responsible for determining the
150
+ appropriateness of using or redistributing the Work and assume any
151
+ risks associated with Your exercise of permissions under this License.
152
+
153
+ 8. Limitation of Liability. In no event and under no legal theory,
154
+ whether in tort (including negligence), contract, or otherwise,
155
+ unless required by applicable law (such as deliberate and grossly
156
+ negligent acts) or agreed to in writing, shall any Contributor be
157
+ liable to You for damages, including any direct, indirect, special,
158
+ incidental, or consequential damages of any character arising as a
159
+ result of this License or out of the use or inability to use the
160
+ Work (including but not limited to damages for loss of goodwill,
161
+ work stoppage, computer failure or malfunction, or any and all
162
+ other commercial damages or losses), even if such Contributor
163
+ has been advised of the possibility of such damages.
164
+
165
+ 9. Accepting Warranty or Additional Liability. While redistributing
166
+ the Work or Derivative Works thereof, You may choose to offer,
167
+ and charge a fee for, acceptance of support, warranty, indemnity,
168
+ or other liability obligations and/or rights consistent with this
169
+ License. However, in accepting such obligations, You may act only
170
+ on Your own behalf and on Your sole responsibility, not on behalf
171
+ of any other Contributor, and only if You agree to indemnify,
172
+ defend, and hold each Contributor harmless for any liability
173
+ incurred by, or claims asserted against, such Contributor by reason
174
+ of your accepting any such warranty or additional liability.
175
+
176
+ END OF TERMS AND CONDITIONS
177
+
178
+ APPENDIX: How to apply the Apache License to your work.
179
+
180
+ To apply the Apache License to your work, attach the following
181
+ boilerplate notice, with the fields enclosed by brackets "[]"
182
+ replaced with your own identifying information. (Don't include
183
+ the brackets!) The text should be enclosed in the appropriate
184
+ comment syntax for the file format. We also recommend that a
185
+ file or class name and description of purpose be included on the
186
+ same "printed page" as the copyright notice for easier
187
+ identification within third-party archives.
188
+
189
+ Copyright [yyyy] [name of copyright owner]
190
+
191
+ Licensed under the Apache License, Version 2.0 (the "License");
192
+ you may not use this file except in compliance with the License.
193
+ You may obtain a copy of the License at
194
+
195
+ http://www.apache.org/licenses/LICENSE-2.0
196
+
197
+ Unless required by applicable law or agreed to in writing, software
198
+ distributed under the License is distributed on an "AS IS" BASIS,
199
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
200
+ See the License for the specific language governing permissions and
201
+ limitations under the License.
README.md CHANGED
@@ -1,9 +1,50 @@
1
- ---
2
- title: GT
3
- emoji: 💻
4
- colorFrom: blue
5
- colorTo: pink
6
- sdk: docker
7
- pinned: false
8
- ---
9
- 开源项目 https://gitee.com/QQ1146638442/GT-Manual
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # nsfwjs-img-check
2
+
3
+ #### 介绍
4
+ 一款基于nsfwjs实现的node版本的图片鉴黄服务
5
+
6
+ 在线体验案例:
7
+ [图片鉴黄服务](https://luckycola.com.cn/public/dist/#/checkImg)
8
+
9
+ #### 版本说明
10
+ node 版本:v16.11.1
11
+
12
+
13
+ #### 安装教程
14
+
15
+ 1. 下载该程序库
16
+ 2. 执行下面命令,下载依赖
17
+ ```js
18
+ yarn
19
+ ```
20
+ 3. 执行下面命令,启动服务
21
+ ```js
22
+ yarn start
23
+ ```
24
+
25
+ #### 使用说明
26
+
27
+ 1. 服务启动成功后,控制台会输出以下提示
28
+ ```js
29
+ 图片鉴黄服务器启动成功!port:3006
30
+ ```
31
+ 2. 服务启动成功后,就可以通过api使用服务啦
32
+
33
+
34
+ ```
35
+ 请求方式: POST
36
+ http://localhost:3006/checkImg
37
+
38
+ ```
39
+
40
+ **api参数说明:**
41
+ | 序号 | 参数 | 是否必须|说明 |
42
+ |--|--|--|--|
43
+ | 1 |file |是 | 需要鉴别的图片资源(png、jpg、jpeg、png格式),注意:该接口请求参数是**multipart/form-data**格式|
44
+
45
+
46
+
47
+ #### 在线官网
48
+ [http(s): //luckycola.com.cn](http://luckycola.com.cn)
49
+
50
+ ![输入图片说明](%E6%88%AA%E5%B1%8F2023-10-11%20%E4%B8%8A%E5%8D%8811.14.47.png)
app.js ADDED
@@ -0,0 +1,175 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ // 导入experss模块
2
+ const express=require("express");
3
+ let fs = require('fs');
4
+ // 创建服务器对象
5
+ let app = express();
6
+ // 导入body-parser插件
7
+ const bodyparser = require("body-parser");;
8
+ // 配置body-parser模块
9
+ app.use(bodyparser.urlencoded({extended:false}));
10
+ app.use(bodyparser.json());
11
+ // 导入系统模块path
12
+ const path = require("path");
13
+ const afs = require('fs-extra');
14
+
15
+ let multiparty = require('multiparty');
16
+ let imgJS = require("image-js");
17
+ const nsfw = require('nsfwjs');
18
+ const tf = require('@tensorflow/tfjs-node');
19
+ const safeContent = ['Drawing', 'Neutral']; // 设置图片内容安全的类型
20
+
21
+ // https://github.com/alex000kim/nsfw_data_scraper
22
+
23
+ let imgTypeoObj = {
24
+ Drawing: '艺术性的',
25
+ Neutral: '中性的',
26
+ Sexy: '性感的',
27
+ Porn: '色情的',
28
+ Hentai: '变态的',
29
+ };
30
+
31
+ //转换图片格式
32
+ const convert = async file => {
33
+ const image = await imgJS.Image.load(file.path);
34
+ const numChannels = 3;
35
+ const numPixels = image.width * image.height;
36
+ const values = new Int32Array(numPixels * numChannels);
37
+
38
+ for (let i = 0; i < numPixels; i++) {
39
+ for (let c = 0; c < numChannels; ++c) {
40
+ values[i * numChannels + c] = image.data[i * 4 + c];
41
+ }
42
+ }
43
+
44
+ return tf.tensor3d(values, [image.height, image.width, numChannels], 'int32');
45
+ };
46
+
47
+ // 初始化模型
48
+ let model;
49
+ (async function() {
50
+ model = await nsfw.load('file://./web_model/', {
51
+ type: 'graph'
52
+ });
53
+ })();
54
+
55
+
56
+ const isSafeContent = predictions => {
57
+ let safeProbability = 0;
58
+ let imgTypeValArr = [];
59
+ for (let index = 0; index < predictions.length; index++) {
60
+ const item = predictions[index];
61
+ const className = item.className;
62
+ const probability = item.probability;
63
+ if (safeContent.includes(className)) {
64
+ safeProbability += probability;
65
+ };
66
+ }
67
+ imgTypeValArr = predictions.sort((a, b) => b.probability - a.probability);
68
+ // console.log('imgTypeValArr:', imgTypeValArr);
69
+ let myimgType = '';
70
+ if (imgTypeValArr.length && imgTypeValArr[0]) {
71
+ myimgType = imgTypeoObj[imgTypeValArr[0].className];
72
+ }
73
+ return {
74
+ isSafe: safeProbability > 0.5,
75
+ imgType: myimgType
76
+ };
77
+ };
78
+
79
+ app.post('/checkImg',async (req, res) => {
80
+ try {
81
+ // 删除指定文件夹下面的所有文件或文件夹
82
+ try {
83
+ await afs.emptyDirSync('./tempImgs');
84
+ console.log('清空tempImgs成功');
85
+ } catch (error) {
86
+ console.log('清空tempImgs失败');
87
+ }
88
+ let form = new multiparty.Form();
89
+ // 设置文件存储路径,以当前编辑的文件为相对路径
90
+ form.uploadDir = './tempImgs';
91
+ form.parse(req, async (err, fields, files) => {
92
+ if (!files || !files.file[0]) {
93
+ return res.send({
94
+ code: -1,
95
+ msg: '请上传file图片资源(form-data格式)',
96
+ data: {}
97
+ })
98
+ }
99
+ // console.log('files.file[0]:', files.file[0]);
100
+ // 图片最大尺寸
101
+ if (files.file[0].size > 1024 * 1024 * 3) {
102
+ return res.send({
103
+ code: -2,
104
+ msg: '被检测图片最大3M',
105
+ data: {}
106
+ })
107
+ };
108
+ // 支持的图片类型
109
+ let imgReg = /\S+\.(png|jpeg|jpg)$/g;
110
+ let originImgName = files.file[0].originalFilename || files.file[0].path;
111
+ if (!imgReg.test(originImgName)) {
112
+ return res.send({
113
+ code: -3,
114
+ msg: '仅仅支持(png、jpeg、jpg)类型图片检测',
115
+ data: {}
116
+ })
117
+ }
118
+ let img = await convert(files.file[0]);
119
+ let predictions = await model.classify(img);
120
+ const {isSafe, imgType} = isSafeContent(predictions);
121
+ // console.log('是否安全:', predictions, isSafe);
122
+ res.send({
123
+ code: 0,
124
+ msg: isSafe ? '图片合规' : '图片可能存在不合规的风险,请核查',
125
+ data: {
126
+ isSafe,
127
+ imgType,
128
+ predictions,
129
+ }
130
+ })
131
+ });
132
+ } catch (error) {
133
+ res.send({
134
+ code: -9,
135
+ msg: '图片核查失败,请重试',
136
+ data: {}
137
+ })
138
+ }
139
+ });
140
+
141
+ // {
142
+ // "code": 0,
143
+ // "msg": "图片合规",
144
+ // "data": {
145
+ // "isSafe": true,
146
+ // "imgType": "艺术性的",
147
+ // "predictions": [
148
+ // {
149
+ // "className": "Drawing",
150
+ // "probability": 0.9533441662788391
151
+ // },
152
+ // {
153
+ // "className": "Neutral",
154
+ // "probability": 0.015517046675086021
155
+ // },
156
+ // {
157
+ // "className": "Sexy",
158
+ // "probability": 0.013940851204097271
159
+ // },
160
+ // {
161
+ // "className": "Porn",
162
+ // "probability": 0.012532410211861134
163
+ // },
164
+ // {
165
+ // "className": "Hentai",
166
+ // "probability": 0.004665587563067675
167
+ // }
168
+ // ]
169
+ // }
170
+ // }
171
+
172
+ // 监听端口
173
+ app.listen(3006,()=>{
174
+ console.log("图片鉴黄服务器启动成功!port:3006");
175
+ });
package.json ADDED
@@ -0,0 +1,21 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "checkimg",
3
+ "version": "1.0.0",
4
+ "description": "",
5
+ "main": "app.js",
6
+ "scripts": {
7
+ "test": "echo \"Error: no test specified\" && exit 1",
8
+ "start": "node app.js"
9
+ },
10
+ "keywords": [],
11
+ "author": "",
12
+ "license": "ISC",
13
+ "dependencies": {
14
+ "@tensorflow/tfjs-node": "^4.10.0",
15
+ "express": "^4.18.2",
16
+ "fs-extra": "^11.1.1",
17
+ "image-js": "^0.35.4",
18
+ "multiparty": "^4.2.3",
19
+ "nsfwjs": "^2.4.2"
20
+ }
21
+ }
web_model/group1-shard1of6.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:63a2c542142d09ca7fcf5d1122d75b60dca90784b5edd39088fbe76d2c9c48bb
3
+ size 4194304
web_model/group1-shard2of6.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:0b8b67fe8785b775f03132b416f4e7a8cf9f41ddbb89d711a879f7206931f1c2
3
+ size 4194304
web_model/group1-shard3of6.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:907937e7b268f657b2be309bcbb9b87d0fa759d74af5a405701aa90d7345cd47
3
+ size 4194304
web_model/group1-shard4of6.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:bb6d6e5032fd93c3a7c22314de0e5fa0ca3e2c1f21d19618e08f78a5080769c5
3
+ size 4194304
web_model/group1-shard5of6.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:9729acbe18c5199ed092370161aceddc299d1865295fecda7694d623ee59d0aa
3
+ size 4194304
web_model/group1-shard6of6.bin ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:494c4e36a43ec46a597810b1a9cce380c620bf976270eec87b0b185f85d8d2b3
3
+ size 3394932
web_model/model.json ADDED
The diff for this file is too large to render. See raw diff
 
yarn.lock ADDED
The diff for this file is too large to render. See raw diff