承接 alkhatibdev/language-switcher 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

alkhatibdev/language-switcher

最新稳定版本:v0.0.2

Composer 安装命令:

composer require alkhatibdev/language-switcher

包简介

Laravel dynamic language switcher for web and api routes

README 文档

README

Social Card of Language Switcher Package

Laravel dynamic language switcher

Latest Version Packagist Downloads (custom server) MIT Licensed

Introduction

Laravel dynamic language switcher for both web and API routes with various supported options.

Features

  • Switch user locale automatically and remind newly selected language for all next requests.
  • Support language switching via request body/query keys, request headers keys, and route parameters names.
  • Support API routes (Switch language via headers for stateless requests).
  • Support all HTTP methods (GET, POST, PUT and ..etc).
  • SEO-friendly routes by supporting language switching depending on route parameters.
  • Everything is configurable with a rich and well-documented configuration file.

Installation

install via composer

composer require alkhatibdev/language-switcher

Publish Configs

php artisan vendor:publish --tag=language-switcher-config

A language-switcher.php config file will be published on your configs directory. Feel free to read and override all these configurable parts, or stick with the defaults configs


Usage

Basic Usage

Everything is set out of the box, start calling your routes with these supported options:

Via Request query/body keys

// Request query key/value http://example.com/?lang=en // Request magic keys http://example.com/?en // Also you can use the same above parameters with the body of POST or PUT curl -X POST http://example.com/api/users -d '{"lang": "en"}' 

Via request headers keys

curl --header "Accept-Language: en" http://example.com/api/users

Via route parameters

For given route: Route::get('/{locale}/home', [HomeController, 'home']);

http://example.com/en/home 

Note
- All previous examples will ask the package to switch locale to 'en'.
- Upcoming requests still remind this newly set locale.


Customize Package Scope

By default, the package middleware is assigned globally to all your routes. However, you can disable assign_globally from the package config file, and assign middleware alias to all routes and route groups manually.

Disable global assignment

// config/language-switcher.php 'assign_globally' => false,

Assign to route or route groups

// routes/web.php // Assign to individual route Route::get('/{locale}/home', [HomeController, 'home'])->middleware(['switchlocale']); // Assign to route group Route::->middleware(['switchlocale'])->group(function () { // });

Assign to middleware groups

// app/Http/kernel.php protected $middlewareGroups = [ 'web' => [ // ... 'switchlocale', ], 'api' => [ // ... 'switchlocale', ], ];

Disable Saving

By default, the package uses sessions to store the current locale, switched by a user, to keep the newly selected locale active for the next requests without a need to pass the locale in every request. However, if you want to stop this behavior, set enable_session to false.

// config/language-switcher.php 'enable_session' => false,

License

Language Switcher is open-sourced software licensed under the MIT license.

统计信息

  • 总下载量: 3.76k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 12
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 12
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固