6. 安装mysql
npm install mysql
npm install @types/mysql -D
7. 新建mysql配置文件以及连接mysql
新建mysql.config.ts文件
data:image/s3,"s3://crabby-images/94369/9436993fb91f948c29713c892bb605aca132ecd3" alt=""
model目录下新建index.ts连接mysql,如果image表不存在则创建
data:image/s3,"s3://crabby-images/90560/90560d3fd6f24e7af5a5869525503f971dbe93dc" alt=""
data:image/s3,"s3://crabby-images/36b9b/36b9bded08ecd54191cbdabce61a51b9c1e7c60f" alt=""
最后入口server.js别忘了引入model
data:image/s3,"s3://crabby-images/c9c72/c9c728a7a4c4051e205c653dd60d881300ae0cbc" alt=""
image表已成功创建!
data:image/s3,"s3://crabby-images/8a345/8a345b242344040b7f0b211fada833e42c90802b" alt=""
8. 使用jade模板引擎新建upload.jade文件充当前端页面
这块不是重点,就是用express自带的jade模板写个文件上传的html页面
文件上传将会调用后端接口:http://localhost:3000/api/file_upload
在routes/index中追加路由,指向模板界面
data:image/s3,"s3://crabby-images/6be19/6be19502c084d81dbf3be93f0bd83d093744759b" alt=""
upload.jade内容如下
data:image/s3,"s3://crabby-images/98dc3/98dc3c098eb0edc3ffd180b422588c74e873c20a" alt=""
页面效果是这样的:
data:image/s3,"s3://crabby-images/bccd6/bccd64855ba8d5a766656b2751b1dda9812cd0c1" alt=""
9. 编写文件上传所需的api/file_upload接口
新建路由文件 route/api.ts(解耦嘛...)
data:image/s3,"s3://crabby-images/4d97d/4d97da4de4fb3bf660e782eb2302a01e0c71760c" alt=""
routes/api.ts中引入controller/api.ts文件
data:image/s3,"s3://crabby-images/afc2e/afc2e8aa2816830a0b39745f05a4f78882b298ee" alt=""
controller/api.ts内容如下(我们将文件上传和写入mysql的方法都封装了一下)
data:image/s3,"s3://crabby-images/8da27/8da27422764583b9a08ceebb5bbc16f1b0083c50" alt=""
文件上传方法:
data:image/s3,"s3://crabby-images/46c9a/46c9a0e262bb6d27c9af96015d71d665511b0d52" alt=""
这里用到了formidable包(这个包专门处理post上传文件的,这里不做具体描述),自然少不了安装包和包的声明文件
npm install formidable
npm install @types/formidable -D
官方文档内容如下:
data:image/s3,"s3://crabby-images/73eea/73eea21bab9e7f26a8dd565b6d3cba6fb1f56490" alt=""
上传记录写入mysql方法如下:
data:image/s3,"s3://crabby-images/2f81d/2f81d896957c2481e6d13183781acf5dc9e4ba8f" alt=""
10. 测试成功!将打包后的文件放入服务器中即可!
data:image/s3,"s3://crabby-images/15264/15264d90b3ecb9d8fa0bfc1f9fb939b1fb575496" alt=""
npm run build (tsc && node handle-public.js)打包之后的结果:
public和views等静态资源被我们通过shelljs复制到dist文件夹下了
data:image/s3,"s3://crabby-images/aa9ea/aa9ea0e0d1a0af4a1533d0afae8526c42505d28c" alt=""
网友评论