Created
June 12, 2022 18:36
-
-
Save davidgrzyb/55bc5f36d288123c9fca17f6e5bcf2e4 to your computer and use it in GitHub Desktop.
Laravel File Upload Example
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
use Illuminate\Database\Migrations\Migration; | |
use Illuminate\Database\Schema\Blueprint; | |
use Illuminate\Support\Facades\Schema; | |
return new class extends Migration | |
{ | |
/** | |
* Run the migrations. | |
* | |
* @return void | |
*/ | |
public function up() | |
{ | |
Schema::table('users', function (Blueprint $table) { | |
$table->string('avatar_path')->nullable(); | |
}); | |
} | |
/** | |
* Reverse the migrations. | |
* | |
* @return void | |
*/ | |
public function down() | |
{ | |
Schema::table('users', function (Blueprint $table) { | |
$table->dropColumn('avatar_path'); | |
}); | |
} | |
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<x-app-layout> | |
<x-slot name="header"> | |
<h2 class="font-semibold text-xl text-gray-800 leading-tight"> | |
{{ __('Profile') }} | |
</h2> | |
</x-slot> | |
<div class="py-12"> | |
<div class="max-w-4xl mx-auto sm:px-6 lg:px-8"> | |
<div class="bg-white overflow-hidden shadow-sm sm:rounded-lg p-6"> | |
<form action="{{ route('profile.update') }}" method="POST" enctype="multipart/form-data"> | |
@csrf | |
@method('put') | |
<div class="mb-6"> | |
<label for="name" class="block mb-2 text-sm font-medium">Name</label> | |
<input type="name" id="name" name="name" value="{{ $user->name }}" class="bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg block w-full p-2.5"> | |
@error('name')<small class="text-red-500">{{ $message }}</small>@enderror | |
</div> | |
<div class="mb-6"> | |
<label for="email" class="block mb-2 text-sm font-medium">Email</label> | |
<input type="email" id="email" name="email" value="{{ $user->email }}" class="bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg block w-full p-2.5"> | |
@error('email')<small class="text-red-500">{{ $message }}</small>@enderror | |
</div> | |
<div class="mb-6"> | |
<label for="password" class="block mb-2 text-sm font-medium">Password</label> | |
<input type="password" id="password" name="password" class="bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg block w-full p-2.5"> | |
@error('password')<small class="text-red-500">{{ $message }}</small>@enderror | |
</div> | |
<div class="mb-6"> | |
<label for="password_confirmation" class="block mb-2 text-sm font-medium">Confirm Password</label> | |
<input type="password" name="password_confirmation" id="password_confirmation" class="bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg block w-full p-2.5"> | |
@error('password_confirmation')<small class="text-red-500">{{ $message }}</small>@enderror | |
</div> | |
<div class="mb-6"> | |
<label for="avatar" class="block mb-2 text-sm font-medium">Avatar</label> | |
<input type="file" name="avatar" id="avatar" class="bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg block w-full p-2.5"> | |
@error('avatar')<small class="text-red-500">{{ $message }}</small>@enderror | |
</div> | |
<div class="flex justify-end pt-2"> | |
<button type="submit" class="text-white bg-indigo-600 hover:bg-indigo-700 focus:ring-4 focus:outline-none focus:ring-indigo-300 font-medium rounded-lg text-sm w-full sm:w-auto px-5 py-2.5 text-center">Save Profile</button> | |
</div> | |
</form> | |
</div> | |
</div> | |
</div> | |
</x-app-layout> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
namespace App\Http\Controllers; | |
use Illuminate\Http\Request; | |
use Illuminate\Support\Facades\Auth; | |
use Illuminate\Support\Facades\Hash; | |
use Illuminate\Validation\Rules\Password; | |
class ProfileController extends Controller | |
{ | |
public function edit() | |
{ | |
return view('profile')->with('user', Auth::user()); | |
} | |
public function update(Request $request) | |
{ | |
$request->validate([ | |
'name' => ['required', 'string', 'max:255'], | |
'email' => ['required', 'string', 'email', 'max:255', 'unique:users,email,' . Auth::id()], | |
'password' => ['nullable', 'confirmed', Password::defaults()], | |
'avatar' => ['nullable', 'mimes:jpg,jpeg,png,gif', 'max:2048'], | |
]); | |
$password = $request->password ? Hash::make($request->password) : Auth::user()->password; | |
$avatarPath = null; | |
if ($request->hasFile('avatar')) { | |
$avatarPath = $request->file('avatar')->storeAs( | |
'avatars', | |
Auth::id() . '.' . $request->file('avatar')->getClientOriginalExtension(), | |
'public', | |
); | |
} | |
Auth::user()->update([ | |
'name' => $request->name, | |
'email' => $request->email, | |
'password' => $password, | |
'avatar_path' => $avatarPath, | |
]); | |
return redirect(route('profile')); | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
namespace App\Models; | |
use Illuminate\Contracts\Auth\MustVerifyEmail; | |
use Illuminate\Database\Eloquent\Factories\HasFactory; | |
use Illuminate\Foundation\Auth\User as Authenticatable; | |
use Illuminate\Notifications\Notifiable; | |
use Laravel\Sanctum\HasApiTokens; | |
class User extends Authenticatable | |
{ | |
use HasApiTokens, HasFactory, Notifiable; | |
/** | |
* The attributes that are mass assignable. | |
* | |
* @var array<int, string> | |
*/ | |
protected $fillable = [ | |
'name', | |
'email', | |
'password', | |
'avatar_path', | |
]; | |
/** | |
* 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', | |
]; | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
use App\Http\Controllers\ProfileController; | |
use Illuminate\Support\Facades\Route; | |
/* | |
|-------------------------------------------------------------------------- | |
| Web Routes | |
|-------------------------------------------------------------------------- | |
| | |
| Here is where you can register web routes for your application. These | |
| routes are loaded by the RouteServiceProvider within a group which | |
| contains the "web" middleware group. Now create something great! | |
| | |
*/ | |
Route::get('/', function () { | |
return view('welcome'); | |
}); | |
Route::get('/profile', [ProfileController::class, 'edit']) | |
->middleware(['auth']) | |
->name('profile'); | |
Route::put('/profile/update', [ProfileController::class, 'update']) | |
->middleware(['auth']) | |
->name('profile.update'); | |
require __DIR__.'/auth.php'; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment