使用GitHub API上传文件及GitHub做图床

本文介绍GitHub API基础及上传文件到仓库API,并应用API将GitHub作为图床
GitHub API版本
当前版本为v3,官方推荐在请求头中显示添加版本标识。
Accept: application/vnd.github.v3+json
Postman示例如图:

请求认证
- 基础认证|Basic authentication
shell示例:
curl -u "username" https://api.github.com
Postman示例如图:

- 令牌认证|OAuth2 token (sent in a header)
shell示例:
curl -H "Authorization: token OAUTH-TOKEN" https://api.github.com
Postman示例如图:

主API,获取所有API
请求API:
GET https://api.github.com
这个API返回常见API
Postman示例如图:

公开仓库查询API
请求API:
GET https://api.github.com/user/repos
header:
| name | value |
|---|---|
| Accept | application/vnd.github.v3+json |
| Authorization | token空格oauth_token |
Postman示例如图:

仓库创建API
请求API:
POST https://api.github.com/user/repos
headers:
Accept : application/vnd.github.v3+json
Authorization : token
空格oauth_token|
请求体|Request body:
name,代表仓库名,必须。其他的可选参数参看官方文档
{
"name":"imgs"
}
Postman示例如图:

为仓库上传/更新文件API
请求API:
PUT https://api.github.com/repos/{user}/imgs/contents/{path}/{filename}
- user:仓库所属用户名
- path:上传文件存放的路径,如果文件夹不存在,会自动创建
- filename:上传的文件名称
请求体|Request body:
{
"message": "提交说明",
"content": "base64编码的文件内容",
"sha": "文件的blob sha"
}
content:文件内容的base64编码后的字符串
sha:文件更新或删除时必填,先用GET接口查询文件信息,可在响应体中获取
Postman示例如图:

从仓库删除文件API
请求API:
DELETE https://api.github.com/repos/{user}/imgs/contents/{path}/{filename}
- user:仓库所属用户名
- path:上传文件存放的路径,如果文件夹不存在,会自动创建
- filename:上传的文件名称
请求体|Request body:
{
"message": "提交说明",
"sha": "文件的blob sha"
}
sha:文件更新或删除时必填,先用GET接口查询文件信息,可在响应体中获取
token的生成
token需要在GitHub网站上右上角Settings中去生成,生成后需要立即保存。
- 点击
Settings

- 点击
Developer settings

- 点击
Personal access tokens

- 点击
Generate new token,生成token并记录

仓库作为图床
仓库要想作为图床,图床的前提是文件内容能外链使用,需要将其作为GitHub Pages才能实现。
将仓库作为图床的整体操作步骤如下:
- 1 创建一个仓库,将添加一个index.html
由于我们要将此仓库作为图床,所以虽不需要静态网站相关内容,但为了GitHub能将此仓库识别为GitHub Pages,还是至少需要一个index.html在仓库中。(当然,你也可以找寻一个静态网站模板放进仓库)
index.html示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width-device-width,initial-scale-1">
<title>Images</title>
</head>
<body></body>
</html>
示例如图:

- 2 将此仓库配置为GitHub Pages
相关配置可以参看多项目部署为同一个GitHub Pages

开启GitHub Pages成功后,当前仓库文件就可通过GitHub Pages地址访问,图中示例为https://dev2007.github.io/imgs
- 3 将图片上传到仓库中
{仓库}/{路径}/{文件名}
示例如图:

- 4 获取图片链接,使用链接
链接格式为:https://{Pages域名}/{仓库}/{路径}/{文件名}
示例地址:https://dev2007.github.io/imgs/myfolder/panda.png
示例如图:

- 5 使用自定义域名,配置好后
Pages域名换为自定义域名即可
相关GitHub Pages配置域名,可参看用GitHub Pages搭建博客(五)
- 6 CDN加速
可以使用Vercel进行加速,可参看用GitHub Pages搭建博客(六)
Demo图床
最后是我搭建的一个Demo图床,可以访问,后续还将添加网页图片上传功能,欢迎查看:图床
欢迎关注我的博客:阿呜的边城
欢迎关注我的公众号:阿呜的编程

