搜索
首页php框架Laravel讲讲Laravel如何集成GitHub来存储文件

下面由Laravel教程栏目给大家介绍Laravel 怎么集成 GitHub 来存储文件,希望对大家有所帮助!

GitHub API 介绍

接口文档:docs.github.com/en/rest

需要用到的是功能十分强大的 GitHub API,这里只需要 创建或更新文件内容 接口。

创建或更新文件内容

  • 请求地址:api.github.com/repos/{owner}/{repo}/contents/{path}

  • 请求方式:PUT

参数

名称 类型 位置 描述
accept string header 建议设置为 application/vnd.github.v3 json
owner string path 用户名
repo string path 仓库名
path string path 文件存储路径
message string body
名称 类型 位置 描述
accept string header 建议设置为 application/vnd.github.v3 json
owner string path 用户名
repo string path 仓库名
path string path 文件存储路径
message string body 必填 - The commit message
content string body 必填 - 新文件内容,使用 Base64 编码
sha string body 如果要更新文件,则必填 - 被替换文件的 blob SHA
branch string body 分支名称 - 版本库的默认分支通常是 master
committer object body 提交人 - 默认为已认证的用户
author object body 文件的作者 - 默认为 committer,如省略 committer,则为认证的用户
必填

- The commit message

content string body committer必填 - 新文件内容,使用
名称 描述
name (string) 必填 - 提交的作者或提交者的名字。如果省略 name 会收到 422 状态代码
email (string) 必填 - 提交的作者或提交者的电子邮件。如果省略 email 会收到 422 状态代码
date (string)
Base64

编码

sha string body author如果要更新文件,则必填 - 被替换文件的 blob SHA
branch string body 分支名称 - 版本库的默认分支通常是 master
名称 描述
name (string) 必填 - 提交的作者或提交者的名字。如果省略 name 会收到 422 状态代码
email (string) 必填 - 提交的作者或提交者的电子邮件。如果省略 email 会收到 422 状态代码
date (string)
object body 提交人 - 默认为已认证的用户
object body 文件的作者 - 默认为 ,如省略 ,则为认证的用户
对象的属性
名称 描述
name (string) 必填 - 提交的作者或提交者的名字。如果省略 name 会收到 422 状态代码
email (string) 必填 - 提交的作者或提交者的电子邮件。如果省略 email 会收到 422 状态代码
date (string)
对象的属性
名称 描述
name (string) 必填 - 提交的作者或提交者的名字。如果省略 name 会收到 422 状态代码
email (string) 必填 - 提交的作者或提交者的电子邮件。如果省略 email 会收到 422 状态代码
date (string)

鉴权

官方提供了三种方式:

  • Basic authentication - 用户名和密码

  • OAuth2 Token - token

  • OAuth2 key/secret - client_id 和 client_secret (只支持查询)

推荐使用第 2 种方式。

设置 token

Settings > Developer settings > Personal access tokens > Generate new token

讲讲Laravel如何集成GitHub来存储文件

生成的 token 要保存好,只显示一次。

创建仓库

一定要把仓库设置为公开的,目的是能够使用 jsDelivr CDN 加速。

使用 GitHub 仓库作为图床,存在的问题是国内访问 GitHub 的速度很慢,可以利用 jsDelivr CDN 来加速访问。jsDelivr 是一个免费开源的 CDN 解决方案,该平台是首个打通中国大陆与海外的免费 CDN 服务,拥有中国政府颁发的 ICP 许可证,无须担心中国防火墙问题而影响使用。使用 jsDelivr 加速访问,需要将自定义域名设置为 https://cdn.jsdelivr.net/gh/用户名/图床仓库名

Laravel 代码

需要设置几个配置参数,建议放到 .env 文件中。

GITHUB_FILE_REPOSITORY=YOUR_REPOSITORY
GITHUB_FILE_BRANCH=master
GITHUB_FILE_TOKEN=YOUR_TOKEN
GITHUB_FILE_PATH=YOUR_PATH
GITHUB_FILE_NAME=1
GITHUB_FILE_COMMIT_MESSAGE="YOUR COMMIT MESSAGE"

然后在 config 下创建一个配置文件,我创建了一个 github-file.php 配置文件

<?php return [
 /**
 * GitHub 仓库
 */
 &#39;repository&#39; => env('GITHUB_FILE_REPOSITORY', ''),

 /**
 * 分支
 */
 'branch' => env('GITHUB_FILE_BRANCH', 'master'),

 /**
 * Personal access token
 */
 'token' => env('GITHUB_FILE_TOKEN', ''),

 /**
 * 存储路径,若 GitHub 仓库中没有,则自动创建
 */
 'path' => env('GITHUB_FILE_PATH', ''),

 /**
 * 自定义域名
 * 若不定义则使用 https://raw.githubusercontent.com/ 出于某些原因可能图片加载会很慢,甚至失败
 * 建议使用 https://cdn.jsdelivr.net/gh/ 加速
 */
 'domain' => env('GITHUB_FILE_DOMAIN', 'https://cdn.jsdelivr.net/gh/'),

 /**
 * 文件命名
 * 1 - 以时间戳方式重命名
 * 2 - 以随机字符串方式重命名
 * 3 - 保持原名
 * ......
 */
 'name' => env('GITHUB_FILE_NAME', 1),

 /**
 * commit 记录
 */
 'commit_message' => env('GITHUB_FILE_COMMIT_MESSAGE', ''),];

创建一个 Trait 以复用上传功能

