我正在将我的工作项目移至laravel.在订购过程中,我正在使用SSL证书.
cart,orderAddress,orderPayment,orderResults是Order Process的四个步骤.
我的第一个问题是“在本地禁用ssl证书的最佳实践是什么?”
如果我的好(在下面)“如何缩短此代码?”因为我要重复自己,所以才不喜欢我.
/**
* disable ssl in Localhost
*/
if (App::environment('local')) {
Route::get('/cart', [
'uses' => 'CartController@index',
'as' => 'cart',
]);
Route::get('/orderAddress', [
'uses' => 'AddressController@orderIndex',
'as' => 'orderAddress',
]);
Route::get('/orderPayment', [
'uses' => 'PaymentController@orderPayment',
'as' => 'orderPayment',
]);
Route::get('/orderResult', [
'uses' => 'OrderController@orderResult',
'as' => 'orderResult',
]);
} else {
/**
* SSL PAGES
*/
Route::group(['before' => 'force.ssl'], function()
{
Route::get('/cart', [
'uses' => 'CartController@index',
'as' => 'cart',
]);
Route::get('/orderAddress', [
'uses' => 'AddressController@orderIndex',
'as' => 'orderAddress',
]);
Route::get('/orderPayment', [
'uses' => 'PaymentController@orderPayment',
'as' => 'orderPayment',
]);
Route::get('/orderResult', [
'uses' => 'OrderController@orderResult',
'as' => 'orderResult',
]);
});
Route::filter('force.ssl', function()
{
if( ! Request::secure())
{
return Redirect::secure(Request::path());
}
});
解决方法:
您可以编写类似以下的中间件:
namespace App\Http\Middleware;
use Closure;
use App;
use Redirect;
class UseSSL
{
public function handle($request, Closure $next)
{
if( App::environment('local') ){
return Redirect::secure($request->path());
}
return $next($request);
}
}
protected $routeMiddleware = [
...
'use.ssl' => UseSSL::class
];
现在你可以说
Route::group(['middleware' => 'use.ssl'], function () {
Route::get('/cart', [
'uses' => 'CartController@index',
'as' => 'cart',
]);
Route::get('/orderAddress', [
'uses' => 'AddressController@orderIndex',
'as' => 'orderAddress',
]);
Route::get('/orderPayment', [
'uses' => 'PaymentController@orderPayment',
'as' => 'orderPayment',
]);
Route::get('/orderResult', [
'uses' => 'OrderController@orderResult',
'as' => 'orderResult',
]);
});
让我知道它是否有效!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。