前言
使用七牛作为CDN非常方便,但是有的时候上传会出现超时、挂起等问题导致上传失败,尤其是海外存储区域。我们可以简单修改一下他们的上传域名来解决,例如将服务器端上传地址临时改为客户端上传地址使用。
错误
| 12
 3
 
 | ResponseErrorsocket hang up (req "error"), POST http://up-as0.qiniup.com -1 (connected: true, keepalive socket: false)
 headers: {}
 
 | 
说明
- 七牛文档
- 通常七牛的服务器端和客户端上传地址都是默认的,保存在 qiniu>qiniu>zone.js 文件里,通常会定义一个conf.Zone实例来保存区域配置。创建实例时,通常前两个参数(一般为两个数组)为服务端上传域名和客户端上传域名

- 如果我们只是临时修改,只需要修改zone.js文件对应区域的地址即可。如果是自动化构建或其它需要重新装包时,我们可以考虑封装为npm包,当然下面写个更简单的,直接在使用创建自己的conf.Zone实例即可 
- 我们获取上传对象时设置上传区域一般是这样写的
  
 
  结合图一我们可以看出只是使用了默认导出的conf.Zone实例

同时可以看到index已经导出了conf类,所有我们只需要使用自己定义的conf.zone实例就行了
代码
- 以修改东南亚服务器端上传地址为客户端上传地址为例
- 以nodejs实现为例
- 简单实现
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 
 | const qiniu = require('qiniu');module.exports = {
 getUploader:  async function () {
 const accesskey = 'your ak';
 const secretkey = 'your sk';
 const region= 'your region';
 const mac = new qiniu.auth.digest.Mac(accesskey, secretkey);
 const options = { scope: 'your bucket' };
 const putPolicy = new qiniu.rs.PutPolicy(options);
 const uploadToken = putPolicy.uploadToken(mac);
 const cf = new qiniu.conf.Config();
 const putExtra = new qiniu.form_up.PutExtra();
 if (region === 'Zone_as0') {
 cf.zone = new qiniu.conf.Zone([
 'upload-as0.qiniup.com'
 ], [
 'upload-as0.qiniup.com'
 ], 'iovip-as0.qbox.me',
 'rs-as0.qbox.me',
 'rsf-as0.qbox.me',
 'api-as0.qiniu.com')
 }
 const formUploader = new qiniu.form_up.FormUploader(cf);
 
 return { formUploader, uploadToken, putExtra }
 }
 };
 
 | 
总结
- 不同区域之间是无法测试的,比如国内是无法测试海外区域上传地址的,通常会报下面的错
 