我正在编写一个托管在api.url.com上的 Laravel API,用于在不同于使用 Laravel Fortify 的 Lravel API 的服务器上托管在 www.myurl.com 上的应用程序。
当用户在生成的链接上验证他们的电子邮件时,问题就出现了,他们不是被重定向到外部应用程序,而是再次回到 API,而是在他们的浏览器上。
文档声明 Authenticate.pgp 中间件中的这个配置可以工作:
<?php
namespace App\Http\Middleware;
use Illuminate\Auth\Middleware\Authenticate as Middleware;
class Authenticate extends Middleware
{
/**
* Get the path the user should be redirected to when they are not authenticated.
*
* @param \Illuminate\Http\Request $request
* @return string|null
*/
protected function redirectTo($request)
{
if (! $request->expectsJson()) {
return url(env('SPA_URL') . '/dashboard');
}
}
}
其中 SPA_URL 在 .env 中设置为www.myurl.com。
这重定向到api.url.com/www.myurl.com/dashboard显然会导致 404 响应。
然后我试图在控制器上调用一个动作
public function redirectDashboard(Request $request){
return redirect()->away('www.myurl.com/dashboard');
}
这再次重定向到api.url.com/www.myurl.com/dashboard显然会导致 404 响应。
我不知道为什么 redirect()->away 仍会重定向到同一 API 域上的 url。
任何帮助将不胜感激,谢谢。