Hexo+Next+阿里云OSS实现相册功能

本文主要内容是利用阿里云对象存储OSS做图床,实现Hexo下Next主题的相册功能,本文首发于笔者博客

相册

前言

由于Next主题本身是没有实现相册的,所以相册功能需要手动添加,主要的内容是需要做一个图床,然后将本地图片上传至图床,在打开博客的时候从图床上请求并加载图片。

最终效果参见我的相册

解决方案对比

可用的解决方案

  • Github的一个仓库做图床

  • 七牛云做图床

  • 阿里云OSS做图床

Github

利用Github仓库做图床是一个最常用的解决方案,但是有很多限制,比如存储空间只有1GB,并且还会受到流量的限制,当图片越来越多或者图片很大的时候Github就不太适用了。

七牛云

七牛云确实是一个很好的解决方案,注册账号并实名认证之后会有10GB永久存储空间,10GB/月 HTTP国内流量,10GB/月 HTTP海外流量,但是七牛云会强制实名认证,并且需要上传手持身份证正面和反面的两张照片,所以这也是我没有用七牛云的原因,当然不在意的朋友可以忽略。

阿里云OSS

阿里云OSS,即阿里云对象存储,速度、安全这些便不用说了,收费方式比较复杂,最简单的方法是购买一个40GB的存储宝即可,一年9元钱,流量和请求使用默认的按量计费即可,流量费用00:00-08:00(闲时):0.25元/GB,8:00-24:00(忙时):0.50元/GB,请求费用0.01元/万次,显然,个人博客能达到GB流量/小时、万次访问的博主完全不会在乎这些费用了,未达到的个人博客收费不出意外的话应该每小时为0.00元,如下图所示:

消费明细

综上,我选择阿里云OSS

创建阿里云OSS存储空间

创建

创建阿里云<i class="fa fa-arrow-right">账号开通阿里云OSS服务<i class="fa fa-arrow-right">购买一个40GB的存储资源包<i class="fa fa-arrow-right">创建储存空间

创建的时候将存储空间的读写权限设置为公共读

获取阿里云OSS的EndPoint和外网访问域名

进入创建好的存储空间的管理页面,找到EndPoint和外网访问域名。

EndPoint和外网访问域名

获取阿里云OSS的Access Key

点击阿里云OSS控制台页面右边的Access Key按钮,进入该页面创建Access Key。

Access Key

安装OSS客户端

进入阿里云OSS控制台页面,在该页面的右上角点击更多,再点击OSS客户端下载进行安装。

安装后使用 上一步获取的AccessKeyId、 AccessKeySecret登录客户端,进入已经创建好的Bucket,创建两个文件夹,分别为photosmin_photos

安装OSS的Python SDK

该SDK的运行环境为Python 2.6,2.7,3.3,3.4,3.5,并需要用到pip命令进行安装,未满足运行环境请移步百度自行搜索安装。

使用如下命令安装SDK:

pip install oss2

构建相册页面

注:本文将使用blog代替博客根目录

创建页面

使用如下命令在blog目录下创建photo页面

hexo new page photos

在主题的配置文件_config.yml中的menu选项下添加Photos

menu:
  home: / || home
  categories: /categories/ || th
  archives: /archives/ || archive
  about: /about/ || user
  tags: /tags/ || tags
+ Photos: /photos/ || photo
  #schedule: /schedule/ || calendar
  #sitemap: /sitemap.xml || sitemap
  #commonweal: /404/ || heartbeat

进入blog/source/photos目录,修改index.md文件,并将位于第14行https://YourDomainName.com改为你的博客的地址

---
title: Photos
date: 2018-04-29 00:47:21
type: "photos"
comments: false
---
<link rel="stylesheet" href="../lib/album/ins.css">
<link rel="stylesheet" href="../lib/album/photoswipe.css"> 
<link rel="stylesheet" href="../lib/album/default-skin/default-skin.css"> 
<div class="photos-btn-wrap">
    <a class="photos-btn active" href="javascript:void(0)">Photos</a>
</div>
<div class="instagram itemscope">
    <a href="https://YourDomainName.com" target="_blank" class="open-ins">图片正在加载中…</a>
</div>

<script>
  (function() {
    var loadScript = function(path) {
      var $script = document.createElement('script')
      document.getElementsByTagName('body')[0].appendChild($script)
      $script.setAttribute('src', path)
    }
    setTimeout(function() {
        loadScript('../lib/album/ins.js')
    }, 0)
  })()
</script>

添加插件

进入blog/themes/next/source/lib,创建文件夹album,然后将这个Github仓库中的assets文件夹、default-skin文件夹、data.json文件、ins.css文件、ins.js文件、photoswipe.css文件下载下来放到新建的album文件夹内,将该仓库中的photoswips.js文件、photoswipe-ui-default.js文件放到blog/themes/next/source/js/src内。

打开ins.js文件,定位到大约121、122行,如下:

