Laravel:刀片文件中内联PHP的最佳实践

时间:2015-06-17 11:10:10

标签: php laravel laravel-5 blade

所以我有以下刀片文件:

confirmEmail.blade.php

@extends('layouts.master')

@section('title')
{{ trans('tc.signUpConfirmTitle')}}
@endsection





@section('body')


<div class="container">
  <div class="row">
    <div class="col-lg-4">
      &nbsp;
    </div>

    <div class="col-lg-4">

      <?php
      echo $_GET['emailToken'];
      $emailToken = isset($_GET['emailToken']) ? $_GET['emailToken'] : "";
      $email = isset($_GET['email']) ? $_GET['email'] : "";

      //database lookup:
      $user = User::where('email','=',$email)->first();   //this fails...

      if($user->emailToken == $emailToken){
        echo "OK!";
      }
      ?>




      <br><br><br><br><br><br>

    </div>

    <div class="col-lg-4">
      &nbsp;
    </div>

  </div>
</div>

@endsection

如您所见,我在<?php ?>标记之间有一些原始PHP。问题是User::where(...)失败了(&#34; FatalErrorException&#34; - Class&#39; User&#39; not found)。

我想这是因为我需要做一些Laravel导入?但这样做是轻量级吗?

我可以问一下这个案例的最佳做法是什么?我对Laravel来说还是很新,所以请耐心等待。是否正在使用这样的原始PHP来打败整个目的?

到目前为止,我一直在使用Blade模板来简单地吐出简单的变量和参数。但我现在想做一些更复杂的事情而且我遇到了麻烦。

1 个答案:

答案 0 :(得分:4)

使用这样的原始PHP打败了整个目的吗? 没错! MVC是为了在你的情况下将不同类型的作业“模型,视图和控制器”组合在一起,你将控制器的工作组合到一个视图中,从而减少了控制器的作用。

控制器中的以下代码将执行您要执行的操作。假设您有一个名为confirmation的函数,它负责所有验证并相应地返回响应。

public function confirmation(Request $request)
{
   $status = 'Failure';
   $emailToken = $request->emailToken;
   $email = $request->email;
   if(isset($email))
     {
       $user = User::where('email','=',$email)->first();
        //I do not know why this fails on your side check if you have that email in your database
       if($user->emailToken == $emailToken)
        {
          $status = 'Success';
        }
     }
          return view('confirmEmail')->with('message', $status);
}

您不应该在用户表中添加确认密钥,但是您的db表可以在任何地方插入任何内容,但我的建议是您应该为此创建一个单独的表。