所以我有以下刀片文件:
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">
</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">
</div>
</div>
</div>
@endsection
如您所见,我在<?php ?>
标记之间有一些原始PHP。问题是User::where(...)
失败了(&#34; FatalErrorException&#34; - Class&#39; User&#39; not found)。
我想这是因为我需要做一些Laravel导入?但这样做是轻量级吗?
我可以问一下这个案例的最佳做法是什么?我对Laravel来说还是很新,所以请耐心等待。是否正在使用这样的原始PHP来打败整个目的?
到目前为止,我一直在使用Blade模板来简单地吐出简单的变量和参数。但我现在想做一些更复杂的事情而且我遇到了麻烦。
答案 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表可以在任何地方插入任何内容,但我的建议是您应该为此创建一个单独的表。