Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/image-processing/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 拉雷维尔,社会名流和;中间件无限重定向循环_Php_Laravel_Laravel 5.1_Laravel Socialite - Fatal编程技术网

Php 拉雷维尔,社会名流和;中间件无限重定向循环

Php 拉雷维尔,社会名流和;中间件无限重定向循环,php,laravel,laravel-5.1,laravel-socialite,Php,Laravel,Laravel 5.1,Laravel Socialite,我学习了拉腊卡斯特关于社交名流的教程。我的最终目标是连接azure广告,但我在这方面遇到了很多问题,所以我想我应该从他的github教程开始,首先让它在原则上工作。在我尝试使用中间件之前我一直很好——现在我陷入了无限重定向循环。如果我跳出这个循环,进入主页,它就成功地让我登录了——但很明显,用户不会知道这一点,会认为它失败了 任何帮助都将不胜感激 埃德 授权控制器: namespace App\Http\Controllers; use Illuminate\Http\Request; use

我学习了拉腊卡斯特关于社交名流的教程。我的最终目标是连接azure广告,但我在这方面遇到了很多问题,所以我想我应该从他的github教程开始,首先让它在原则上工作。在我尝试使用中间件之前我一直很好——现在我陷入了无限重定向循环。如果我跳出这个循环,进入主页,它就成功地让我登录了——但很明显,用户不会知道这一点,会认为它失败了

任何帮助都将不胜感激

埃德

授权控制器:
namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\AuthenticateUser;

class AuthController extends Controller  {

public function login(AuthenticateUser $authenticateUser, Request $request) {
    $authenticateUser->execute($request->has('code'), $this);
    return \Socialite::with('github')->redirect();
}

public function logout() {
    if (\Auth::check()) \Auth::logout(); 
    return view('auth.loggedout');
}   

}
认证者:

<?php

namespace App;

use Illuminate\Contracts\Auth\Guard;
use Laravel\Socialite\Contracts\Factory as Socialite;
use App\Repositories\UserRepository;
use Request;

class AuthenticateUser {

private $socialite;
private $auth;

public function __construct(UserRepository $users, Socialite $socialite, Guard $auth) {
    $this->users = $users;
    $this->socialite = $socialite;
    $this->auth = $auth;
}

public function execute($hasCode) {

    if (!$hasCode) {
        return $this->getAuthorizationFirst();
    }

    $user = $this->users->findbyEmail($this->getUser());

    $this->auth->login($user, true);

    return redirect('/');
}

public function getAuthorizationFirst() {
    return $this->socialite->driver('github')->redirect();
}

public
        function getUser() {
    return $user = $this->socialite->driver('github')->user();
}

}
验证中间件:

<?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Contracts\Auth\Guard;

class Authenticate {

/**
 * The Guard implementation.
 *
 * @var Guard
 */
protected $auth;

/**
 * Create a new filter instance.
 *
 * @param  Guard  $auth
 * @return void
 */
public function __construct(Guard $auth) {
    $this->auth = $auth;
}

/**
 * Handle an incoming request.
 *
 * @param  \Illuminate\Http\Request  $request
 * @param  \Closure  $next
 * @return mixed
 */
public function handle($request, Closure $next) {

    if ($this->auth->guest()) {
        if ($request->ajax()) {
            return response('Unauthorized.', 401);
        } else {
            return redirect()->guest('o365/connect');
        }
    }

    if (\Auth::check()) {
        return $next($request);
    }        
}
}

调试时,您希望使用
dd()
(转储和死亡)类型的断点。当你怀疑有什么东西破坏了你的代码dd时,看看你自己。你处于无限重定向循环中可能有很多原因,你很可能会使用这种技术自己解决它。是的,我已经尝试了很多dd,但是由于代码实际上在工作,所以很难找出在哪里做它。这段代码实际上是用来让我登录的——它只是在重定向时被卡住了。
<?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Contracts\Auth\Guard;

class Authenticate {

/**
 * The Guard implementation.
 *
 * @var Guard
 */
protected $auth;

/**
 * Create a new filter instance.
 *
 * @param  Guard  $auth
 * @return void
 */
public function __construct(Guard $auth) {
    $this->auth = $auth;
}

/**
 * Handle an incoming request.
 *
 * @param  \Illuminate\Http\Request  $request
 * @param  \Closure  $next
 * @return mixed
 */
public function handle($request, Closure $next) {

    if ($this->auth->guest()) {
        if ($request->ajax()) {
            return response('Unauthorized.', 401);
        } else {
            return redirect()->guest('o365/connect');
        }
    }

    if (\Auth::check()) {
        return $next($request);
    }        
}
}