var minSrc = 'https://yourBucketName.oss-cn-shenzhen.aliyuncs.com/min_photos/' + data.link[i];
var src = 'https://yourBucketName.oss-cn-shenzhen.aliyuncs.com/photos/' + data.link[i];

yourBucketName.oss-cn-shenzhen.aliyuncs.com替换为你的阿里云OSS外网访问域名。

配置插件

进入blog/themes/next/layout,在_layout.swig文件的</head>标签前加入如下引用:

<script src="{{ url_for(theme.js) }}/src/photoswipe.js?v={{ theme.version }}"></script>
<script src="{{ url_for(theme.js) }}/src/photoswipe-ui-default.js?v={{ theme.version }}"></script>

<body>标签下添加如下代码:

{% if page.type === "photos" %}
  <!-- Root element of PhotoSwipe. Must have class pswp. -->
  <div class="pswp" tabindex="-1" role="dialog" aria-hidden="true">
    <div class="pswp__bg"></div>
    <div class="pswp__scroll-wrap">
        <div class="pswp__container">
            <div class="pswp__item"></div>
            <div class="pswp__item"></div>
            <div class="pswp__item"></div>
        </div>
        <div class="pswp__ui pswp__ui--hidden">
            <div class="pswp__top-bar">
                <div class="pswp__counter"></div>
                <button class="pswp__button pswp__button--close" title="Close (Esc)"></button>
                <button class="pswp__button pswp__button--share" title="Share"></button>
                <button class="pswp__button pswp__button--fs" title="Toggle fullscreen"></button>
                <button class="pswp__button pswp__button--zoom" title="Zoom in/out"></button>
                <div class="pswp__preloader">
                    <div class="pswp__preloader__icn">
                      <div class="pswp__preloader__cut">
                        <div class="pswp__preloader__donut"></div>
                      </div>
                    </div>
                </div>
            </div>
            <div class="pswp__share-modal pswp__share-modal--hidden pswp__single-tap">
                <div class="pswp__share-tooltip"></div> 
            </div>
            <button class="pswp__button pswp__button--arrow--left" title="Previous (arrow left)">
            </button>
            <button class="pswp__button pswp__button--arrow--right" title="Next (arrow right)">
            </button>
            <div class="pswp__caption">
                <div class="pswp__caption__center"></div>
            </div>
        </div>
    </div>
  </div>
{% endif %}

进入blog/themes/next/layout/_scripts/pages文件夹,在post-details.swig中添加如下引用:

<script src="{{ url_for(theme.js) }}/src/photoswipe.js?v={{ theme.version }}"></script>
<script src="{{ url_for(theme.js) }}/src/photoswipe-ui-default.js?v={{ theme.version }}"></script>

图片处理与上传

下载配置脚本

下载这个Github仓库,然后在该仓库的文件夹内创建两个文件夹,分别为photosmin_photos,然后修改tool.py文件:

def handle_photo():
    '''
    更新json文件
    
    '''
    endpoint = 'http://oss-cn-shenzhen.aliyuncs.com'
    auth = oss2.Auth('YourAccessKeyId', 'YourAccessKeySecret')
    bucket = oss2.Bucket(auth, endpoint, 'YourBucketName')
    file_list = []
    objs=islice(oss2.ObjectIterator(bucket,prefix='photos/20',delimiter=''),None)
def aliyun_operation(flag):
    '''
    上传图片
    '''
    endpoint = 'http://oss-cn-shenzhen.aliyuncs.com'
    auth = oss2.Auth('YourAccessKeyId', 'YourAccessKeySecret')
    bucket = oss2.Bucket(auth, endpoint, 'YourBucketName')

endpointauthbucket分别替换为你的阿里云OSS的EndPoint,Access Key和BucketName。

'''大约在130行'''

list_info.reverse()  # 翻转
tmp = bubbleYear(list_info)
bubble(tmp)
final_dict = {"list": list_info}
with open("../blog/themes/next/source/lib/album/data.json","w") as fp:
    json.dump(final_dict, fp)

将上述代码中的blog替换为你的博客根目录的名字。

使用脚本

将需要上传到博客相册的图片重命名为2018-5-1_图片的描述.jpg形式,日期年月日之间为-,日期与图片描述之间为_,然后将图片移动到刚才创建的photos文件夹下,然后使用如下命令进行图片裁剪并上传到阿里云OSS上。

python tool.py

执行脚本可能遇到的问题:

  • No module named 'PIL'

    解决办法:执行pip install Pillow

结语

感谢各位的阅读。

参考文章

  1. http://www.biueo.com/2018/02/17/hexo%E7%9A%84Next%E4%B8%BB%E9%A2%98%E6%B7%BB%E5%8A%A0%E7%9B%B8%E5%86%8C/

更新于2018年11月10日:

  • 修改pool.py的单词拼写错误
  • 更新执行python命令可能出现的问题及解决办法
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容