webpack-bundle-cdn-uploader
0.5.3 • Public • Published webpack-bundle-cdn-uploader
ENGLISH VERSION
在 Webpack 打包完成后自动将打包文件上传至对应 CDN 或 FTP, 开箱即用.
测试环境
- webpack 3@3.12.0
- webpack 4@4.35.0
安装/使用
npm install --save-dev webpack-bundle-cdn-uploader
const CdnUploadPlugin = require('webpack-bundle-cdn-uploader');
//实际参数以及介绍参考底下参数一栏
const uploaderOptions = {
cdn:{
type:'[qiniu|txcos|ftp|s3]',
accessKey:'[your.qiniu.access_key|your.txcos.secretId|your.s3.access]'
secretKey:'[your.qiniu.secret_key|your.txcos.secretKey|your.s3.secret]',
bucket:'[your.cdn.bucket]',
host:'[your.region]' //AWS s3无需填写
},
deletePrevious:true, //是否从CDN上删除上一次上传的bundle文件
deleteOutput:true //是否删除webpack打包后的文件
};
module.exports = {
// ...
plugins: [
new CdnUploadPlugin(uploaderOptions)
]
}
//webpack配置文件例子请查看example目录下的对应版本config.sample文件
支持 CDN 列表
- 七牛 - 使用自己封装的上传工具
- 腾讯 cos - 使用官方 SDK
- ftp - 稍微封装了几个用到的函数成支持 async/await, 底层使用 node-ftp 包, 参数参考:
https://github.com/mscdex/node-ftp
- AWS s3 - 使用 Knox, 参数参考:
https://github.com/Automattic/knox
参数
cdn
: object|array
CDN 参数 (传入 Array 则可以上传至不同的 CDN, 子参数与以下相同),
type
:qiniu|txcos|s3|ftp
CDN 类型, (必填) 其余所需参数通过这个变量来判断 (七牛:qiniu|腾讯 txcos|S3|FTP)
bucket
: 所上传的 bucket 名称, (暂时必填) 大部分对象存储提供商都类似
test
:需要上传文件后缀的正则, 默认(/.css|.js/) (如果上传至不同 CDN 则为必选参数作为文件区分)
accessKey
: 对应的 cdn access key: (必填) (七牛为 access key|腾讯为 secret id)
secretKey
: 对应的 cdn secret key: (必填) (七牛为 secret key|腾讯为 secret key)
host
: 服务器区域代码, (必填, S3 无需填写, FTP 为 IP 地址) 例如七牛 z1,或腾讯 cos 的 ap-shanghai
port
: (FTP 独有) FTP 服务器的 IP 端口, 默认 21
,
user
: (FTP 独有) FTP 用户名, 默认 anonymous
password
:(FTP 独有) FTP 密码, 默认 anonymous@
destPath
:(FTP 独有) 输出文件存储路径
contentType
(S3 独有), 输出格式, 否则诸如 HTML 可能会直接输出源码 (默认: text/plain)
permission
(s3 独有), s3 权限设置, (默认:public-read)
metas
(Only for s3) (可选) 输出 Meta, 如果包含 content-type 则会覆盖上面的 contentType 参数
deletePrevious
: (true|false) (默认 false) 是否从 CDN 上删除上一次上传的 bundle 文件, 大部分存储提供商都可以对相同文件名进行覆盖, 所以无需开启, 主要用于更换 cdn 后删除原 cdn 信息
deleteOutput
: (true|false) (默认 false) 是否删除 webpack 打包后的文件
lang
: (en|cn|[自定义输出语言文件路径]) console.log 输出语言, 默认(cn), 如果要输出自己的文字则传入语言文件地址
logPath
:记录输出文件路径, (默认 webpack 输出路径)
logName
:记录输出文件名称, (默认: wp.previous) 如果需要上传至不同项目可以在这里设置避免删除过往记录
注意
- CDN 参数传入 Array 时暂时只支持上传至不同 CDN, 同 CDN 不同 bucket 待开发
- 如果使用了 html 打包插件那么 publicPath 记得设置为 CDN 地址而非本地目录地址, 同时其他使用了该地址的资源也都需要替换或者上传至 CDN
- 打包结束后会在 webpack 配置中的输出目录产生一个
wp.previous.json
文件记录上一次的打包以及输出配置, 如果需要在每次打包后删除 CDN 上的旧资源请不要删除这个文件
- 通过正则匹配上传 js 以及 css 文件至不同 CDN 虽然支持但是并不推荐, 因为该插件并不修改打包内容所以如果 css 地址不同需要手动修改输出的 html 文件, 甚至 js 内容
- 上传 HTML 至 AWS S3 需要将 CDN 上的输出 content-type 更改为 text/html, 否则将会输出 html 源码. 可以在 aws s3 控制台中将 html 文件的 metadata 添加或更改为
text/html
, 也可以在导入前 CDN 参数中传入contentType
参数. 但是该参数只建议在 html 为你的唯一上传文件时使用, 否则你其他的打包文件也会被设置为 text/html.
欢迎在 Issues 里提各种需求和 bug
Package Sidebar
Install
npm i webpack-bundle-cdn-uploader
Weekly Downloads