定制 revolution/laravel-vercel-installer 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

revolution/laravel-vercel-installer

最新稳定版本:1.3.2

Composer 安装命令:

composer require revolution/laravel-vercel-installer

包简介

Vercel Installer

README 文档

README

Maintainability Code Coverage

Install some files to run Laravel on Vercel.

Requirements

  • PHP >= 8.2
  • Laravel >= 11.0

Installation

composer require revolution/laravel-vercel-installer --dev

php artisan vercel:install

Uninstall

composer remove revolution/laravel-vercel-installer --dev

Once you have run the command you can uninstall this package.

vercel.json

It will probably not work with the new spec that uses functions and rewrites in vercel.json.

regions

https://vercel.com/docs/edge-network/regions

builds

vercel-php@0.7.4 is PHP8.3

To use another version, check this repository. https://github.com/vercel-community/php

routes

If there are other files in public, add them to routes.

    {
        "src": "/images/(.*)",
        "dest": "/public/images/$1"
    },

env

Secret env is set in the vercel settings page.

php artisan key:generate --show command generates a new key without updating the .env file. Set this key on the Settings page APP_KEY.

Assets

Even if you build css/js assets during deployment, they probably won't be loaded. Since @vercel/static simply distributes the files included in the repository as is, @vercel/static cannot access files built with vercel-php.

There are two solutions: include pre-built files in the repository, or display assets inline with Vite::content().

Include pre-build assets

Build the assets locally and include them in the repository.

// .gitignore

!/public/build

Inline assets

Use Vite::content to display assets inline instead of @vite.

    "scripts": {
        "vercel": [
            "@php artisan migrate --force",
            "npm install",
            "npm run build"
        ]
    }
{{--@vite(['resources/css/app.css', 'resources/js/app.js'])--}}
<style>
    {!! Vite::content('resources/css/app.css') !!}
</style>
<script>
    {!! Vite::content('resources/js/app.js') !!}
</script>

Database

You can use AWS RDS or any public DB.

Migration command

If you define the migrate command in the scripts section of composer.json, it will be executed during deployment.

    "scripts": {
        "vercel": [
            "@php artisan migrate --force"
        ]
    }

Cache and session

array is default. You can't use the file driver.

If you're using a database, you can use the database driver.

We recommend using database or array with the failover driver.

TrustProxies

Laravel 10

If you have any problems with TrustProxies, change /app/Http/Middleware/TrustProxies.php.

class TrustProxies extends Middleware
{
    /**
     * The trusted proxies for this application.
     *
     * @var array<int, string>|string|null
     */
    protected $proxies = '*';

Laravel 11

Change /bootstrap/app.php

->withMiddleware(function (Middleware $middleware) {
        $middleware->trustProxies(at: '*');
    })

API prefix

If you use Laravel's API routes, you will need to change the /api/ route as it conflicts with Vercel.

Laravel 11

/bootstrap/app.php

use Illuminate\Foundation\Application;

return Application::configure(basePath: dirname(__DIR__))
    ->withRouting(
        web: __DIR__.'/../routes/web.php',
        commands: __DIR__.'/../routes/console.php',
        api: __DIR__.'/../routes/api.php',
        apiPrefix: 'prefix/api',
        health: '/up',
    )

Disable build cache

Deployment often fails when you increase the package version in composer.json. To solve this, add VERCEL_FORCE_NO_BUILD_CACHE to Vercel's project settings - Environment Variables. Setting it in vercel.json probably won't solve the problem.

  • VERCEL_FORCE_NO_BUILD_CACHE : 1

https://vercel.com/docs/deployments/troubleshoot-a-build#managing-build-cache

LICENSE

MIT

统计信息

  • 总下载量: 29.47k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-12-22