<?php namespace App\Traits;use Exception;use Illuminate\Support\Str;
use Illuminate\Support\Facades\Http;
trait UploadToGithub{
    public function uploadToGithub($file, $message = &#39;&#39;)
    {
        $path = config(&#39;github-file.path&#39;) . &#39;/&#39; . $this->setFileName($file);
        $repository = config('github-file.repository');

        if ($file->isValid()) {
            $url = "https://api.github.com/repos/$repository/contents/$path";

            $response = Http::withToken(config('github-file.token'))->put($url, [
                'message' => $message ?: config('github-file.commit_message'),
                'content' => base64_encode(file_get_contents($file))
            ]);

            // 上传失败抛出一个错误,成功则返回 JSON
            $body = $response->throw()->json();

            // 上传成功后 GitHub API 返回的是 201,其实有了上一步这里的判断可以省略
            if ($response->successful()) {
                return config('github-file.domain')
                    ? rtrim(config('github-file.domain'), '/') . '/' . trim($repository, '/') . '/' . ltrim($body['content']['path'], '/')
                    : $body['content']['download_url'];
            }
        }

        throw new Exception('未发现图片');
    }

    /**
     * 生成图片名称
     * @param $file
     * @return mixed|string
     */
    private function setFileName($file)
    {
        switch (config('github-file.name')) {
            case 1:
                return date('YmdHis', time()) . '.' . $file->getClientOriginalExtension();
            case 2:
                return Str::random(32) . '.' . $file->getClientOriginalExtension();
            case 3:
            default:
                return $file->getClientOriginalName();
        }
    }}

在需要的地方使用 UploadToGithub

use UploadToGithub;public function updload(Request $request){
    $url = $this->uploadToGithub($request->file('file-field-name'));
    
    return response()->json([
        'code' => 200,
        'message' => '上传成功',
        'data' => [
            'url' => $url
        ]
    ]);}

最新的五个Laravel视频教程(推荐)                                 

以上是讲讲Laravel如何集成GitHub来存储文件的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:learnku。如有侵权,请联系admin@php.cn删除
Laravel(PHP)与Python:不同的用例和应用Laravel(PHP)与Python:不同的用例和应用Apr 18, 2025 am 12:16 AM

选择Laravel或Python取决于项目需求:1)若需快速开发Web应用并使用ORM和认证系统,选Laravel;2)若涉及数据分析、机器学习或科学计算,选Python。

Laravel和Python:找到合适的工具Laravel和Python:找到合适的工具Apr 18, 2025 am 12:14 AM

Laravel适合快速构建Web应用,Python适用于需要灵活性和多功能性的项目。 1)Laravel提供丰富功能如ORM和路由,适合PHP生态系统。 2)Python以简洁语法和强大库生态系统着称,适用于Web开发和数据科学等领域。

Laravel和PHP:创建动态网站Laravel和PHP:创建动态网站Apr 18, 2025 am 12:12 AM

使用Laravel和PHP可以高效且有趣地创建动态网站。1)Laravel遵循MVC架构,Blade模板引擎简化HTML编写。2)路由系统和请求处理机制使URL定义和用户输入处理变得简单。3)EloquentORM简化数据库操作。4)通过博客系统示例展示了数据库迁移、CRUD操作和Blade模板的使用。5)Laravel提供了强大的用户认证和授权功能。6)调试技巧包括使用日志系统和Artisan工具。7)性能优化建议包括惰性加载和缓存。

拉维尔(Laravel)和完整的堆栈:前后一起拉维尔(Laravel)和完整的堆栈:前后一起Apr 18, 2025 am 12:07 AM

Laravel通过Blade模板引擎、EloquentORM、Artisan工具和LaravelMix实现全栈开发:1.Blade简化前端开发;2.Eloquent简化数据库操作;3.Artisan提高开发效率;4.LaravelMix管理前端资源。

Laravel:现代网络开发的框架Laravel:现代网络开发的框架Apr 18, 2025 am 12:05 AM

Laravel是一个基于PHP的现代化框架,遵循MVC架构模式,提供了丰富的工具和功能,简化了Web开发过程。1)它包含EloquentORM用于数据库交互,2)Artisan命令行接口用于快速生成代码,3)Blade模板引擎用于高效的视图开发,4)强大的路由系统用于定义URL结构,5)认证系统用于用户管理,6)事件监听和广播用于实时功能,7)缓存和队列系统用于性能优化,使得构建和维护现代Web应用变得更加容易和高效。

Laravel(PHP)与Python:权衡优点和缺点Laravel(PHP)与Python:权衡优点和缺点Apr 17, 2025 am 12:18 AM

Laravel适合快速构建Web应用,而Python适用于更广泛的应用场景。 1.Laravel提供EloquentORM、Blade模板引擎和Artisan工具,简化Web开发。 2.Python以动态类型、丰富的标准库和第三方生态系统着称,适用于Web开发、数据科学等领域。

Laravel vs. Python:比较框架和图书馆Laravel vs. Python:比较框架和图书馆Apr 17, 2025 am 12:16 AM

Laravel和Python各有优势:Laravel适合快速构建功能丰富的Web应用,Python在数据科学和通用编程领域表现出色。1.Laravel提供EloquentORM和Blade模板引擎,适合构建现代Web应用。2.Python拥有丰富的标准库和第三方库,Django和Flask框架满足不同开发需求。

Laravel的目的:构建强大而优雅的Web应用程序Laravel的目的:构建强大而优雅的Web应用程序Apr 17, 2025 am 12:13 AM

Laravel值得选择,因为它能使代码结构清晰,开发过程更具艺术性。1)Laravel基于PHP,遵循MVC架构,简化Web开发。2)其核心功能如EloquentORM、Artisan工具和Blade模板增强了开发的优雅与健壮性。3)通过路由、控制器、模型和视图,开发者能高效构建应用。4)队列和事件监听等高级功能进一步提升应用性能。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。