将服务层添加到 Laravel 应用程序的效果
The effects of adding a Service Layer to a Laravel application
我已经使用 Zend Framework 进行开发多年,现在正在学习 Laravel。
在我以前的应用程序中,我通常有一个由控制器调用的服务层。服务层位于映射器和域模型的顶部,负责一些应用程序逻辑、引发事件、一些输入过滤等。
为什么我不应该在 Laravel 中实现服务层?在我目前看到的示例中,控制器直接与域对象(或更准确地说,活动记录)一起工作。
如果我的 Laravel 控制器调用我的服务层,我会失去 Laravel 的任何优势吗? (据我所知,我仍然可以使用 Route/Model 绑定)。
作为次要问题 - 实现服务层的最佳方式是什么?作为服务提供商的集合,也许?
我也从 Zend 切换到 Laravel 并且错过了我的服务。为了安慰自己,我实现了一个位于命名空间 App\Services 中的服务命名空间。在那里,我进行所有我不想在我的控制器中看到的模型或数据处理等。
我的控制器布局示例:
<?php
namespace App\Http\Controllers;
use App\Services\Contact as ContactService;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Lang;
class IndexController extends Controller
{
/**
* Create a new controller instance.
*
* @param Request $request
* @return void
*/
public function __construct(Request $request)
{
$this->_request = $request;
}
/**
* Standard contact page
*
* @return contact page
*/
public function contact(ContactService $contactService)
{
$errors = null;
$success = false;
if ($this->_request->isMethod('post')) {
$validator = $contactService->validator($this->_request->all());
if ($validator->fails()) {
$errors = $validator->errors();
} else {
$contactService->create($validator->getData());
$success = true;
}
}
return view('pages/contact', ['errors' => $errors, 'success' => $success]);
}
}
服务 return 验证器,处理 cruds,基本上做所有我不想在我的控制器中看到的事情,就像我在我的 Zend 项目中所做的那样。
服务示例:
<?php
namespace App\Services;
use Validator;
use Mail;
use App\Models\Contact as ContactModel;
class Contact
{
/**
* Get a validator for a contact.
*
* @param array $data
* @return \Illuminate\Contracts\Validation\Validator
*/
public function validator(array $data)
{
return Validator::make($data, [
'email' => 'required|email|max:255',
'phone' => 'max:255',
'firstName' => 'required|max:255',
'lastName' => 'required|max:255',
'message' => 'required'
]);
}
/**
* Create a new contact instance after a valid form.
*
* @param array $data
* @return ContactModel
*/
public function create(array $data)
{
//Handle or map any data differently if needed, just for illustration
$data = [
'email' => $data['email'],
'firstName' => $data['firstName'],
'lastName' => $data['lastName'],
'language' => $data['language'],
'phone' => $data['phone'],
'message' => $data['message']
];
// Send an email
Mail::send('emails.contact', ['data' => $data], function ($m) use ($data) {
$m->from(config('mail.from.address'), config('mail.from.name'));
$m->to(env('MAIL_TO', 'hello@world.com'), env('MAIL_TO'))->subject('Contact form entry from: ' . $data['firstName']);
});
return ContactModel::create($data);
}
}
看到这个 post:“设计模式:服务层 Laravel 5” @Francoiss https://m.dotdev.co/design-pattern-service-layer-with-laravel-5-740ff0a7b65f.. 除了上面的答案,你还可以将验证代码封装在一个单独的验证器 class
我已经使用 Zend Framework 进行开发多年,现在正在学习 Laravel。
在我以前的应用程序中,我通常有一个由控制器调用的服务层。服务层位于映射器和域模型的顶部,负责一些应用程序逻辑、引发事件、一些输入过滤等。
为什么我不应该在 Laravel 中实现服务层?在我目前看到的示例中,控制器直接与域对象(或更准确地说,活动记录)一起工作。
如果我的 Laravel 控制器调用我的服务层,我会失去 Laravel 的任何优势吗? (据我所知,我仍然可以使用 Route/Model 绑定)。
作为次要问题 - 实现服务层的最佳方式是什么?作为服务提供商的集合,也许?
我也从 Zend 切换到 Laravel 并且错过了我的服务。为了安慰自己,我实现了一个位于命名空间 App\Services 中的服务命名空间。在那里,我进行所有我不想在我的控制器中看到的模型或数据处理等。
我的控制器布局示例:
<?php
namespace App\Http\Controllers;
use App\Services\Contact as ContactService;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Lang;
class IndexController extends Controller
{
/**
* Create a new controller instance.
*
* @param Request $request
* @return void
*/
public function __construct(Request $request)
{
$this->_request = $request;
}
/**
* Standard contact page
*
* @return contact page
*/
public function contact(ContactService $contactService)
{
$errors = null;
$success = false;
if ($this->_request->isMethod('post')) {
$validator = $contactService->validator($this->_request->all());
if ($validator->fails()) {
$errors = $validator->errors();
} else {
$contactService->create($validator->getData());
$success = true;
}
}
return view('pages/contact', ['errors' => $errors, 'success' => $success]);
}
}
服务 return 验证器,处理 cruds,基本上做所有我不想在我的控制器中看到的事情,就像我在我的 Zend 项目中所做的那样。
服务示例:
<?php
namespace App\Services;
use Validator;
use Mail;
use App\Models\Contact as ContactModel;
class Contact
{
/**
* Get a validator for a contact.
*
* @param array $data
* @return \Illuminate\Contracts\Validation\Validator
*/
public function validator(array $data)
{
return Validator::make($data, [
'email' => 'required|email|max:255',
'phone' => 'max:255',
'firstName' => 'required|max:255',
'lastName' => 'required|max:255',
'message' => 'required'
]);
}
/**
* Create a new contact instance after a valid form.
*
* @param array $data
* @return ContactModel
*/
public function create(array $data)
{
//Handle or map any data differently if needed, just for illustration
$data = [
'email' => $data['email'],
'firstName' => $data['firstName'],
'lastName' => $data['lastName'],
'language' => $data['language'],
'phone' => $data['phone'],
'message' => $data['message']
];
// Send an email
Mail::send('emails.contact', ['data' => $data], function ($m) use ($data) {
$m->from(config('mail.from.address'), config('mail.from.name'));
$m->to(env('MAIL_TO', 'hello@world.com'), env('MAIL_TO'))->subject('Contact form entry from: ' . $data['firstName']);
});
return ContactModel::create($data);
}
}
看到这个 post:“设计模式:服务层 Laravel 5” @Francoiss https://m.dotdev.co/design-pattern-service-layer-with-laravel-5-740ff0a7b65f.. 除了上面的答案,你还可以将验证代码封装在一个单独的验证器 class