在自定义类/子系统中使用Laravel 4模型而不依赖于类

deb*_*ian 6 php xml parsing laravel laravel-4

我正在构建一个解析器系统,它将根据请求/ cronjob解析大量不同的XML/JSON提要.我使用Laravel 4.

该线程的目的是在我的上下文中使用IoC,而不是在自定义类方法中使用硬编码的模型名称

为具有XML结构的Soccer Player提供解析器的示例,如:

<players category="Midfielders">
   <player id="777">
      <name>Caio Augusto Paim do Santos</name>
   <statistic>
      <club name="Camaçari" id="7191" league="Baiano 2" league_id="1136" season="2013" minutes="" appearences="" lineups="" substitute_in="" substitute_out="" substitutes_on_bench="" goals="" yellowcards="" yellowred="" redcards=""/>
Run Code Online (Sandbox Code Playgroud)

我在我的/ app文件夹中创建了一个名为/ parsers的附加目录.这些是自定义类,它们都在同一文件夹中扩展或实现自定义摘要/接口,并且基本上负责接收XML/JSON文件的路径并返回一个好的结构化PHP数组.

它们在autoload的composer.json中添加为: "app/parsers"

附加文件结构的屏幕截图在此输入图像描述

一切都很好,代码/类是可测试的,不依赖于另一个类,但这是问题所在.

查看XML示例,例如: <club id="XXX" league_id="YYY" /> 这是Feed俱乐部ID和Feed联盟ID,但我在数据库中有自己的ID,引用了Feed ID.

喜欢这个截图:

在此输入图像描述

所以逻辑说:转到数据库,检查联盟列表中是否有来自XML文件提供的feed_id的id.如果是,请获取它,如果没有,请创建一个新联盟并获取未来参考的ID.

这需要我在我的解析器类中使用Model,现在我知道你可以使用IoC并将模型注入到控制器中,但我不确定我是否可以对我的解析器类做同样的事情......

所以在我的解析器类中间做这样的事情:

// Try to get league and season ids from database if they already exists, if not, insert
$leagueId = DB::select('SELECT id FROM league WHERE feed_id=?', array($data['league_id']));
Run Code Online (Sandbox Code Playgroud)

要么

$league = new LeagueModel();
Run Code Online (Sandbox Code Playgroud)

几乎是不正确的.

现在只是为了澄清它的工作方式,我的解析器在Laravel Command类中被调用,如下所示:

/**
* Execute the console command.
*
* @return void
*/
public function fire()
{
    $this->setParser();
    $this->setStorage();
    $this->parser->parseFile($file);
}
Run Code Online (Sandbox Code Playgroud)

Laravel Command类在我的控制器中被调用,如:

$stamps = $this->getStamp();
Artisan::call('command:getSoccerPlayer',array('stamps' => $stamps, 'parser_id' => Request::segment(2)));
Run Code Online (Sandbox Code Playgroud)

Controller本身通过URI调用: /jobs/soccer_player/parse?type=soccer&directory=players

**您有什么建议或如何克服此问题以避免依赖性,并且在此上下文中仍然使用模型与数据库进行交互?**

PS请不要注意我的屏幕截图上的整个解析逻辑现在都在"解析"相同的方法,一旦我看到我想要它的工作/外观的全貌,我会把它分解成碎片.

感谢任何帮助!

Ayo*_*emi 1

您仍然可以调用命名空间模型

use App\Models\League; 

class SoccerPlayerParser extends AbstractParser{
    //...

    public function parse()
    {
       //...
        $league = App\Models\League::find($data['league_id']);
       //...
    }

    //....
}
Run Code Online (Sandbox Code Playgroud)

  • “不是真的。如果我为我的模型提供命名空间,它会丢失 Laravel 默认提供的命名空间,因此我无法再访问数据库外观:-/”你仍然这样做。一旦应用命名空间,它就会从全局类命名空间中删除已定义的类。如果您想使用全局命名空间(即 DB)中的类,只需在命名空间声明后添加“use DB;”即可。 (2认同)