nabil12ful / store-data-requests
通过请求字段 HTML 表单将数据存储到数据库中,按模型操作
v1.5
2023-03-28 12:10 UTC
Requires
- laravel/framework: ^8.0|^9.0|^10.0
- yoeunes/toastr: ^2.3
README
支持 laravel v8+
从(表单请求字段)通过模型存储到数据库中
安装
composer require nabil12ful/store-data-requests
要发布
php artisan vendor:publish --provider="Nabil\StoreDataRequestsServiceProvider"
用法
php artisan make:controller UserController -r
或者
php artisan make:controller UserController -m User
在控制器生成后更改此信息 & 恭喜 😄
protected $model = \App\Models\User::class; protected $folderBlade = 'backend.user'; // View folder name OR path protected $uploadPath = 'upload/user'; protected $columns = [ // table columns & fields name 'name', 'email', ]; protected $mediaColumns = [ // columns name have a media files like [Image, Pdf, Doc, etc...] 'image' ];
视图文件夹
+--- views | +--- backend | | +--- user | | | +--- index.blade.php | | | +--- create.blade.php | | | +--- edit.blade.php | | | +--- show.blade.php | | +--- product | | | +--- index.blade.php | | | +--- create.blade.php | | | +--- edit.blade.php | | | +--- show.blade.php | | +--- index.blade.php
要使用验证
通过创建请求验证
php artisan make:request UserStoreRequest
public function store(UserStoreRequest $request): RedirectResponse { StoreDataRequests::model($this->model)->make($request, $this->columns)->store($this->uploadPath); }
或者使用
首先更改列数组
protected $columns = [ // table columns & fields name with rules 'name' => 'required|string|min:5', 'email' => 'required|email', ]; protected $mediaColumns = [ // table columns & fields name has files with rules 'image' => 'required|image', ];
然后使用 storeValidated
,updateValidated
方法
public function store(Request $request) { $result = StoreDataRequests::model($this->model)->make($request, $this->columns)->storeValidated('upload/users'); if(isset($result->id)) { toastr()->success('The data has been stored successfully', 'Success'); return redirect()->back(); }else{ return back()->withInput()->withErrors($result); } }
在更新时
public function update($id, Request $request) { $result = StoreDataRequests::model($this->model)->make($request, $this->columns, $this->mediaColumns)->updateHasFilesValidate($id, $this->uploadPath); if(!$result) { toastr()->success('The data has been updated successfully', 'Success'); return redirect()->back(); }else{ return back()->withInput()->withErrors($result); } }
删除记录
如果您想通过删除记录从上传路径中删除文件,请输入路径参数
StoreDataRequests::model($this->model)->delete(decrypt($id), $this->uploadPath);
在我们的简单控制器中使用我们的服务
首先在您的控制器文件中导入我们的插件
use Nabil\StoreDataRequests;
然后写入此代码以创建新记录
public function store(Request $request) { StoreDataRequests::model('Prodect')->make($request, ['title','description'])->store(); }
或者写入此代码以在数据库模型中更新旧记录
public function update(Request $request, $id) { StoreDataRequests::model('Prodect')->make($request, ['title','description'])->update($id); }
使用插入数据上传文件
使用
StoreDataRequests::model('Prodect')->make($request, ['title','description'], ['image'])->store('path/to/upload');
或者更新包含文件的
StoreDataRequests::model('Prodect')->make($request, ['title','description'], ['image'])->update($id, 'path/to/upload');