[英]Auth::check() doesn't seem to work properly in my Laravel project
如果用户已登录,我想将其重定向到主页(在路由中命名为home),如果不是,则将其重定向到loginpage(在路由中命名为loginpage)。 第一个可以正常运行,但是当我在登录页面中输入正确的用户名和密码时,用户将被重定向到同一登录页面,而不是首页。 这是代码
<?php
namespace App\Http\Controllers;
use Auth;
use Illuminate\Http\Request;
class ClientController extends Controller
{
public function home() {
if (!Auth::check())
return redirect()->route('loginpage');
else
return view('home');
}
public function loginpage() {
if (!Auth::check())
return view('loginpage');
else
return redirect()->route('home');
}
}
我的登录页面中的相关JavaScript代码如下:
function alerting() {
var usernam = document.getElementById("username").value;
var password = document.getElementById("password").value;
$(document).ready(function () {
$.ajax({
type: "POST",
url: '{{ URL::asset('login/login.php') }}',
dataType: 'json',
data: {function_name: 'userLogin', uname: usernam, pname: password},
success: function (data) {
if(data=='1'){
window.location.href = '{{route('home')}}';
}else{
alert("Username or password is wrong.");
}
}
})
});
}
这是登录功能:
<?php
include "config.php";
$ra = "SET NAMES utf8";
$retan = connection();
$resu = $retan->query($ra);
switch ($_POST['function_name']) {
case 'userLogin':
userLogin($_POST['uname'],$_POST['pname']);
break;
}
function userLogin($username,$password){
$connect = connection();
$connect->set_charset("utf8");
$query_in = "SELECT count(*) AS tedad FROM app_users au WHERE au.user_email='".$username."' AND au.user_password='".$password."'";
$result = $connect->query($query_in);
$data = mysqli_fetch_assoc($result);
$primf = $data['tedad'];
echo json_encode("".$primf);
}
上面提到的配置文件:
<?php
define('DB_SERVER', '127.0.0.1:3306');
define('DB_USERNAME', '');
define('DB_PASSWORD', '');
define('DB_DATABASE', 'test');
function connection(){
$conn = mysqli_connect(DB_SERVER,DB_USERNAME,DB_PASSWORD,DB_DATABASE);
return $conn;
}
?>
您正在使用Auth
外观来检查用户,而无需使用用户实例或Auth::loginUsingId
调用Auth::login
。
https://laravel.com/docs/5.6/authentication#other-authentication-methods
顺便说一句,您的userLogin函数需要进行SQL注入。 请尝试按照之前的建议进行操作,并使用laravel的标准身份验证系统,它的工作原理就像是一种魅力。
您是否使用php artisan make:auth
命令为laravel生成身份验证系统?
为什么要使用铁杆登录功能? 您应该根据laravel Documentation Authentication quickstart使用auth generator
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.