将 vue 生成的 js 上传到七牛的实例


Posted in Javascript onJuly 28, 2017

一般 vue 的项目,大家都是直接把最后生成的 css js 等文件直接上传到服务器,并没有才有 cdn 的业务

这样做一般有2个弊端,

  1. 增加服务器带宽压力,访问量一旦上去,服务器就可能因为带宽压力挂掉
  2. 部分地区访问速度会变慢

不过虽然知道归知道,但是每次都手动把 js css 文件传到七牛上很累的。
尤其是在改动频繁的情况下,上传七牛每次上传七牛 cdn 很浪费时间。

于是就去找七牛的文档,决定用脚本来解决这个问题,我是用的 python sdk 实现得。

python 环境请自行安装

首先下载七牛的包

pip install qiniu

然后安装第三方的依赖包 glob2

pip install glob2

upqiniu.py

# -*- coding: utf-8 -*-
from qiniu import Auth, put_file,
import qiniu.config
import glob2
import os
#需要填写你的 Access Key 和 Secret Key
access_key = '*********************'
secret_key = '**********************'
#构建鉴权对象
q = Auth(access_key, secret_key)
#要上传的空间
bucket_name = '****'

resources = glob2.glob('dist/static/**')
def upload(path):
  file_name = path.replace('dist/', '')
  key = file_name
  token = q.upload_token(bucket_name, key, 3600)
  localfile = './' + path
  put_file(token, key, localfile)

for r in resources:
  if os.path.isfile(r):
   upload(r)

需要将本脚本(upqiniu.py)放到 dist 同级目录下,如下图:

将 vue 生成的 js 上传到七牛的实例
image.png

脚本中的 access_key secret_key 你登录七牛后在个人资料中即可找到:

将 vue 生成的 js 上传到七牛的实例

还需要将 webpack 的 publicPath 改成七牛的地址即改成下面这个

将 vue 生成的 js 上传到七牛的实例

在 vue 的项目中,只需要改动 config 目录下面的 index.js 即可

将 vue 生成的 js 上传到七牛的实例

虽然改动起来有一点小麻烦,但是一劳永逸,

首先 npm run build

然后 python upqiniu.py

最后将你的 index.html 拉到线上服务器就可以了。

ps: 这个脚本会将 dist/static/ 的所有文件上传到七牛,包括 字体文件 , 图片等。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
你可能不再需要JQUERY
Mar 09 Javascript
firefox下jquery ajax返回object XMLDocument处理方法
Jan 26 Javascript
jquery判断元素的子元素是否存在的示例代码
Feb 04 Javascript
Javascript获取当前时间函数和时间操作小结
Oct 01 Javascript
ExtJs动态生成treepanel的Json格式
Jul 19 Javascript
jQuery实现多级下拉菜单jDropMenu的方法
Aug 28 Javascript
jquery validate表单验证的基本用法入门
Jan 18 Javascript
Javascript中apply、call、bind的巧妙使用
Aug 18 Javascript
Vue-Router的使用方法
Sep 05 Javascript
微信小程序ibeacon三点定位详解
Oct 31 Javascript
详解vue 命名视图
Aug 14 Javascript
使用npm命令提示: 'npm' 不是内部或外部命令,也不是可运行的程序的处理方法
May 14 Javascript
详解Vue2中组件间通信的解决全方案
Jul 28 #Javascript
详解React 16 中的异常处理
Jul 28 #Javascript
JavaScript截屏功能的实现代码
Jul 28 #Javascript
BootStrap selectpicker后台动态绑定数据的方法
Jul 28 #Javascript
详解angularjs的数组传参方式的简单实现
Jul 28 #Javascript
js 获取html5的data属性实现方法
Jul 28 #Javascript
jQuery获取table表中的td标签(实例讲解)
Jul 28 #jQuery
You might like
Ajax+PHP 边学边练 之二 实例
2009/11/24 PHP
字母顺序颠倒而单词顺序不变的php代码
2010/08/08 PHP
PHP中的一些常用函数收集
2015/05/26 PHP
PHP表单验证内容是否为空的实现代码
2016/11/14 PHP
php实现批量上传数据到数据库(.csv格式)的案例
2017/06/18 PHP
js判断当页面无法回退时关闭网页否则就history.go(-1)
2014/08/07 Javascript
JavaScript实现列表分页功能特效
2015/05/15 Javascript
JS实现不使用图片仿Windows右键菜单效果代码
2015/10/22 Javascript
JavaScript+html5 canvas制作的百花齐放效果完整实例
2016/01/26 Javascript
jQuery on()绑定动态元素出现的问题小结
2016/02/19 Javascript
JS敏感词过滤代码
2016/12/23 Javascript
jquery做个日期选择适用于手机端示例
2017/01/10 Javascript
JavaScript对象引用与赋值实例详解
2017/03/15 Javascript
vue-router2.0 组件之间传参及获取动态参数的方法
2017/11/10 Javascript
详解Angular调试技巧之报错404(not found)
2018/01/31 Javascript
vue中使用sessionStorage记住密码功能
2018/07/24 Javascript
vue-cli系列之vue-cli-service整体架构浅析
2019/01/14 Javascript
python提取内容关键词的方法
2015/03/16 Python
python中尾递归用法实例详解
2015/04/28 Python
详谈Numpy中数组重塑、合并与拆分方法
2018/04/17 Python
Python爬虫包BeautifulSoup实例(三)
2018/06/17 Python
利用python在excel里面直接使用sql函数的方法
2019/02/08 Python
python将pandas datarame保存为txt文件的实例
2019/02/12 Python
Python笔记之代理模式
2019/11/20 Python
将pycharm配置为matlab或者spyder的用法说明
2020/06/08 Python
全球最大的网上自行车商店:Chain Reaction Cycles
2016/12/02 全球购物
Farfetch美国:奢侈品牌时尚购物平台
2019/05/02 全球购物
为您的家、后院、车库等在线购物:Spreetail
2019/06/17 全球购物
介绍一下HTTP、HTTPS和SSL
2012/12/16 面试题
幼儿园元旦家长感言
2014/02/27 职场文书
董事长助理工作职责范本
2014/07/01 职场文书
临床医学专业求职信
2014/08/08 职场文书
葬礼主持词
2015/07/02 职场文书
中考百日冲刺决心书
2015/09/22 职场文书
企业内部管理控制:采购授权审批制度范本
2020/01/19 职场文书
日本十大血腥动漫,那些被禁播的动漫盘点
2022/03/21 日漫