HEX
Server: nginx/1.28.1
System: Linux 10-41-63-61 6.8.0-31-generic #31-Ubuntu SMP PREEMPT_DYNAMIC Sat Apr 20 00:40:06 UTC 2024 x86_64
User: www (1001)
PHP: 7.4.33
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/my.esfyn.top/Modules/User/Http/Controllers/Web/UserController.php
<?php


namespace Modules\User\Http\Controllers\Web;


use App\Http\Controllers\MyController;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Modules\User\Http\Requests\ForgetRequest;
use Modules\User\Http\Requests\RegRequest;
use Modules\User\Models\User;

class UserController extends MyController
{

    public function index()
    {

        session([
            'the_page' => 'user',
            'page_title' => "会员中心",
        ]);

        return $this->theme('user');
    }

    public function reg()
    {
        session([
            'the_page' => 'user.reg',
            'page_title' => "会员注册",
        ]);

        return $this->theme('reg');
    }

    public function store(RegRequest $request, User $user)
    {
        $data = $request->validated();

        if (session('reg_code') == $data['reg_code'] && session('reg_mobile') == $data['mobile']) {

            unset($data['reg_code']);
            $data['password'] = Hash::make($data['password']);

            $result = $user->store($data);

            return $this->result($result, ['msg' => '注册成功']);
        }

        return $this->result(false, ['msg' => "注册失败"]);
    }

    public function login()
    {
        session([
            'the_page' => 'user.login',
            'page_title' => "会员登录",
        ]);

        return $this->theme('login');
    }

    public function auth()
    {
        $name = $this->param('name');
        $password = $this->param('password');

        if (empty($name) || empty($password)) {
            return $this->result(false, ['msg' => "请正确填写账号密码"]);
        }

        if (Auth::attempt(['name' => $name, 'password' => $password, 'status' => 1])) {
            return $this->result(true, ['msg' => "登录成功"]);
        }

        return $this->result(false, ['msg' => "验证失败,请确认账号密码后重试"]);
    }

    public function regCode()
    {

        if (session('send_time') >= time()) {
            return $this->result(false, ['msg' => "操作频繁,请稍后再试"]);
        }

        if ($mobile = $this->param('mobile', 'mobile')) {

            $number = mt_rand(1111, 9999);
            $result = ali_sms($mobile, 0, ['code' => $number]);

            if ($result) {

                session(['reg_code' => $number]);
                session(['reg_mobile' => $mobile]);
                session(['send_time' => time() + 60]);
            }

            return $this->result($result);

        }

        return $this->result(false, ['msg' => "发送识别,请检查手机号码是否正确"]);
    }

    public function logout()
    {
        auth()->logout();

        return redirect()->intended();
    }

    public function forget()
    {
        return $this->theme('forget');
    }

    public function editPwd(ForgetRequest $request)
    {
        $data = $request->validated();

        if (session('reg_code') == $data['reg_code'] && session('reg_mobile') == $data['mobile']) {

            $user = User::where('mobile', $data['mobile'])->first();

            if ($user) {

                $user->password = Hash::make($data['password']);
                $result = $user->save();

                return $this->result($result, ['msg' => '修改成功']);
            }
        }

        return $this->result(false, ['msg' => "修改失败"]);
    }
}