laravel-gii 可视化代码生成扩展开发

1. laravel-gii 可视化代码生成扩展开发

1.1. 目录

1.2. 安装 laravel7

1.3. 服务器要求

推荐使用homestead,假如你不使用 Homestead,请确保你的服务器满足以下要求:

  • PHP >= 7.2.5
  • BCMath PHP 拓展
  • Ctype PHP 拓展
  • Fileinfo PHP 拓展
  • JSON PHP 拓展
  • Mbstring PHP 拓展
  • OpenSSL PHP 拓展
  • PDO PHP 拓展
  • Tokenizer PHP 拓展
  • XML PHP 拓展

1.4. 安装 laravel

1.4.1. 通过 Composer 创建项目

  1. 切换目录
    cd ~/code
  2. 执行
    composer create-project --prefer-dist laravel/laravel laravel-gii "7.*"
    执行结果见下图:
    ab1a7b91e8d8d7cbd14754f865e9d875542397cfe277de52c7d3fc2f7e3aff19.png

1.4.2. homestead站点配置

  1. 进入 homestead 根目录
    cd ~/Homestead
  2. 编辑 Homestead.yaml,sites 参数增加配置
sites:
    - map: laravel-gii.test
      to: /home/vagrant/code/laravel-gii/public
  1. 添加 host
    sudo vim /etc/hosts
  2. 增加
    192.168.11.10 laravel-gii.test
  3. 保存
    :wq
  4. 重启 homestead
    homestead provision && homestead reload

1.4.3. 访问

浏览器打开 http://laravel-gii.test/

4913bc70ea80d9a1fa4252a5c993daacc3e3a851cccf9fa01c7a35e7c5cffb8a.png

1.5. laravel7 扩展开发步骤

1.5.1. 安装扩展

  1. 切换目录
    cd ~/code/laravel-gii
  2. 执行命令
    composer require jeroen-g/laravel-packager --dev
    执行结果见下图:
    a166fde4c4e552119b795f1378751eff155b20cfa1d24ebc76c16072e02f89ec.png

1.5.2. 生成骨架

  1. 执行命令、生成骨架
    php artisan packager:new gii laravel-gii --i
    发现报错,如下图
    249779ebfbb6cad93da6c3610bfbf3a89c351946a49dc63459d99d31999be5c1.png
  1. 屏蔽代码 vendor/symfony/process/Process.php:1201 行
    // throw new ProcessTimedOutException($this, ProcessTimedOutException::TYPE_GENERAL);
    代码修改见下图:
    ee3d4e91c3d44db32490d6fd942195763bf235add4ce0d4bfc31a70aa6062ef9.png
  1. 移除扩展
    php artisan packager:remove gii laravel-gii
    执行结果见下图:
    c7983fb548b0c546257b00197b5183b38daa6cb4036577b8b1669b9239bc2cbe.png
  1. 重新执行,这里把 gii 改为 doujinya
    php artisan packager:new doujinya laravel-gii --i
    执行结果见下图:
    2cdffec2678a923d4a042079a0c23fc768e8007a98fe879b445c444ce95a827a.png
  2. composer.json require 增加
    "doujinya/laravel-gii": "dev-master"
    执行结果见下图:
    81e9b8e7c848d92ad9a81bf163bf9416c67cf9e257d7ae13b43867b544c6db6e.png
  1. 执行
    composer update doujinya/laravel-gii -vvv
    执行结果见下图:
    3e1fbd2ddafad744309a80ba40e475444cda21ee48f0ae4ec5cef2c57647f02e.png

1.5.4. 执行发布测试

执行命令
php artisan vendor:publish
选择 15,见下图


60c34d6f9640a2f32e9f0b9acafdde4ec8b657c29a57b4aafbf18ac0185d8ab8.png

发现 config 目录下,多了一个 laravel-gii.php 文件
目录结构,扩展目录 packages/doujinya/laravel-gii,如下

3f0f0cb2a0973f9257632849844af0c5bc9ffccd0d479fa4a64043f14bb135f0.png

