第一个问题
<code>Route::get('test', function () { session(['wechat.oauth_user'=>1]); dd(session('wechat.oauth_user')); });</code>
输出1,然后我把session(['wechat.oauth_user'=>1]);
注释了
<code>Route::get('test', function () { //session(['wechat.oauth_user'=>1]); dd(session('wechat.oauth_user')); });</code>
刷新页面,输出null,这是为什么?
第二个问题
我使用了overtrue/wechat的插件,用插件自带的中间件成功获取了用户信息,然后user路由里也输出了session
<code> public function handle($request, Closure $next, $guard = null) { $wechat = app('EasyWeChat\\Foundation\\Application'); if (!session('wechat.oauth_user')) { if ($request->has('state') && $request->has('code')) { session(['wechat.oauth_user' => $wechat->oauth->user()]); return redirect()->to(url($request->url(), array_except($request->query(), ['code', 'state']))); } return $wechat->oauth->redirect($request->fullUrl()); } return $next($request); }</code>
<code> Route::get('user', function () { dd(session('wechat.oauth_user')); });</code>
在这个基础上,我建立了自己的中间件UserMiddleware
<code> public function handle($request, Closure $next) { if(Auth::guard('web')->guest()){ if (!session('wechat.oauth_user')) { return redirect('user'); } else{ User::CreateOrLogin(session('wechat.oauth_user')); } } return $next($request); }</code>
User.php
方法 CreateOrLogin
是
<code> public static function CreateOrLogin($data){ $user=self::getByOpenid($data['id']); if(!$user){ $create=['openid'=>$data['id']]; $user=self::create($create); } Auth::guard('web')->login($user); } public static function getByOpenid($openid){ return self::where('openid','=',$openid)->first(); }</code>
一切都是ok的,但是每次刷新页面都会执行微信获取用户信息的接口,然后一个个注释掉,发现Auth::guard('web')->login($user);
这句注释掉后,刷新页面就不会再跳转到微信,加上去就要跳转到微信获取用户信息接口,感觉像是login会清除掉session一样
问题三
<code>Route::group(['middleware' => ['web']], function () { Route::get('test', function () { dd(auth()->user()); }); Route::get('test2', function () { dd(auth()->loginUsingId(1)); }); });</code>
先访问test2,成功登陆,再访问test,输出null,为什么。。。
问题一和问题二和问题三没有关联,求大神解答
回复内容:
第一个问题
<code>Route::get('test', function () { session(['wechat.oauth_user'=>1]); dd(session('wechat.oauth_user')); });</code>
输出1,然后我把session(['wechat.oauth_user'=>1]);
注释了
<code>Route::get('test', function () { //session(['wechat.oauth_user'=>1]); dd(session('wechat.oauth_user')); });</code>
刷新页面,输出null,这是为什么?
第二个问题
我使用了overtrue/wechat的插件,用插件自带的中间件成功获取了用户信息,然后user路由里也输出了session
<code> public function handle($request, Closure $next, $guard = null) { $wechat = app('EasyWeChat\\Foundation\\Application'); if (!session('wechat.oauth_user')) { if ($request->has('state') && $request->has('code')) { session(['wechat.oauth_user' => $wechat->oauth->user()]); return redirect()->to(url($request->url(), array_except($request->query(), ['code', 'state']))); } return $wechat->oauth->redirect($request->fullUrl()); } return $next($request); }</code>
<code> Route::get('user', function () { dd(session('wechat.oauth_user')); });</code>
在这个基础上,我建立了自己的中间件UserMiddleware
<code> public function handle($request, Closure $next) { if(Auth::guard('web')->guest()){ if (!session('wechat.oauth_user')) { return redirect('user'); } else{ User::CreateOrLogin(session('wechat.oauth_user')); } } return $next($request); }</code>
User.php
方法 CreateOrLogin
是
<code> public static function CreateOrLogin($data){ $user=self::getByOpenid($data['id']); if(!$user){ $create=['openid'=>$data['id']]; $user=self::create($create); } Auth::guard('web')->login($user); } public static function getByOpenid($openid){ return self::where('openid','=',$openid)->first(); }</code>
一切都是ok的,但是每次刷新页面都会执行微信获取用户信息的接口,然后一个个注释掉,发现Auth::guard('web')->login($user);
这句注释掉后,刷新页面就不会再跳转到微信,加上去就要跳转到微信获取用户信息接口,感觉像是login会清除掉session一样
问题三
<code>Route::group(['middleware' => ['web']], function () { Route::get('test', function () { dd(auth()->user()); }); Route::get('test2', function () { dd(auth()->loginUsingId(1)); }); });</code>
先访问test2,成功登陆,再访问test,输出null,为什么。。。
问题一和问题二和问题三没有关联,求大神解答
检查是否加载了 web
中间件

TheSecretTokeEpingAphp-PowerEdwebSiterUnningSmoothlyShyunderHeavyLoadInVolvOLVOLVOLDEVERSALKEYSTRATICES:1)emplactopCodeCachingWithOpcachingWithOpCacheToreCescriptexecution Time,2)使用atabasequercachingCachingCachingWithRedataBasEndataBaseLeSendataBaseLoad,3)

你应该关心DependencyInjection(DI),因为它能让你的代码更清晰、更易维护。1)DI通过解耦类,使其更模块化,2)提高了测试的便捷性和代码的灵活性,3)使用DI容器可以管理复杂的依赖关系,但要注意性能影响和循环依赖问题,4)最佳实践是依赖于抽象接口,实现松散耦合。

是的,优化papplicationispossibleandessential.1)empartcachingingcachingusedapcutorediucedsatabaseload.2)优化的atabaseswithexing,高效Quereteries,and ConconnectionPooling.3)EnhanceCodeWithBuilt-unctions,避免使用,避免使用ingglobalalairaiables,并避免使用

theKeyStrategiestosiminificallyBoostphpapplicationPermenCeare:1)useOpCodeCachingLikeLikeLikeLikeLikeCacheToreDuceExecutiontime,2)优化AtabaseInteractionswithPreparedStateTemtStatementStatementSandProperIndexing,3)配置

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增强codemodocultion,可验证性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

选择DependencyInjection(DI)用于大型应用,ServiceLocator适合小型项目或原型。1)DI通过构造函数注入依赖,提高代码的测试性和模块化。2)ServiceLocator通过中心注册获取服务,方便但可能导致代码耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)启用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替换loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化进行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。