php-限制某些路由访问Laravel中的localhost

我的Laravel应用程序中的数据库是从其他Java应用程序填充的.这两个应用程序(Java和Laravel)在同一服务器上运行. Java应用程序向laravel应用程序发出带有数据的POST请求. Laravel应用程序将发送的数据插入数据库.

问题是我找不到验证请求的方法.我希望Laravel应用程序仅在源来自同一服务器时才接受该特定请求(例如,laravel.app / insert_data).

目前,路线laravel.app/insert_data可公开访问.如何限制为仅本地主机,以便不接受来自未知主机的数据.

一种方法是,我可以从请求和过滤器中获取HTTP标头.但我假设Laravel具有内置功能来执行此类操作.

解决方法:

您应该使用laravel过滤器.

可以这样定义:

Route::filter('localCallOnly', function()
{
    //if IPs don't match - 404
    if (Request::server('SERVER_ADDR') != Request::server('REMOTE_ADDR'))
    {
        return App::abort(404);
    }
});

后来用于您想要的任何路线:

Route::get('insert_data', array('before' => 'localCallOnly', 'uses' => 'MyController@insertData'));

基本上,这意味着“ localCallOnly”过滤器必须应用于“ insert_data”路由.因此,如果您的规则(相同的IP)与路由不匹配(​​控制器操作),则不会执行.

上一篇:javascript-Node.js Express,路由器,最佳参数作为扩展


下一篇:php-Laravel如何将组前缀参数添加到路由功能