1.5.5. 添加页面

  1. 编辑 packages/doujinya/laravel-gii/src/LaravelGiiServiceProvider.php
    去掉 $this->loadRoutesFrom(__DIR__.'/routes.php');前的注释,加载路由
  2. 增加路由文件 packages/doujinya/laravel-gii/src/routes.php,内容如下
  1. 增加目录 packages/doujinya/laravel-gii/src/Controller
  2. 增加文件 packages/doujinya/laravel-gii/src/Controller/TestController.php,内容如下
  1. 执行
    composer dump-autoload
  2. 访问 http://laravel-gii.test/gii/test
    da196213a0db9aab08fa0d892789696dd59d04ca628d5c12d2993e5a4d696442.png

1.6. sunshinev/laravel-gii 扩展

  1. github 地址:
    https://github.com/sunshinev/laravel-gii
  2. 安装 laravel 5
    composer create-project --prefer-dist laravel/laravel demo "5.*"
  3. 项目根目录执行
    Composer require sunshinev/laravel-gii -vvv
  4. 发布资源
    php artisan vendor:publish --tag laravel-gii
  5. 配置站点:同 1.4.2
  6. 生成model,访问 http://demo-gii.test/gii/model
  • MySQL table name:选择alarm_log
  • Model name:填写App\Models\AlarmLog
  • Parent class name:填写Illuminate\Database\Eloquent\Model
  1. 生成crud,访问 http://demo-gii.test/gii/crud

+Controller:输入App\Http\Controllers\AlarmController
+Model name: 输入App\Models\AlarmLog

  1. 遇到的问题
  • 前端依赖于sunshinev/base-fe项目
  • create_at update_at不能自定义,需要手动修改代码
  • modelcrud生成表单,输入不人性化
  • 项目使用 iView4.0,需要改成 element-ui
  • laravel版本

1.7.改造自己的laravel-gii

1.7.1 复制文件

复制文件,修改命名空间

目标扩展(基础目录vendor/sunshinev/laravel-gii) 自己的扩展(基础目录packages/doujinya/laravel-gii)
src/routes/routes.php src/routes/routes.php
src/Controllers/CrudController.php src/Controllers/CrudController.php
src/Controllers/ModelController.php src/Controllers/ModelController.php
src/Business/ControllerBusiness.php src/Models/BaseGenerate.php
src/Business/GenerateBusiness.php src/Models/ControllerGenerate.php
src/Business/ModelBusiness.php src/Models/ModelGenerate.php
aravel-gii/src/views src/views
src/assets resources/assets
src/stubs resources/stubs

1.7.2 增加配置文件

修改 packages/doujinya/laravel-gii/config/laravel-gii.php,代码如下,modelcrud表单select选择的默认配置

[
        'App\Models',
        'App\Models\Admin'
    ],
    //base_model_default
    'base_model_defaults'=>[
        'Illuminate\Database\Eloquent\Model',
    ],
    //create_at default
    'create_at_defaults'=>[
        'create_time',
        'create_at',
        ''
    ],
    //update_at default
    'update_at_defaults'=>[
        'update_time',
        'update_at',
        ''
    ],
    /*******************crud generate config ************************/
    'controller_namespaces'=>[
        'App\Http\Controllers',
        'App\Http\Controllers\Admin'
    ],
    'model_base_path'=>[
        'app/Models'=>'App\Models',
        'app/Models/Admin'=>'App\Models\Admin'
    ],
];

1.7.3 访问gii页面

/Users/doujinya/code/test-gii/packages/skyyouare/laravel-gii/composer.json require参数增加

        "sebastian/diff": "^3.0",
        "doctrine/dbal": "^2.10"
composer update -vvv

packages/skyyouare/laravel-gii/src/GiiServiceProvider.phpboot方法文件增加$this->loadViewsFrom(__DIR__.'/views', 'gii_views');
bootForConsole方法增加

        $this->publishes([
            __DIR__.'/../resources/assets' => public_path('gii_assets'),
        ], 'gii.views');

执行命令

php artisan vendor:publish

选择 16 laravel-gii.views

2b7f44edc986094cfbf1f8dd367edc5b706cfb0ff2754443a01b4e7023a61581.png

1.7.4 其他资源发布同上

参考已发布的扩展源码

https://github.com/skyyouare/laravel-gii