题图来源 :unsplash
使用GitHub API上传文件及GitHub做图床的更多相关文章
- MAC 上传文件到github
在IOS中,经常需要上传文件到github.以桌面上的一个文件夹为例: 步骤1: cd 到该文件夹下,建立POD文件. $ cd /Users/andy/Desktop/openinstallSDK ...
- Git在windows下上传文件至github流程
github是开发者分享的一个平台,这里不多说,想要上传文件至github需要有一个开发者账号,还需要在windows下安装好了git. 做好准备工作之后,接下来操作 一:登录github,创建项目 ...
- Git学习笔记——从一台电脑上传文件到Github上
目标:从一台电脑上传文件到Github上 前提: 1.这里假定已在Github上创建了仓库,建立了仓库 2.已在这台电脑上安装了Git客户端 实验环境: 1.Windows 10 64位,已安装了Gi ...
- 演示如何通过 web api 上传文件MVC40
演示如何通过 web api 上传文件WebApiWebFormHost/UploadFileController.cs /* * 通过 web api 上传文件 */ using System; u ...
- 返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, .net 4.5 带来的更方便的异步操作
原文:返璞归真 asp.net mvc (11) - asp.net mvc 4.0 新特性之自宿主 Web API, 在 WebForm 中提供 Web API, 通过 Web API 上传文件, ...
- php 下 html5 XHR2 + FormData + File API 上传文件
FormData的作用: FormData对象可以帮助我们自动的打包表单数据,通过XMLHttpRequest的send()方法来提交表单.当然FormData也可以动态的append数据.FormD ...
- 关于初学者上传文件到github的方法
转:http://blog.csdn.net/steven6977/article/details/10567719 说来也惭愧,我是最近开始用github,小白一个,昨天研究了一个下午.终于可以上传 ...
- 『网络の转载』关于初学者上传文件到github的方法
说来也惭愧,我是最近开始用github,小白一个,昨天研究了一个下午.终于可以上传了,所以今天写点,一来分享是自己的一些经验,二来也是做个记录,万一哪天又不记得了:) 废话不多说,直接来,这次主要介绍 ...
- git上传文件到github与gulp的简单使用
git有两种方式提交源代码到github 第一种方式通过地址提交下面介绍的是通过ssh方式上传 git使用ssh方式上传代码到githubgit首先要生成公钥和私钥 将公钥添加到github中将私钥保 ...
随机推荐
- 多测师讲解自动化测试_rf运行无日志(解决方法)_高级讲肖sir
rf运行无日志(解决方法) 出现现象: 方法: 1.先在套件里面导入OperatingSystem库 2.在套件中新建一个关键字套件点击右键选择new user keyword关键 字的名称为:kil ...
- DockerFile系统的学习
1.背景 DockerFile定义:用来构建Docker镜像的文件,有脚本命令组成. 自定义镜像并运行步骤:编写dockerFile文件-->docker build为镜像-->docke ...
- Django创建表时报错django.db.utils.InternalError: (1366问题解决记录
问题出现 执行Python manage.py makemigrations生成创建表的py文件 执行python manage.py migrate创建数据表 界面出现报错 问题原因 网上搜索原因, ...
- 通过IIS部署,将图片或者视频等文件用http协议网址访问
打开IIS管理器 又键点击添加网站 然后到这个界面 文件夹里有这些图片,随便用的一些图片 然后我这里用的是局域网测试,所以IP就是wifi的IP地址,如果是服务器的话,直接选服务器本身的IP地址就行了 ...
- UI自动化执行时报Parent suite setup failed: SessionNotCreatedException: Message: session not created: This version of ChromeDriver only supports Chrome version 81报错的问题解决
持续集成在执行UI时报错:Parent suite setup failed: SessionNotCreatedException: Message: session not created: Th ...
- 【DeepLearning】AlexNet
在前文中,我们介绍了LeNet的相关细节,它是由两个卷积层.两个池化层以及两个全链接层组成.卷积都是5*5的模板,stride =1,池化为MAX.整体来说它有三大特点:局部感受野,权值共享和池化.2 ...
- Python批量图片识别并翻译——我用python给女朋友翻译化妆品标签
Python批量图片识别并翻译--我用python给女朋友翻译化妆品标签 最近小编遇到一个生存问题,女朋友让我给她翻译英文化妆品标签.美其名曰:"程序猿每天英语开发,英文一定很好吧,来帮我翻 ...
- LuoguP4704 太极剑
题面 测试要求 Bob 尽可能快地切断 n 根绳子. 所有绳子的端点两两不同,所以共有 2n 个端点.这些端点被捆在一个圆上,等距离分布.我们把这些端点按顺时针方向编号为 1 到 2n. Bob 每次 ...
- AT3557 Four Coloring
题目链接 题解 先把每个格子看做一个点 (所谓的切比雪夫距离的转化) ,然后把这些点组成的矩形旋转45度,再把他塞到一个每个格子大小为\(d*d\)的网格图中,那么在一个格子上的点颜色相同 代码 #i ...
- 开发工具:Mybatis.Plus.插件三种方式的逆向工程
本文源码:GitHub·点这里 || GitEE·点这里 一.逆向工程简介 在Java开发中,持久层最常用的框架就是mybatis,该框架需要编写sql语句,mybatis官方提供逆向工程,可以把数据 ...