skip to Main Content

I tried to add an image to the register but I don’t know why since the register no longer works

Register blade

@extends('layouts.app')

@section('content')
<div class="container">
    <div class="row justify-content-center">
        <div class="col-md-8">
            <div class="card">
                <div class="card-header">{{ __('Register') }}</div>

                <div class="card-body">
                    <form method="POST" action="{{ route('register') }}">
                        @csrf

                        <div class="row mb-3">
                            <label for="name" class="col-md-4 col-form-label text-md-end">{{ __('Name') }}</label>

                            <div class="col-md-6">
                                <input id="name" type="text" class="form-control @error('name') is-invalid @enderror" name="name" value="{{ old('name') }}" required autocomplete="name" autofocus>

                                @error('name')
                                <span class="invalid-feedback" role="alert">
                                    <strong>{{ $message }}</strong>
                                </span>
                                @enderror
                            </div>
                        </div>

                        <div class="row mb-3">
                            <label for="email" class="col-md-4 col-form-label text-md-end">{{ __('Email Address') }}</label>

                            <div class="col-md-6">
                                <input id="email" type="email" class="form-control @error('email') is-invalid @enderror" name="email" value="{{ old('email') }}" required autocomplete="email">

                                @error('email')
                                <span class="invalid-feedback" role="alert">
                                    <strong>{{ $message }}</strong>
                                </span>
                                @enderror
                            </div>
                        </div>

                        <div class="row mb-3">
                            <label for="image" class="col-md-4 col-form-label text-md-end">{{ __('Image') }}</label>

                            <div class="col-md-6">
                                <input type="file" class="custom-file-input" id="Image" name="image" required>
                                @error('image')
                                <span class="invalid-feedback" role="alert">
                                    <strong>{{ $message }}</strong>
                                </span>
                                @enderror
                            </div>
                        </div>


                        <div class="row mb-3">
                            <label for="secretword" class="col-md-4 col-form-label text-md-end">{{ __('secretword') }}</label>

                            <div class="col-md-6">
                                <input id="secretword" type="text" class="form-control @error('secretword') is-invalid @enderror" name="secretword" value="{{ old('secretword') }}" required autocomplete="secretword" autofocus>

                                @error('secretword')
                                <span class="invalid-feedback" role="alert">
                                    <strong>{{ $message }}</strong>
                                </span>
                                @enderror
                            </div>
                        </div>

                        <div class="row mb-3">
                            <label for="password" class="col-md-4 col-form-label text-md-end">{{ __('Password') }}</label>

                            <div class="col-md-6">
                                <input id="password" type="password" class="form-control @error('password') is-invalid @enderror" name="password" required autocomplete="new-password">

                                @error('password')
                                <span class="invalid-feedback" role="alert">
                                    <strong>{{ $message }}</strong>
                                </span>
                                @enderror
                            </div>
                        </div>

                        <div class="row mb-3">
                            <label for="password-confirm" class="col-md-4 col-form-label text-md-end">{{ __('Confirm Password') }}</label>

                            <div class="col-md-6">
                                <input id="password-confirm" type="password" class="form-control" name="password_confirmation" required autocomplete="new-password">
                            </div>
                        </div>

                        <div class="row mb-0">
                            <div class="col-md-6 offset-md-4">
                                <button type="submit" class="btn btn-primary">
                                    {{ __('Register') }}
                                </button>
                            </div>
                        </div>
                    </form>
                </div>
            </div>
        </div>
    </div>
</div>
@endsection

User Model

<?php

namespace AppModels;

use IlluminateContractsAuthMustVerifyEmail;
use IlluminateDatabaseEloquentFactoriesHasFactory;
use IlluminateFoundationAuthUser as Authenticatable;
use IlluminateDatabaseEloquentModel;
use IlluminateNotificationsNotifiable;
use LaravelSanctumHasApiTokens;
use QirolabLaravelReactionsTraitsReacts;
use QirolabLaravelReactionsContractsReactsInterface;

class User extends Authenticatable implements MustVerifyEmail, ReactsInterface
{
    use HasApiTokens, HasFactory, Notifiable, Reacts;

    /**
     * The attributes that are mass assignable.
     *
     * @var array<int, string>
     */
    protected $fillable = [
        'name',
        'email',
        'image',
        'password',
        'secretword',
    ];

    /**
     * The attributes that should be hidden for serialization.
     *
     * @var array<int, string>
     */
    protected $hidden = [
        'password',
        'remember_token',
    ];

    /**
     * The attributes that should be cast.
     *
     * @var array<string, string>
     */
    protected $casts = [
        'email_verified_at' => 'datetime',
    ];

    public function roles()
    {
        return $this
            ->belongsToMany(Role::class)
            ->withTimestamps();
    }

    public function users()
    {
        return $this
            ->belongsToMany('AppUser')
            ->withTimestamps();
    }

    public function authorizeRoles($roles)
    {
        if ($this->hasAnyRole($roles)) {
            return true;
        }
        abort(401, 'This action is unauthorized.');
    }

    public function hasAnyRole($roles)
    {
        if (is_array($roles)) {
            foreach ($roles as $role) {
                if ($this->hasRole($role)) {
                    return true;
                }
            }
        } else {
            if ($this->hasRole($roles)) {
                return true;
            }
        }
        return false;
    }