1.7.5 发布资源,见 packages/doujinya/laravel-gii/src/LaravelGiiServiceProvider.php

    /**
     * Console-specific booting.
     *
     * @return void
     */
    protected function bootForConsole(): void
    {
        // Publishing the configuration file.
        $this->publishes([
            __DIR__.'/../config/laravel-gii.php' => config_path('laravel-gii.php'),
        ], 'laravel-gii.config');

        // Publishing assets.
        $this->publishes([
            __DIR__.'/../resources/assets' => public_path('gii_assets'),
        ], 'laravel-gii.views');

         // Publishing images.
         $this->publishes([
            __DIR__.'/../resources/images' =>  public_path('images'),
        ], 'laravel-gii.images');

        // Publishing js.
        $this->publishes([
            __DIR__.'/../resources/js' =>  base_path('resources/js'),
        ], 'laravel-gii.js');

        // Publishing blade.
        $this->publishes([
            __DIR__.'/../resources/blade' =>  base_path('resources/views'),
        ], 'laravel-gii.blade');

        // Publishing sass.
        $this->publishes([
            __DIR__.'/../resources/sass' =>  base_path('resources/sass'),
        ], 'laravel-gii.sass');

        //publishing controller
        $this->publishes([
            __DIR__.'/../resources/controllers' =>  base_path('app/Http/Controllers'),
        ], 'laravel-gii.controller');
        //publishing request
        $this->publishes([
            __DIR__.'/../resources/Requests' =>  base_path('app/Http/Requests'),
        ], 'laravel-gii.request');
        //publishing route
        $this->publishes([
            __DIR__.'/../resources/routes' =>  base_path('routes'),
        ], 'laravel-gii.route');
        //exception route
        $this->publishes([
            __DIR__.'/../resources/Exceptions' =>  base_path('app/Exceptions'),
        ], 'laravel-gii.exception');
        //publishing provider
        $this->publishes([
            __DIR__.'/../resources/Providers' =>  base_path('app/Providers'),
        ], 'laravel-gii.provider');

        // Registering package commands.
        // $this->commands([]);
    }

1.8 使用

1. composer require laravel/ui ^2.1 --dev -vvv
2. php artisan ui vue
3. npm install
4. npm install element-ui vue-router qs --save-dev
5. php artisan vendor:publish  --tag laravel-gii.config --tag laravel-gii.views --tag laravel-gii.images --tag laravel-gii.js --tag laravel-gii.blade --tag  laravel-gii.sass --tag laravel-gii.controller --tag laravel-gii.request --tag laravel-gii.route --tag laravel-gii.exception --tag laravel-gii.provider --force
6. 运行 npm run watch-poll 编译

1.9 把你的项目放到 GitHub 上

当你的代码库准备就绪后,可以到包目录下初始化一个 Git 仓库。

cd packages/doujinya/laravel-gii
git init
git add .
git commit -m "first commit"

创建一个 新 GitHub 仓库 并且添加 origin.

git remote add origin [email protected]:yourusername/yourrepository.git
git push -u origin master
git tag -a 1.0.0 -m "release: First version"
git push --tags

2.0 把你的项目放到 Packagist 上

首先,在 Packagist.org 网站注册。我更喜欢使用我的 GitHub 帐户进行注册。

然后使用此 URL 提交新软件包。输入你的包的 GitHub URL,然后单击 Check. 如果发生任何错误,请按照屏幕上的说明进行操作。

完成上一步后,你将跳转到你的包的 packagist 页面,在该页面上你可能会收到如下通知:

此软件包不会自动更新。请为 Packagist 设置 GitHub Service Hook 以便在你每次推送时更新它!

让我们来设置一下。在此 页面 上获取 API 令牌,然后访问你的包的 GitHub 页面,找到 设置 / 网络钩子和服务 / 添加新服务 界面。搜索 Packagist,输入你的名字和令牌,然后点击提交。在 Packagist 页面上显示的错误应该会在 5–10 分钟内消失。

恭喜,你有一个有效的软件包在线,现在你可以通过 composer 引用它了。

2.1. 附录

laravel7 文档:https://learnku.com/docs/laravel/7.x
laravel7扩展开发:https://zhuanlan.zhihu.com/p/140687763
参考扩展:https://github.com/sunshinev/laravel-gii
完成扩展:https://github.com/skyyouare/laravel-gii

你可能感兴趣的:(laravel-gii 可视化代码生成扩展开发)