将 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 相关文章推荐
JS日历 推荐
Dec 03 Javascript
为jquery.ui.dialog 增加“自动记住关闭时的位置”的功能
Nov 24 Javascript
用js实现层随着内容大小动态渐变改变 推荐
Dec 19 Javascript
8个超棒的学习 jQuery 的网站 推荐收藏
Apr 02 Javascript
Js从头学起(基本数据类型和引用类型的参数传递详细分析)
Feb 16 Javascript
JS实现模仿微博发布效果实例代码
Dec 16 Javascript
jQuery实用技巧必备(上)
Nov 02 Javascript
js实现select二级联动下拉菜单
Apr 17 Javascript
jquery实现全选、全不选以及单选功能
Mar 23 jQuery
Bootstrap 3浏览器兼容性问题及解决方案
Apr 11 Javascript
js学习总结之DOM2兼容处理重复问题的解决方法
Jul 27 Javascript
使用JavaScript计算前一天和后一天的思路详解
Dec 20 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
深入理解curl类,可用于模拟get,post和curl下载
2013/06/08 PHP
php mysql_real_escape_string函数用法与实例教程
2013/09/30 PHP
visual studio code 调试php方法(图文详解)
2017/09/15 PHP
extjs之去除s.gif的影响
2010/12/25 Javascript
Javascript 遮罩层和加载效果代码
2013/08/01 Javascript
js的toLowerCase方法用法实例
2015/01/27 Javascript
JS动态修改表格cellPadding和cellSpacing的方法
2015/03/31 Javascript
使用Angular和Nodejs、socket.io搭建聊天室及多人聊天室
2015/08/21 NodeJs
JavaScript实现标题栏文字轮播效果代码
2015/10/24 Javascript
jquery+json实现动态商品内容展示的方法
2016/01/14 Javascript
详解React Native网络请求fetch简单封装
2017/08/10 Javascript
JS实现的邮箱提示补全效果示例
2018/01/30 Javascript
JavaScript实现无限级递归树的示例代码
2019/03/29 Javascript
Vue.js实现可编辑的表格
2019/12/11 Javascript
node.js爬虫框架node-crawler初体验
2020/10/29 Javascript
详解python脚本自动生成需要文件实例代码
2017/02/04 Python
Python中支持向量机SVM的使用方法详解
2017/12/26 Python
Django 根据数据模型models创建数据表的实例
2018/05/27 Python
python实现自动发送报警监控邮件
2018/06/21 Python
Selenium定时刷新网页的实现代码
2018/10/31 Python
详解Python 正则表达式模块
2018/11/05 Python
Python数据分析:手把手教你用Pandas生成可视化图表的教程
2018/12/15 Python
对python中Librosa的mfcc步骤详解
2019/01/09 Python
Python学习笔记基本数据结构之序列类型list tuple range用法分析
2019/06/08 Python
Window版下在Jupyter中编写TensorFlow的环境搭建
2020/04/10 Python
Python爬虫抓取论坛关键字过程解析
2020/10/19 Python
Python+Appium实现自动化清理微信僵尸好友的方法
2021/02/04 Python
Python基于爬虫实现全网搜索并下载音乐
2021/02/14 Python
canvas像素画板的实现代码
2018/11/21 HTML / CSS
SheIn俄罗斯:时尚女装网上商店
2017/02/28 全球购物
Clarins娇韵诗英国官网:来自法国的天然护肤品牌
2017/04/18 全球购物
定制别致的瑜伽垫:Sugarmat
2019/06/21 全球购物
夜大毕业自我鉴定
2013/10/11 职场文书
自动化专业毕业生求职信
2014/06/18 职场文书
反四风对照检查材料
2014/09/22 职场文书
2014年档案室工作总结
2014/12/01 职场文书