    public function hasRole($role)
    {
        if ($this->roles()->where('name', $role)->first()) {
            return true;
        }
        return false;
    }
};


User table

<?php

use IlluminateDatabaseMigrationsMigration;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateSupportFacadesSchema;

return new class extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('users', function (Blueprint $table) {
            $table->id();
            $table->string('name');
            $table->string('secretword');
            $table->string('image');
            $table->string('email')->unique();
            $table->timestamp('email_verified_at')->nullable();
            $table->string('password');
            $table->integer('reactions')->default(0);
            $table->rememberToken();
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::table('users', function (Blueprint $table) {
            $table->integer('reaction')->default(0)->change();
        });
    }
};


RegisterConctroller


namespace AppHttpControllersAuth;

use AppHttpControllersController;
use AppProvidersRouteServiceProvider;
use AppModelsUser;
use AppModelsRole;
use IlluminateFoundationAuthRegistersUsers;
use IlluminateSupportFacadesHash;
use IlluminateSupportFacadesValidator;
 
class RegisterController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Register Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles the registration of new users as well as their
    | validation and creation. By default this controller uses a trait to
    | provide this functionality without requiring any additional code.
    |
    */

    use RegistersUsers;

    /**
     * Where to redirect users after registration.
     *
     * @var string
     */
    protected $redirectTo = RouteServiceProvider::HOME;

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest');
    }

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return IlluminateContractsValidationValidator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'name' => ['required', 'string', 'max:255'],
            'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
            'secretword' => ['required', 'string', 'max:255'],
            'password' => ['required', 'string', 'min:8', 'confirmed'],
            'image' => ['required','image','mimes:jpeg,png,jpg,gif,svg','max:1000'],
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return AppModelsUser
     */
    protected function create(array $data)
    {
        $newUser = User::create([
            'name' => $data['name'],
            'secretword' => $data['secretword'],
            'email' => $data['email'],
            'image' => $data['image'],
            'password' => Hash::make($data['password']),
        ]);
        

        if(User::count() > 1){
            $adminRole = Role::where('name', 'like', 'ROLE_USER')->first();
            $newUser->roles()->attach($adminRole->id);
        }else{
            $adminRole = Role::where('name', 'like', 'ROLE_SUPERADMIN')->first();
            $newUser->roles()->attach($adminRole->id);
            $adminRole = Role::where('name', 'like', 'ROLE_USER')->first();
            $newUser->roles()->attach($adminRole->id);
        }

        return $newUser;

    }
}

when i do dd($data); i see this :

^ array:7 [▼
  "_token" => "Zh1vOo1lcbtA9LkaWBBSVZNvo6gFWDhUaW4qQfjB"
  "name" => "tqjsoahemaqdq"
  "email" => "[email protected]"
  "secretword" => "secretword1"
  "password" => "denden73"
  "password_confirmation" => "denden73"
  "image" => IlluminateHttpUploadedFile {#1369 ▼
    -test: false
    -originalName: "Screenshot from 2022-08-18 15-07-46.png"
    -mimeType: "image/png"
    -error: 0
    #hashName: null
    path: "/tmp"
    filename: "phpX0fkFo"
    basename: "phpX0fkFo"
    pathname: "/tmp/phpX0fkFo"
    extension: ""
    realPath: "/tmp/phpX0fkFo"
    aTime: 2022-08-25 14:47:03
    mTime: 2022-08-25 14:47:03
    cTime: 2022-08-25 14:47:03
    inode: 30730823
    size: 9104
    perms: 0100600
    owner: 1000
    group: 1000
    type: "file"
    writable: true
    readable: true
    executable: false
    file: true
    dir: false
    link: false
  }
]

Since I tried to add an image to register, it doesn’t work anymore. The page just refreshes, In the database (phpmyadmin) in user there is nothing. It’s for a course project I’m a student. I wanted to know how can I fix this?

2

Answers


  1. Try to add this enctype="multipart/form-data" to <form> tag

    This should looks like this:

    <form method="POST" action="{{ route('register') }}" enctype="multipart/form-data">
    </form>
    
    Login or Signup to reply.
  2. There is a difference between saving an image and saving another column.

    So, add enctype to your blade file:

    <form method="POST" action="{{ route('register') }}" enctype="multipart/form-data">
    

    In controller change code in function called create

    protected function create(array $data)
        {
            $request = request();
            if ($request->hasFile('image')) {
              $profileImage = $request->file('image');
              $image_name = time().$profileImage->getClientOriginalExtension();
              $upload_path = 'images/';
              $image_url = $upload_path . $image_name;
              $save = $profileImage->move($upload_path, $image_name);
            }
    
            $newUser = User::create([
                'name' => $data['name'],
                'secretword' => $data['secretword'],
                'email' => $data['email'],
                'image' => $image_url,
                'password' => Hash::make($data['password']),
            ]);
            //next code as it is
        }
    

    Don’t forget to run command php artisan storage:link

    It will store image in path storage/app/public/images

    Login or Signup to reply.
Please signup or login to give your own answer.
Back To Top
Search