微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Laravel V4.1.0:401代码“消息”:“未经身份验证”适用于API

如何解决Laravel V4.1.0:401代码“消息”:“未经身份验证”适用于API

我在不使用PHP artisan serve时遇到调用Laravel API的问题 我已使用Passport进行身份验证

当我使用PHP artisan serve并使用http://127.0.0.1:8000/api/login登录时,它可以正常工作;当我使用令牌并使用http://127.0.0.1:8000/api/getData获取数据时,它也可以正常工作。

但是,我想让它不运行 PHP artisan serve。当我尝试这样做时:

使用http://127.0.0.1/Laravel/MyApp/public/index.PHP/api/login登录可以正常工作,当我使用令牌并使用http://127.0.0.1/Laravel/MyApp/public/index.PHP/api/getData获取数据时,它会显示401 code - unauthorized

我正在使用AppServ : Apache

搜索了SOF,并尝试了所有建议的解决方案,但是没有运气。

api.PHP

Route::post('/login','App\Http\Controllers\ApiAuthController@login')->name('login');
Route::post('register','App\Http\Controllers\ApiAuthController@register');

Route::group(['middleware'=>'auth:api','namespace'=>'App\Http\Controllers'],function () {
    Route::post('getData','DataController@index');
});

用户

class User extends Authenticatable
{
    use HasApiTokens,HasFactory,Notifiable;
..........
}

kernel.PHP

protected $middlewareGroups = [
        'web' => [
            \App\Http\Middleware\EncryptCookies::class,\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,\Illuminate\Session\Middleware\StartSession::class,\Illuminate\Session\Middleware\AuthenticateSession::class,\Laravel\Passport\Http\Middleware\CreateFreshApiToken::class,\Illuminate\View\Middleware\ShareErrorsFromSession::class,\App\Http\Middleware\VerifyCsrftoken::class,\Illuminate\Routing\Middleware\SubstituteBindings::class,],'api' => [
            'throttle:api',];

gurads:

'guards' => [
        'web' => [
            'driver' => 'session','provider' => 'users','api' => [
            'driver' => 'passport',

我的.htaccess在公共目录中:

<IfModule mod_rewrite.c>
    <IfModule mod_negotiation.c>
        Options -MultiViews -Indexes
    </IfModule>

    RewriteEngine On

    # Handle Authorization Header
    RewriteCond %{HTTP:Authorization} ^(.+)$ 
    RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
    
    # Redirect Trailing Slashes If Not A Folder...
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteCond %{REQUEST_URI} (.+)/$
    RewriteRule ^ %1 [L,R=301]

    # Send Requests To Front Controller...
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteRule ^ index.PHP [L]
</IfModule>

我试图将公共目录数据复制到根文件夹并编辑.htaccess。 我也尝试在根文件夹中创建新的.htaccess,并且在不删除公用文件夹中的.htaccess的情况下也没有运气。

这是登录名:

Login

这是PHP artisan服务结果,效果很好

php artisan serve result

这是不使用PHP artisan服务时的情况

when not using php artisan serve

谢谢

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。