문자열 (Strings)
소개
라라벨은 문자열 값을 다루기 위한 다양한 함수들을 제공합니다. 이러한 함수들 중 많은 부분이 프레임워크 자체에서 사용되지만, 필요하다면 여러분도 직접 애플리케이션에서 자유롭게 사용할 수 있습니다.
사용 가능한 메서드
문자열 관련 함수
__ class_basename e preg_replace_array Str::after Str::afterLast Str::apa Str::ascii Str::before Str::beforeLast Str::between Str::betweenFirst Str::camel Str::charAt Str::chopStart Str::chopEnd Str::contains Str::containsAll Str::doesntContain Str::deduplicate Str::endsWith Str::excerpt Str::finish Str::headline Str::inlineMarkdown Str::is Str::isAscii Str::isJson Str::isUlid Str::isUrl Str::isUuid Str::kebab Str::lcfirst Str::length Str::limit Str::lower Str::markdown Str::mask Str::orderedUuid Str::padBoth Str::padLeft Str::padRight Str::password Str::plural Str::pluralStudly Str::position Str::random Str::remove Str::repeat Str::replace Str::replaceArray Str::replaceFirst Str::replaceLast Str::replaceMatches Str::replaceStart Str::replaceEnd Str::reverse Str::singular Str::slug Str::snake Str::squish Str::start Str::startsWith Str::studly Str::substr Str::substrCount Str::substrReplace Str::swap Str::take Str::title Str::toBase64 Str::transliterate Str::trim Str::ltrim Str::rtrim Str::ucfirst Str::ucsplit Str::upper Str::ulid Str::unwrap Str::uuid Str::uuid7 Str::wordCount Str::wordWrap Str::words Str::wrap str trans trans_choice
Fluent 문자열 메서드
after afterLast apa append ascii basename before beforeLast between betweenFirst camel charAt classBasename chopStart chopEnd contains containsAll deduplicate dirname endsWith exactly excerpt explode finish headline inlineMarkdown is isAscii isEmpty isNotEmpty isJson isUlid isUrl isUuid kebab lcfirst length limit lower markdown mask match matchAll isMatch newLine padBoth padLeft padRight pipe plural position prepend remove repeat replace replaceArray replaceFirst replaceLast replaceMatches replaceStart replaceEnd scan singular slug snake split squish start startsWith stripTags studly substr substrReplace swap take tap test title toBase64 toHtmlString transliterate trim ltrim rtrim ucfirst ucsplit unwrap upper when whenContains whenContainsAll whenEmpty whenNotEmpty whenStartsWith whenEndsWith whenExactly whenNotExactly whenIs whenIsAscii whenIsUlid whenIsUuid whenTest wordCount words wrap
문자열
__()
__
함수는 주어진 번역 문자열 또는 번역 키를 언어 파일을 사용해 번역합니다:
echo __('Welcome to our application');
echo __('messages.welcome');
지정한 번역 문자열이나 키가 존재하지 않을 경우, __
함수는 전달한 값을 그대로 반환합니다. 즉, 위의 예시에서 해당 키에 대한 번역이 존재하지 않으면 __
함수는 messages.welcome
을 반환합니다.
class_basename()
class_basename
함수는 주어진 클래스의 네임스페이스를 제외한 클래스 이름만 반환합니다:
$class = class_basename('Foo\Bar\Baz');
// Baz
e()
e
함수는 PHP의 htmlspecialchars
함수를 사용하며, 기본적으로 double_encode
옵션이 true
로 설정되어 있습니다:
echo e('<html>foo</html>');
// <html>foo</html>
preg_replace_array()
preg_replace_array
함수는 문자열에서 주어진 패턴을 배열 요소로 하나씩 순차적으로 대체합니다:
$string = 'The event will take place between :start and :end';
$replaced = preg_replace_array('/:[a-z_]+/', ['8:30', '9:00'], $string);
// The event will take place between 8:30 and 9:00
Str::after()
Str::after
메서드는 문자열에서 지정한 값 뒤에 오는 모든 부분을 반환합니다. 만약 해당 값이 문자열에 존재하지 않으면 전체 문자열을 반환합니다:
use Illuminate\Support\Str;
$slice = Str::after('This is my name', 'This is');
// ' my name'
Str::afterLast()
Str::afterLast
메서드는 문자열에서 지정한 값이 마지막으로 등장한 이후의 모든 부분을 반환합니다. 해당 값이 문자열에 없으면 전체 문자열을 반환합니다:
use Illuminate\Support\Str;
$slice = Str::afterLast('App\Http\Controllers\Controller', '\\');
// 'Controller'
Str::apa()
Str::apa
메서드는 문자열을 APA 가이드라인에 따라 제목 형식(Title Case)으로 변환합니다:
use Illuminate\Support\Str;
$title = Str::apa('Creating A Project');
// 'Creating a Project'
Str::ascii()
Str::ascii
메서드는 문자열을 ASCII 값으로 변환(음역)하려고 시도합니다:
use Illuminate\Support\Str;
$slice = Str::ascii('û');
// 'u'
Str::before()
Str::before
메서드는 문자열에서 지정한 값 앞에 오는 모든 내용을 반환합니다:
use Illuminate\Support\Str;
$slice = Str::before('This is my name', 'my name');
// 'This is '
Str::beforeLast()
Str::beforeLast
메서드는 문자열에서 지정한 값이 마지막으로 등장하기 전의 모든 부분을 반환합니다:
use Illuminate\Support\Str;
$slice = Str::beforeLast('This is my name', 'is');
// 'This '
Str::between()
Str::between
메서드는 두 값 사이에 위치하는 문자열의 일부를 반환합니다:
use Illuminate\Support\Str;
$slice = Str::between('This is my name', 'This', 'name');
// ' is my '
Str::betweenFirst()
Str::betweenFirst
메서드는 두 값 사이에서 찾을 수 있는 가장 짧은(최소 크기) 부분 문자열을 반환합니다:
use Illuminate\Support\Str;
$slice = Str::betweenFirst('[a] bc [d]', '[', ']');
// 'a'
Str::camel()
Str::camel
메서드는 주어진 문자열을 camelCase
(카멜 표기법)로 변환합니다:
use Illuminate\Support\Str;
$converted = Str::camel('foo_bar');
// 'fooBar'
Str::charAt()
Str::charAt
메서드는 지정한 인덱스 위치의 문자를 반환합니다. 만약 인덱스가 범위를 벗어나면 false
를 반환합니다:
use Illuminate\Support\Str;
$character = Str::charAt('This is my name.', 6);
// 's'
Str::chopStart()
Str::chopStart
메서드는 전달한 값이 문자열의 시작 부분에 있을 때, 해당 값이 처음 등장한 부분만 잘라냅니다:
use Illuminate\Support\Str;
$url = Str::chopStart('https://laravel.com', 'https://');
// 'laravel.com'
두 번째 인수로 배열을 전달할 수도 있습니다. 만약 문자열이 배열 안에 있는 값 중 하나로 시작한다면, 그 값이 문자열에서 제거됩니다:
use Illuminate\Support\Str;
$url = Str::chopStart('http://laravel.com', ['https://', 'http://']);
// 'laravel.com'
Str::chopEnd()
Str::chopEnd
메서드는 전달한 값이 문자열의 끝에 있을 때, 해당 값이 마지막에 등장한 부분만 잘라냅니다:
use Illuminate\Support\Str;
$url = Str::chopEnd('app/Models/Photograph.php', '.php');
// 'app/Models/Photograph'
두 번째 인수로 배열을 전달할 수도 있습니다. 만약 문자열이 배열 안에 있는 값 중 하나로 끝난다면, 그 값이 문자열에서 제거됩니다:
use Illuminate\Support\Str;
$url = Str::chopEnd('laravel.com/index.php', ['/index.html', '/index.php']);
// 'laravel.com'
Str::contains()
Str::contains
메서드는 주어진 문자열에 특정 값이 포함되어 있는지 확인합니다. 기본적으로 대소문자를 구분합니다:
use Illuminate\Support\Str;
$contains = Str::contains('This is my name', 'my');
// true
또한, 배열을 전달하여 해당 문자열에 배열 내 값 중 하나라도 포함되어 있는지 확인할 수도 있습니다:
use Illuminate\Support\Str;
$contains = Str::contains('This is my name', ['my', 'foo']);
// true
ignoreCase
인수를 true
로 설정하면 대소문자를 무시할 수 있습니다:
use Illuminate\Support\Str;
$contains = Str::contains('This is my name', 'MY', ignoreCase: true);
// true
Str::containsAll()
Str::containsAll
메서드는 주어진 문자열에 배열의 모든 값이 포함되어 있는지 확인합니다:
use Illuminate\Support\Str;
$containsAll = Str::containsAll('This is my name', ['my', 'name']);
// true
ignoreCase
인수를 true
로 설정하여 대소문자를 무시할 수도 있습니다:
use Illuminate\Support\Str;
$containsAll = Str::containsAll('This is my name', ['MY', 'NAME'], ignoreCase: true);
// true
Str::doesntContain()
Str::doesntContain
메서드는 주어진 문자열에 특정 값이 포함되어 있지 않은지 확인합니다. 기본적으로 대소문자를 구분합니다:
use Illuminate\Support\Str;
$doesntContain = Str::doesntContain('This is name', 'my');
// true
또한, 배열을 전달하여 문자열에 배열 내 값 중 어느 것도 포함되어 있지 않은지 확인할 수 있습니다:
use Illuminate\Support\Str;
$doesntContain = Str::doesntContain('This is name', ['my', 'foo']);
// true
ignoreCase
인수를 true
로 설정하면 대소문자를 무시할 수 있습니다:
use Illuminate\Support\Str;
$doesntContain = Str::doesntContain('This is name', 'MY', ignoreCase: true);
// true
Str::deduplicate()
Str::deduplicate
메서드는 주어진 문자열에서 연속해서 반복되는 문자를 한 번만 남기고 모두 하나로 합칩니다. 기본적으로 이 메서드는 공백 문자를 합칩니다:
use Illuminate\Support\Str;
$result = Str::deduplicate('The Laravel Framework');
// The Laravel Framework
두 번째 인수로 합칠 문자를 지정하여 공백 외의 문자도 중복을 합칠 수 있습니다:
use Illuminate\Support\Str;
$result = Str::deduplicate('The---Laravel---Framework', '-');
// The-Laravel-Framework
Str::endsWith()
Str::endsWith
메서드는 주어진 문자열이 특정 값으로 끝나는지 확인합니다.
use Illuminate\Support\Str;
$result = Str::endsWith('This is my name', 'name');
// true
또한 값의 배열을 전달하여, 주어진 문자열이 배열 내 값 중 하나로 끝나는지 확인할 수도 있습니다.
use Illuminate\Support\Str;
$result = Str::endsWith('This is my name', ['name', 'foo']);
// true
$result = Str::endsWith('This is my name', ['this', 'foo']);
// false
Str::excerpt()
Str::excerpt
메서드는 주어진 문자열에서 특정 구절이 처음 등장하는 부분을 기준으로 발췌(excerpt)를 추출합니다.
use Illuminate\Support\Str;
$excerpt = Str::excerpt('This is my name', 'my', [
'radius' => 3
]);
// '...is my na...'
radius
옵션(기본값 100)을 사용하면, 생략된 문자열 양쪽에 표시할 문자 수를 지정할 수 있습니다.
또한, omission
옵션을 사용하여 생략된 문자열 앞뒤에 붙을 문자열을 지정할 수 있습니다.
use Illuminate\Support\Str;
$excerpt = Str::excerpt('This is my name', 'name', [
'radius' => 3,
'omission' => '(...) '
]);
// '(...) my name'
Str::finish()
Str::finish
메서드는 주어진 문자열이 특정 값으로 끝나지 않는 경우, 그 값을 한 번만 문자열 끝에 추가합니다.
use Illuminate\Support\Str;
$adjusted = Str::finish('this/string', '/');
// this/string/
$adjusted = Str::finish('this/string/', '/');
// this/string/
Str::headline()
Str::headline
메서드는 케이스(casing), 하이픈, 언더스코어로 구분된 문자열을 각 단어의 첫 글자가 대문자인 공백으로 구분된 문자열로 변환합니다.
use Illuminate\Support\Str;
$headline = Str::headline('steve_jobs');
// Steve Jobs
$headline = Str::headline('EmailNotificationSent');
// Email Notification Sent
Str::inlineMarkdown()
Str::inlineMarkdown
메서드는 GitHub Flavored Markdown을 CommonMark를 사용해 인라인 HTML로 변환합니다. 하지만 markdown
메서드와 달리, 생성된 모든 HTML을 블록 레벨 요소로 감싸지 않습니다.
use Illuminate\Support\Str;
$html = Str::inlineMarkdown('**Laravel**');
// <strong>Laravel</strong>
Markdown 보안
기본적으로 Markdown은 원시 HTML을 지원하므로, 사용자 입력을 바로 사용할 경우 교차 사이트 스크립팅(XSS) 취약점이 발생할 수 있습니다. CommonMark 보안 문서에 따라, html_input
옵션을 사용해 원시 HTML을 escape 또는 strip(제거)할 수 있고, allow_unsafe_links
옵션으로 안전하지 않은 링크 허용 여부를 지정할 수 있습니다. 만약 일부 원시 HTML을 허용해야 한다면, 변환된 Markdown 결과를 HTML Purifier로 한 번 더 거쳐 처리하는 방식을 권장합니다.
use Illuminate\Support\Str;
Str::inlineMarkdown('Inject: <script>alert("Hello XSS!");</script>', [
'html_input' => 'strip',
'allow_unsafe_links' => false,
]);
// Inject: alert("Hello XSS!");
Str::is()
Str::is
메서드는 주어진 문자열이 특정 패턴과 일치하는지 확인합니다. 패턴에는 별표(*)를 와일드카드로 사용할 수 있습니다.
use Illuminate\Support\Str;
$matches = Str::is('foo*', 'foobar');
// true
$matches = Str::is('baz*', 'foobar');
// false
대소문자 구분을 하지 않으려면 ignoreCase
인수를 true
로 지정할 수 있습니다.
use Illuminate\Support\Str;
$matches = Str::is('*.jpg', 'photo.JPG', ignoreCase: true);
// true
Str::isAscii()
Str::isAscii
메서드는 주어진 문자열이 7비트 ASCII 문자열인지 판별합니다.
use Illuminate\Support\Str;
$isAscii = Str::isAscii('Taylor');
// true
$isAscii = Str::isAscii('ü');
// false
Str::isJson()
Str::isJson
메서드는 주어진 문자열이 유효한 JSON 형식인지 확인합니다.
use Illuminate\Support\Str;
$result = Str::isJson('[1,2,3]');
// true
$result = Str::isJson('{"first": "John", "last": "Doe"}');
// true
$result = Str::isJson('{first: "John", last: "Doe"}');
// false
Str::isUrl()
Str::isUrl
메서드는 주어진 문자열이 올바른 URL인지 확인합니다.
use Illuminate\Support\Str;
$isUrl = Str::isUrl('http://example.com');
// true
$isUrl = Str::isUrl('laravel');
// false
isUrl
메서드는 광범위한 프로토콜을 유효한 것으로 간주합니다. 하지만, 원하는 프로토콜만 허용하려면 해당 프로토콜을 배열로 전달할 수 있습니다.
$isUrl = Str::isUrl('http://example.com', ['http', 'https']);
Str::isUlid()
Str::isUlid
메서드는 주어진 문자열이 유효한 ULID인지 확인합니다.
use Illuminate\Support\Str;
$isUlid = Str::isUlid('01gd6r360bp37zj17nxb55yv40');
// true
$isUlid = Str::isUlid('laravel');
// false
Str::isUuid()
Str::isUuid
메서드는 주어진 문자열이 유효한 UUID인지 확인합니다.
use Illuminate\Support\Str;
$isUuid = Str::isUuid('a0a2a2d2-0b87-4a18-83f2-2529882be2de');
// true
$isUuid = Str::isUuid('laravel');
// false
Str::kebab()
Str::kebab
메서드는 주어진 문자열을 kebab-case
형식으로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::kebab('fooBar');
// foo-bar
Str::lcfirst()
Str::lcfirst
메서드는 주어진 문자열의 첫 글자를 소문자로 변환하여 반환합니다.
use Illuminate\Support\Str;
$string = Str::lcfirst('Foo Bar');
// foo Bar
Str::length()
Str::length
메서드는 주어진 문자열의 길이를 반환합니다.
use Illuminate\Support\Str;
$length = Str::length('Laravel');
// 7
Str::limit()
Str::limit
메서드는 주어진 문자열을 지정한 길이만큼 잘라서 반환합니다.
use Illuminate\Support\Str;
$truncated = Str::limit('The quick brown fox jumps over the lazy dog', 20);
// The quick brown fox...
세 번째 인수를 전달하면 생략 표시로 사용할 문자열을 직접 지정할 수도 있습니다.
$truncated = Str::limit('The quick brown fox jumps over the lazy dog', 20, ' (...)');
// The quick brown fox (...)
문자열을 자를 때 단어 경계를 유지하고 싶다면 preserveWords
인수를 사용하면 됩니다. 이 값을 true
로 지정하면 마지막 단어가 중간에 잘리지 않습니다.
$truncated = Str::limit('The quick brown fox', 12, preserveWords: true);
// The quick...
Str::lower()
Str::lower
메서드는 주어진 문자열을 모두 소문자로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::lower('LARAVEL');
// laravel
Str::markdown()
Str::markdown
메서드는 GitHub Flavored Markdown을 CommonMark을 통해 HTML로 변환합니다.
use Illuminate\Support\Str;
$html = Str::markdown('# Laravel');
// <h1>Laravel</h1>
$html = Str::markdown('# Taylor <b>Otwell</b>', [
'html_input' => 'strip',
]);
// <h1>Taylor Otwell</h1>
Markdown 보안
기본적으로 Markdown은 원시 HTML을 지원하므로, 사용자 입력을 바로 사용할 경우 교차 사이트 스크립팅(XSS) 취약점이 발생할 수 있습니다. CommonMark 보안 문서에 따라, html_input
옵션을 사용해 원시 HTML을 escape 또는 strip(제거)할 수 있고, allow_unsafe_links
옵션으로 안전하지 않은 링크 허용 여부를 지정할 수 있습니다. 만약 일부 원시 HTML을 허용해야 한다면, 변환된 Markdown 결과를 HTML Purifier로 한 번 더 거쳐 처리하는 방식을 권장합니다.
use Illuminate\Support\Str;
Str::markdown('Inject: <script>alert("Hello XSS!");</script>', [
'html_input' => 'strip',
'allow_unsafe_links' => false,
]);
// <p>Inject: alert("Hello XSS!");</p>
Str::mask()
Str::mask
메서드는 문자열의 일부 구간을 반복되는 문자로 마스킹합니다. 이를 통해 이메일 주소, 전화번호 등 일부 정보를 숨길 때 사용할 수 있습니다.
use Illuminate\Support\Str;
$string = Str::mask('[email protected]', '*', 3);
// tay***************
필요하다면 세 번째 인수(마스킹 시작 위치)에 음수를 전달해 문자열 끝에서부터 거리를 지정할 수 있습니다.
$string = Str::mask('[email protected]', '*', -15, 3);
// tay***@example.com
Str::orderedUuid()
Str::orderedUuid
메서드는 인덱스 컬럼에 효율적으로 저장할 수 있는 "타임스탬프 우선" UUID를 생성합니다. 이 메서드로 생성된 UUID는 이전에 생성된 UUID보다 뒤에 오게 정렬됩니다.
use Illuminate\Support\Str;
return (string) Str::orderedUuid();
Str::padBoth()
Str::padBoth
메서드는 PHP의 str_pad
함수를 감싸, 문자열 양쪽을 특정 문자열로 채워 원하는 길이가 되도록 만듭니다.
use Illuminate\Support\Str;
$padded = Str::padBoth('James', 10, '_');
// '__James___'
$padded = Str::padBoth('James', 10);
// ' James '
Str::padLeft()
Str::padLeft
메서드는 PHP의 str_pad
함수를 감싸, 문자열 왼쪽 측면을 특정 문자열로 채워서 원하는 길이가 되도록 만듭니다.
use Illuminate\Support\Str;
$padded = Str::padLeft('James', 10, '-=');
// '-=-=-James'
$padded = Str::padLeft('James', 10);
// ' James'
Str::padRight()
Str::padRight
메서드는 PHP의 str_pad
함수를 감싸, 문자열 오른쪽 측면을 특정 문자열로 채워서 원하는 길이가 되도록 만듭니다.
use Illuminate\Support\Str;
$padded = Str::padRight('James', 10, '-');
// 'James-----'
$padded = Str::padRight('James', 10);
// 'James '
Str::password()
Str::password
메서드는 주어진 길이의 안전한 랜덤 비밀번호를 생성합니다. 비밀번호는 문자, 숫자, 기호, 공백 등으로 조합됩니다. 기본적으로 비밀번호 길이는 32자입니다.
use Illuminate\Support\Str;
$password = Str::password();
// 'EbJo2vE-AS:U,$%_gkrV4n,q~1xy/-_4'
$password = Str::password(12);
// 'qwuar>#V|i]N'
Str::plural()
Str::plural
메서드는 단수 영어 단어를 복수형으로 변환합니다. 이 함수는 라라벨의 복수화 기능이 지원하는 모든 언어를 지원합니다.
use Illuminate\Support\Str;
$plural = Str::plural('car');
// cars
$plural = Str::plural('child');
// children
두 번째 인수로 정수를 전달하면, 해당 수에 따라 단수 형태 또는 복수 형태 중 적합한 형태가 반환됩니다.
use Illuminate\Support\Str;
$plural = Str::plural('child', 2);
// children
$singular = Str::plural('child', 1);
// child
Str::pluralStudly()
Str::pluralStudly
메서드는 StudlyCaps 형식의 단수형 영단어를 복수형으로 변환합니다. 이 함수 역시 라라벨의 복수화 기능이 지원하는 모든 언어를 지원합니다.
use Illuminate\Support\Str;
$plural = Str::pluralStudly('VerifiedHuman');
// VerifiedHumans
$plural = Str::pluralStudly('UserFeedback');
// UserFeedback
두 번째 인수로 정수를 전달하면, 해당 수에 따라서 단수 혹은 복수 형태 중 적절한 형태를 반환합니다.
use Illuminate\Support\Str;
$plural = Str::pluralStudly('VerifiedHuman', 2);
// VerifiedHumans
$singular = Str::pluralStudly('VerifiedHuman', 1);
// VerifiedHuman
Str::position()
Str::position
메서드는 주어진 문자열에서 특정 부분 문자열이 처음 등장하는 위치를 반환합니다. 찾는 문자열이 존재하지 않을 경우 false
를 반환합니다.
use Illuminate\Support\Str;
$position = Str::position('Hello, World!', 'Hello');
// 0
$position = Str::position('Hello, World!', 'W');
// 7
Str::random()
Str::random
메서드는 지정한 길이만큼의 임의의 문자열을 생성합니다. 이 함수는 PHP의 random_bytes
함수를 사용합니다.
use Illuminate\Support\Str;
$random = Str::random(40);
테스트 환경에서는 Str::random
메서드가 반환하는 값을 "가짜"로 만들 수 있습니다. 이를 위해 createRandomStringsUsing
메서드를 사용할 수 있습니다.
Str::createRandomStringsUsing(function () {
return 'fake-random-string';
});
다시 원래처럼 임의의 값을 생성하도록 하려면, createRandomStringsNormally
메서드를 호출하면 됩니다.
Str::createRandomStringsNormally();
Str::remove()
Str::remove
메서드는 주어진 값 또는 값의 배열을 문자열에서 제거합니다.
use Illuminate\Support\Str;
$string = 'Peter Piper picked a peck of pickled peppers.';
$removed = Str::remove('e', $string);
// Ptr Pipr pickd a pck of pickld ppprs.
또한, remove
메서드의 세 번째 인자로 false
를 전달하면 문자열을 제거할 때 대소문자를 구분하지 않도록 설정할 수 있습니다.
Str::repeat()
Str::repeat
메서드는 주어진 문자열을 지정한 횟수만큼 반복합니다.
use Illuminate\Support\Str;
$string = 'a';
$repeat = Str::repeat($string, 5);
// aaaaa
Str::replace()
Str::replace
메서드는 문자열 내에서 지정한 문자열을 다른 문자열로 대체합니다.
use Illuminate\Support\Str;
$string = 'Laravel 11.x';
$replaced = Str::replace('11.x', '12.x', $string);
// Laravel 12.x
replace
메서드는 caseSensitive
(대소문자 구분) 인자도 받을 수 있습니다. 기본적으로 replace
메서드는 대소문자를 구분합니다.
Str::replace('Framework', 'Laravel', caseSensitive: false);
Str::replaceArray()
Str::replaceArray
메서드는 배열을 이용하여 문자열 내의 지정한 값들을 순차적으로 대체합니다.
use Illuminate\Support\Str;
$string = 'The event will take place between ? and ?';
$replaced = Str::replaceArray('?', ['8:30', '9:00'], $string);
// The event will take place between 8:30 and 9:00
Str::replaceFirst()
Str::replaceFirst
메서드는 문자열 내에서 지정한 값이 처음 등장하는 부분만을 다른 값으로 대체합니다.
use Illuminate\Support\Str;
$replaced = Str::replaceFirst('the', 'a', 'the quick brown fox jumps over the lazy dog');
// a quick brown fox jumps over the lazy dog
Str::replaceLast()
Str::replaceLast
메서드는 문자열 내에서 지정한 값이 마지막으로 등장하는 부분만을 다른 값으로 대체합니다.
use Illuminate\Support\Str;
$replaced = Str::replaceLast('the', 'a', 'the quick brown fox jumps over the lazy dog');
// the quick brown fox jumps over a lazy dog
Str::replaceMatches()
Str::replaceMatches
메서드는 지정한 패턴에 일치하는 문자열의 모든 부분을 주어진 값으로 대체합니다.
use Illuminate\Support\Str;
$replaced = Str::replaceMatches(
pattern: '/[^A-Za-z0-9]++/',
replace: '',
subject: '(+1) 501-555-1000'
)
// '15015551000'
replaceMatches
메서드는 일치하는 각 부분에 대해 호출되는 클로저를 인자로 받아, 해당 부분을 클로저 내부에서 처리하여 원하는 값으로 대체할 수도 있습니다.
use Illuminate\Support\Str;
$replaced = Str::replaceMatches('/\d/', function (array $matches) {
return '['.$matches[0].']';
}, '123');
// '[1][2][3]'
Str::replaceStart()
Str::replaceStart
메서드는 지정한 값이 문자열의 맨 앞에 있을 경우, 처음 등장하는 해당 값만을 다른 값으로 대체합니다.
use Illuminate\Support\Str;
$replaced = Str::replaceStart('Hello', 'Laravel', 'Hello World');
// Laravel World
$replaced = Str::replaceStart('World', 'Laravel', 'Hello World');
// Hello World
Str::replaceEnd()
Str::replaceEnd
메서드는 지정한 값이 문자열의 맨 끝에 있을 때만, 마지막에 등장하는 해당 값만을 다른 값으로 대체합니다.
use Illuminate\Support\Str;
$replaced = Str::replaceEnd('World', 'Laravel', 'Hello World');
// Hello Laravel
$replaced = Str::replaceEnd('Hello', 'Laravel', 'Hello World');
// Hello World
Str::reverse()
Str::reverse
메서드는 주어진 문자열의 순서를 뒤집어 반환합니다.
use Illuminate\Support\Str;
$reversed = Str::reverse('Hello World');
// dlroW olleH
Str::singular()
Str::singular
메서드는 문자열을 단수형으로 변환합니다. 이 함수는 라라벨의 복수화(pluralization) 기능이 지원하는 모든 언어를 사용할 수 있습니다.
use Illuminate\Support\Str;
$singular = Str::singular('cars');
// car
$singular = Str::singular('children');
// child
Str::slug()
Str::slug
메서드는 주어진 문자열에서 URL에 적합한 "슬러그(slug)"를 생성합니다.
use Illuminate\Support\Str;
$slug = Str::slug('Laravel 5 Framework', '-');
// laravel-5-framework
Str::snake()
Str::snake
메서드는 주어진 문자열을 snake_case
로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::snake('fooBar');
// foo_bar
$converted = Str::snake('fooBar', '-');
// foo-bar
Str::squish()
Str::squish
메서드는 문자열 내의 불필요한 공백, 단어 사이에 포함된 여분의 공백을 모두 제거합니다.
use Illuminate\Support\Str;
$string = Str::squish(' laravel framework ');
// laravel framework
Str::start()
Str::start
메서드는 문자열이 이미 해당 값으로 시작하지 않는 경우, 지정한 값을 앞에 한 번만 추가합니다.
use Illuminate\Support\Str;
$adjusted = Str::start('this/string', '/');
// /this/string
$adjusted = Str::start('/this/string', '/');
// /this/string
Str::startsWith()
Str::startsWith
메서드는 주어진 문자열이 특정 값으로 시작하는지 여부를 확인합니다.
use Illuminate\Support\Str;
$result = Str::startsWith('This is my name', 'This');
// true
여러 개의 값을 배열로 전달하면, 문자열이 배열 내 어떤 값으로 시작하더라도 true
를 반환합니다.
$result = Str::startsWith('This is my name', ['This', 'That', 'There']);
// true
Str::studly()
Str::studly
메서드는 문자열을 StudlyCase
(각 단어의 첫 글자만 대문자)로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::studly('foo_bar');
// FooBar
Str::substr()
Str::substr
메서드는 지정한 시작 위치와 길이에 따라 부분 문자열을 반환합니다.
use Illuminate\Support\Str;
$converted = Str::substr('The Laravel Framework', 4, 7);
// Laravel
Str::substrCount()
Str::substrCount
메서드는 주어진 문자열에서 지정한 값이 등장하는 횟수를 반환합니다.
use Illuminate\Support\Str;
$count = Str::substrCount('If you like ice cream, you will like snow cones.', 'like');
// 2
Str::substrReplace()
Str::substrReplace
메서드는 문자열의 일부 구간 내 텍스트를 대체합니다. 세 번째 인자는 시작 위치, 네 번째 인자는 교체될 문자 개수를 의미합니다. 네 번째 인자에 0
을 전달하면 기존 문자를 아무것도 대체하지 않고, 해당 위치에 문자열을 삽입할 수 있습니다.
use Illuminate\Support\Str;
$result = Str::substrReplace('1300', ':', 2);
// 13:
$result = Str::substrReplace('1300', ':', 2, 0);
// 13:00
Str::swap()
Str::swap
메서드는 PHP의 strtr
함수를 이용하여 문자열 내 여러 값을 한 번에 치환합니다.
use Illuminate\Support\Str;
$string = Str::swap([
'Tacos' => 'Burritos',
'great' => 'fantastic',
], 'Tacos are great!');
// Burritos are fantastic!
Str::take()
Str::take
메서드는 문자열의 처음부터 지정한 개수만큼의 문자를 반환합니다.
use Illuminate\Support\Str;
$taken = Str::take('Build something amazing!', 5);
// Build
Str::title()
Str::title
메서드는 문자열을 영어의 Title Case
(각 단어 첫 글자를 대문자로)로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::title('a nice title uses the correct case');
// A Nice Title Uses The Correct Case
Str::toBase64()
Str::toBase64
메서드는 주어진 문자열을 Base64 인코딩된 문자열로 변환합니다.
use Illuminate\Support\Str;
$base64 = Str::toBase64('Laravel');
// TGFyYXZlbA==
Str::transliterate()
Str::transliterate
메서드는 주어진 문자열을 가능한 가장 비슷한 ASCII 표현으로 변환합니다.
use Illuminate\Support\Str;
$email = Str::transliterate('ⓣⓔⓢⓣ@ⓛⓐⓡⓐⓥⓔⓛ.ⓒⓞⓜ');
// '[email protected]'
Str::trim()
Str::trim
메서드는 주어진 문자열의 앞뒤에서 공백(또는 지정 문자들)을 제거합니다. PHP의 기본 trim
함수와 달리, Str::trim
은 유니코드 공백 문자도 함께 제거합니다.
use Illuminate\Support\Str;
$string = Str::trim(' foo bar ');
// 'foo bar'
Str::ltrim()
Str::ltrim
메서드는 문자열의 시작 부분에서 공백(또는 지정 문자들)을 제거합니다. PHP의 기본 ltrim
함수와 달리, Str::ltrim
도 유니코드 공백을 제거합니다.
use Illuminate\Support\Str;
$string = Str::ltrim(' foo bar ');
// 'foo bar '
Str::rtrim()
Str::rtrim
메서드는 문자열의 끝 부분에서 공백(또는 지정 문자들)을 제거합니다. PHP의 기본 rtrim
함수와 달리, Str::rtrim
도 유니코드 공백 문자를 제거합니다.
use Illuminate\Support\Str;
$string = Str::rtrim(' foo bar ');
// ' foo bar'
Str::ucfirst()
Str::ucfirst
메서드는 주어진 문자열의 첫 글자를 대문자로 변환해 반환합니다.
use Illuminate\Support\Str;
$string = Str::ucfirst('foo bar');
// Foo bar
Str::ucsplit()
Str::ucsplit
메서드는 주어진 문자열을 대문자 기준으로 나누어 배열로 반환합니다.
use Illuminate\Support\Str;
$segments = Str::ucsplit('FooBar');
// [0 => 'Foo', 1 => 'Bar']
Str::upper()
Str::upper
메서드는 주어진 문자열을 모두 대문자로 변환합니다.
use Illuminate\Support\Str;
$string = Str::upper('laravel');
// LARAVEL
Str::ulid()
Str::ulid
메서드는 ULID(Compact, 시간 순으로 정렬되는 고유 식별자)를 생성합니다.
use Illuminate\Support\Str;
return (string) Str::ulid();
// 01gd6r360bp37zj17nxb55yv40
특정 ULID가 생성된 날짜와 시간을 나타내는 Illuminate\Support\Carbon
인스턴스를 얻고 싶다면, 라라벨의 Carbon 통합에서 제공하는 createFromId
메서드를 사용할 수 있습니다.
use Illuminate\Support\Carbon;
use Illuminate\Support\Str;
$date = Carbon::createFromId((string) Str::ulid());
테스트를 수행할 때, Str::ulid
메서드가 반환하는 값을 임의로 고정시키고 싶을 때가 있습니다. 이를 위해 createUlidsUsing
메서드를 사용할 수 있습니다.
use Symfony\Component\Uid\Ulid;
Str::createUlidsUsing(function () {
return new Ulid('01HRDBNHHCKNW2AK4Z29SN82T9');
});
ULID를 다시 정상적으로 생성하도록 하려면, createUlidsNormally
메서드를 호출하면 됩니다.
Str::createUlidsNormally();
Str::unwrap()
Str::unwrap
메서드는 주어진 문자열의 시작과 끝에서 지정한 문자열을 제거합니다.
use Illuminate\Support\Str;
Str::unwrap('-Laravel-', '-');
// Laravel
Str::unwrap('{framework: "Laravel"}', '{', '}');
// framework: "Laravel"
Str::uuid()
Str::uuid
메서드는 UUID(버전4)를 생성합니다.
use Illuminate\Support\Str;
return (string) Str::uuid();
테스트 수행 시 Str::uuid
메서드가 반환하는 값을 '임의로 고정'하고자 할 때는 createUuidsUsing
메서드를 사용할 수 있습니다.
use Ramsey\Uuid\Uuid;
Str::createUuidsUsing(function () {
return Uuid::fromString('eadbfeac-5258-45c2-bab7-ccb9b5ef74f9');
});
UUID 생성 방식을 정상 모드로 되돌리려면 createUuidsNormally
메서드를 호출하세요.
Str::createUuidsNormally();
Str::uuid7()
Str::uuid7
메서드는 UUID(버전7)를 생성합니다.
use Illuminate\Support\Str;
return (string) Str::uuid7();
정렬 가능한 UUID를 생성할 때 사용할 시간 정보를 옵션으로 DateTimeInterface
형태로 전달할 수 있습니다.
return (string) Str::uuid7(time: now());
Str::wordCount()
Str::wordCount
메서드는 문자열에 포함된 단어의 개수를 반환합니다.
use Illuminate\Support\Str;
Str::wordCount('Hello, world!'); // 2
Str::wordWrap()
Str::wordWrap
메서드는 문자열을 지정한 글자 수로 감싸 줄바꿈합니다.
use Illuminate\Support\Str;
$text = "The quick brown fox jumped over the lazy dog."
Str::wordWrap($text, characters: 20, break: "<br />\n");
/*
The quick brown fox<br />
jumped over the lazy<br />
dog.
*/
Str::words()
Str::words
메서드는 문자열의 단어 수를 제한합니다. 세 번째 인수로 추가 문자열을 전달하여, 잘린 문자열의 끝에 붙일 값을 지정할 수 있습니다.
use Illuminate\Support\Str;
return Str::words('Perfectly balanced, as all things should be.', 3, ' >>>');
// Perfectly balanced, as >>>
Str::wrap()
Str::wrap
메서드는 주어진 문자열을 앞뒤로 원하는 문자열로 감쌉니다.
use Illuminate\Support\Str;
Str::wrap('Laravel', '"');
// "Laravel"
Str::wrap('is', before: 'This ', after: ' Laravel!');
// This is Laravel!
str()
str
함수는 주어진 문자열로 새로운 Illuminate\Support\Stringable
인스턴스를 반환합니다. 이 함수는 Str::of
메서드와 동일합니다.
$string = str('Taylor')->append(' Otwell');
// 'Taylor Otwell'
str
함수에 인수를 전달하지 않으면, Illuminate\Support\Str
인스턴스를 반환합니다.
$snake = str()->snake('FooBar');
// 'foo_bar'
trans()
trans
함수는 언어 파일을 사용하여 지정한 번역 키를 번역합니다.
echo trans('messages.welcome');
지정한 번역 키가 존재하지 않으면, trans
함수는 인자로 전달된 키 자체를 반환합니다. 위 예시에서, 해당 번역 키가 없다면 trans
함수는 messages.welcome
을 반환하게 됩니다.
trans_choice()
trans_choice
함수는 주어진 번역 키를 단수/복수형에 맞게 번역합니다.
echo trans_choice('messages.notifications', $unreadCount);
지정한 번역 키가 존재하지 않으면, trans_choice
함수는 키 자체를 반환합니다. 위 예시에서 해당 번역 키가 없다면 messages.notifications
을 반환합니다.
플루언트 문자열(Fluent Strings)
플루언트 문자열은 더 읽기 쉽고 체이닝이 가능한 객체 지향 방식의 문자열 처리 인터페이스를 제공합니다. 기존의 문자열 처리 방식보다 여러 문자열 연산을 한 번에 연결하여 사용할 수 있습니다.
after
after
메서드는 문자열에서 지정한 값 다음에 오는 모든 내용을 반환합니다. 해당 값이 문자열에 존재하지 않으면 전체 문자열을 반환합니다.
use Illuminate\Support\Str;
$slice = Str::of('This is my name')->after('This is');
// ' my name'
afterLast
afterLast
메서드는 문자열에서 지정한 값이 마지막으로 등장한 이후의 모든 내용을 반환합니다. 해당 값이 없으면 전체 문자열을 반환합니다.
use Illuminate\Support\Str;
$slice = Str::of('App\Http\Controllers\Controller')->afterLast('\\');
// 'Controller'
apa
apa
메서드는 APA 규칙에 따라 주어진 문자열을 제목 표기법(title case)으로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::of('a nice title uses the correct case')->apa();
// A Nice Title Uses the Correct Case
append
append
메서드는 주어진 값을 문자열 뒤에 덧붙입니다.
use Illuminate\Support\Str;
$string = Str::of('Taylor')->append(' Otwell');
// 'Taylor Otwell'
ascii
ascii
메서드는 가능한 경우 문자열을 ASCII 값으로 변환합니다.
use Illuminate\Support\Str;
$string = Str::of('ü')->ascii();
// 'u'
basename
basename
메서드는 주어진 문자열에서 마지막 경로 요소(파일명 등)를 반환합니다.
use Illuminate\Support\Str;
$string = Str::of('/foo/bar/baz')->basename();
// 'baz'
필요하다면, 파일의 확장자 등 제거할 "확장자" 값을 추가로 전달할 수 있습니다.
use Illuminate\Support\Str;
$string = Str::of('/foo/bar/baz.jpg')->basename('.jpg');
// 'baz'
before
before
메서드는 문자열에서 지정한 값이 나오기 전까지의 내용을 반환합니다.
use Illuminate\Support\Str;
$slice = Str::of('This is my name')->before('my name');
// 'This is '
beforeLast
beforeLast
메서드는 문자열에서 지정한 값이 마지막으로 등장하기 전까지의 내용을 반환합니다.
use Illuminate\Support\Str;
$slice = Str::of('This is my name')->beforeLast('is');
// 'This '
between
between
메서드는 두 지정된 값 사이에 위치한 문자열의 일부만 반환합니다.
use Illuminate\Support\Str;
$converted = Str::of('This is my name')->between('This', 'name');
// ' is my '
betweenFirst
betweenFirst
메서드는 지정한 두 값 사이에 있는 가장 짧은 문자열 부분을 반환합니다.
use Illuminate\Support\Str;
$converted = Str::of('[a] bc [d]')->betweenFirst('[', ']');
// 'a'
camel
camel
메서드는 주어진 문자열을 camelCase
로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::of('foo_bar')->camel();
// 'fooBar'
charAt
charAt
메서드는 지정한 인덱스에 해당하는 문자를 반환합니다. 인덱스가 범위를 벗어나면 false
를 반환합니다.
use Illuminate\Support\Str;
$character = Str::of('This is my name.')->charAt(6);
// 's'
classBasename
classBasename
메서드는 네임스페이스를 제외한 클래스명만 반환합니다.
use Illuminate\Support\Str;
$class = Str::of('Foo\Bar\Baz')->classBasename();
// 'Baz'
chopStart
chopStart
메서드는 문자열이 지정한 값으로 시작할 경우, 처음 등장하는 해당 값만 제거합니다.
use Illuminate\Support\Str;
$url = Str::of('https://laravel.com')->chopStart('https://');
// 'laravel.com'
배열을 전달할 수도 있습니다. 문자열이 배열 안에 있는 값 중 하나로 시작하면, 그 값이 제거됩니다.
use Illuminate\Support\Str;
$url = Str::of('http://laravel.com')->chopStart(['https://', 'http://']);
// 'laravel.com'
chopEnd
chopEnd
메서드는 문자열 끝에 해당 값이 있을 경우, 마지막에 등장하는 그 값만 제거합니다.
use Illuminate\Support\Str;
$url = Str::of('https://laravel.com')->chopEnd('.com');
// 'https://laravel'
배열을 전달할 수도 있습니다. 문자열이 배열 안에 있는 값 중 하나로 끝나면, 그 값이 제거됩니다.
use Illuminate\Support\Str;
$url = Str::of('http://laravel.com')->chopEnd(['.com', '.io']);
// 'http://laravel'
contains
contains
메서드는 문자열이 지정한 값을 포함하고 있는지 확인합니다. 기본적으로 대소문자를 구분합니다.
use Illuminate\Support\Str;
$contains = Str::of('This is my name')->contains('my');
// true
배열을 전달하여, 해당 배열의 값 중 하나라도 포함하는지 확인할 수 있습니다.
use Illuminate\Support\Str;
$contains = Str::of('This is my name')->contains(['my', 'foo']);
// true
ignoreCase
인수를 true
로 설정하면 대소문자를 구분하지 않습니다.
use Illuminate\Support\Str;
$contains = Str::of('This is my name')->contains('MY', ignoreCase: true);
// true
containsAll
containsAll
메서드는 문자열이 지정한 배열의 모든 값을 모두 포함하는지 확인합니다.
use Illuminate\Support\Str;
$containsAll = Str::of('This is my name')->containsAll(['my', 'name']);
// true
ignoreCase
인수를 true
로 설정하면 대소문자를 구분하지 않습니다.
use Illuminate\Support\Str;
$containsAll = Str::of('This is my name')->containsAll(['MY', 'NAME'], ignoreCase: true);
// true
deduplicate
deduplicate
메서드는 주어진 문자열에서 연속되는 문자들을 하나씩만 남기고 중복을 제거합니다. 기본적으로 공백 문자를 중복 제거합니다.
use Illuminate\Support\Str;
$result = Str::of('The Laravel Framework')->deduplicate();
// The Laravel Framework
두 번째 인수로 다른 문자를 지정하면, 그 문자에 대해 중복 제거가 실행됩니다.
use Illuminate\Support\Str;
$result = Str::of('The---Laravel---Framework')->deduplicate('-');
// The-Laravel-Framework
dirname
dirname
메서드는 주어진 문자열에서 상위 디렉터리 경로 부분을 반환합니다.
use Illuminate\Support\Str;
$string = Str::of('/foo/bar/baz')->dirname();
// '/foo/bar'
추가로, 문자열에서 제거할 디렉터리 계층의 수를 지정할 수 있습니다.
use Illuminate\Support\Str;
$string = Str::of('/foo/bar/baz')->dirname(2);
// '/foo'
endsWith
endsWith
메서드는 문자열이 지정한 값으로 끝나는지 확인합니다.
use Illuminate\Support\Str;
$result = Str::of('This is my name')->endsWith('name');
// true
배열을 전달하여, 배열 안의 값 중 하나라도 문자열의 끝에 있으면 참을 반환합니다.
use Illuminate\Support\Str;
$result = Str::of('This is my name')->endsWith(['name', 'foo']);
// true
$result = Str::of('This is my name')->endsWith(['this', 'foo']);
// false
exactly
exactly
메서드는 문자열이 다른 문자열과 정확히 일치하는지 확인합니다.
use Illuminate\Support\Str;
$result = Str::of('Laravel')->exactly('Laravel');
// true
excerpt
excerpt
메서드는 문자열에서 지정한 구/문구가 처음 등장하는 부분을 중심으로 발췌(excerpt) 문자열을 반환합니다.
use Illuminate\Support\Str;
$excerpt = Str::of('This is my name')->excerpt('my', [
'radius' => 3
]);
// '...is my na...'
radius
옵션은 기본값이 100
이며, 잘린 문자열의 양쪽에 몇 글자가 표시될지 결정합니다.
또한 omission
옵션을 사용해 잘린 부분 앞뒤에 붙일 문자열을 변경할 수도 있습니다.
use Illuminate\Support\Str;
$excerpt = Str::of('This is my name')->excerpt('name', [
'radius' => 3,
'omission' => '(...) '
]);
// '(...) my name'
explode
explode
메서드는 지정한 구분자로 문자열을 분할하고, 분할된 각 부분이 포함된 컬렉션을 반환합니다.
use Illuminate\Support\Str;
$collection = Str::of('foo bar baz')->explode(' ');
// collect(['foo', 'bar', 'baz'])
finish
finish
메서드는 문자열이 지정한 값으로 끝나지 않는 경우, 그 값을 문자열 끝에 추가합니다.
use Illuminate\Support\Str;
$adjusted = Str::of('this/string')->finish('/');
// this/string/
$adjusted = Str::of('this/string/')->finish('/');
// this/string/
headline
headline
메서드는 케이스, 하이픈(-
), 밑줄(_
)로 분리된 문자열을 띄어쓰기로 구분한 다음, 각 단어의 첫 글자를 대문자로 변환합니다.
use Illuminate\Support\Str;
$headline = Str::of('taylor_otwell')->headline();
// Taylor Otwell
$headline = Str::of('EmailNotificationSent')->headline();
// Email Notification Sent
inlineMarkdown
inlineMarkdown
메서드는 GitHub 스타일 마크다운을 CommonMark를 사용하여 인라인 HTML로 변환합니다. 하지만 markdown
메서드와 달리, 생성된 HTML 전체를 블록 요소로 감싸지 않습니다.
use Illuminate\Support\Str;
$html = Str::of('**Laravel**')->inlineMarkdown();
// <strong>Laravel</strong>
마크다운 보안
기본적으로 마크다운은 원시 HTML을 지원하므로, 사용자로부터 받은 원본 입력을 그대로 사용할 경우 교차 사이트 스크립팅(XSS) 취약점이 노출될 수 있습니다. CommonMark 보안 문서에 따르면, html_input
옵션을 사용하여 원시 HTML을 이스케이프하거나 제거하도록 설정할 수 있으며, allow_unsafe_links
옵션을 통해 안전하지 않은 링크의 허용 여부를 지정할 수 있습니다. 특정 원시 HTML만 허용해야 한다면, 변환된 마크다운을 HTML Purifier와 같은 필터를 통해 한 번 더 정제해야 합니다.
use Illuminate\Support\Str;
Str::of('Inject: <script>alert("Hello XSS!");</script>')->inlineMarkdown([
'html_input' => 'strip',
'allow_unsafe_links' => false,
]);
// Inject: alert("Hello XSS!");
is
is
메서드는 주어진 문자열이 특정 패턴과 일치하는지 확인합니다. 패턴 내에 별표(*)를 와일드카드로 사용할 수 있습니다.
use Illuminate\Support\Str;
$matches = Str::of('foobar')->is('foo*');
// true
$matches = Str::of('foobar')->is('baz*');
// false
isAscii
isAscii
메서드는 주어진 문자열이 ASCII 문자열인지 확인합니다.
use Illuminate\Support\Str;
$result = Str::of('Taylor')->isAscii();
// true
$result = Str::of('ü')->isAscii();
// false
isEmpty
isEmpty
메서드는 주어진 문자열이 비어 있는지를 확인합니다.
use Illuminate\Support\Str;
$result = Str::of(' ')->trim()->isEmpty();
// true
$result = Str::of('Laravel')->trim()->isEmpty();
// false
isNotEmpty
isNotEmpty
메서드는 주어진 문자열이 비어 있지 않은지 확인합니다.
use Illuminate\Support\Str;
$result = Str::of(' ')->trim()->isNotEmpty();
// false
$result = Str::of('Laravel')->trim()->isNotEmpty();
// true
isJson
isJson
메서드는 주어진 문자열이 올바른 JSON 형식인지 판별합니다.
use Illuminate\Support\Str;
$result = Str::of('[1,2,3]')->isJson();
// true
$result = Str::of('{"first": "John", "last": "Doe"}')->isJson();
// true
$result = Str::of('{first: "John", last: "Doe"}')->isJson();
// false
isUlid
isUlid
메서드는 주어진 문자열이 ULID인지 확인합니다.
use Illuminate\Support\Str;
$result = Str::of('01gd6r360bp37zj17nxb55yv40')->isUlid();
// true
$result = Str::of('Taylor')->isUlid();
// false
isUrl
isUrl
메서드는 주어진 문자열이 URL인지 확인합니다.
use Illuminate\Support\Str;
$result = Str::of('http://example.com')->isUrl();
// true
$result = Str::of('Taylor')->isUrl();
// false
isUrl
메서드는 다양한 프로토콜을 유효한 것으로 간주합니다. 하지만, 인자로 프로토콜을 직접 지정하면 해당 프로토콜만 유효한 것으로 간주합니다.
$result = Str::of('http://example.com')->isUrl(['http', 'https']);
isUuid
isUuid
메서드는 주어진 문자열이 UUID인지 확인합니다.
use Illuminate\Support\Str;
$result = Str::of('5ace9ab9-e9cf-4ec6-a19d-5881212a452c')->isUuid();
// true
$result = Str::of('Taylor')->isUuid();
// false
kebab
kebab
메서드는 주어진 문자열을 kebab-case
로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::of('fooBar')->kebab();
// foo-bar
lcfirst
lcfirst
메서드는 주어진 문자열의 첫 글자를 소문자로 변환하여 반환합니다.
use Illuminate\Support\Str;
$string = Str::of('Foo Bar')->lcfirst();
// foo Bar
length
length
메서드는 주어진 문자열의 길이를 반환합니다.
use Illuminate\Support\Str;
$length = Str::of('Laravel')->length();
// 7
limit
limit
메서드는 주어진 문자열을 지정한 길이만큼 자릅니다.
use Illuminate\Support\Str;
$truncated = Str::of('The quick brown fox jumps over the lazy dog')->limit(20);
// The quick brown fox...
자르는 뒤에 붙일 문자열을 두 번째 인자로 지정할 수도 있습니다.
$truncated = Str::of('The quick brown fox jumps over the lazy dog')->limit(20, ' (...)');
// The quick brown fox (...)
문자열을 자를 때 완전한 단어 단위로 자르기를 원한다면, preserveWords
인자를 사용할 수 있습니다. 이 인자가 true
이면 문자열은 가장 가까운 단어 경계까지만 잘립니다.
$truncated = Str::of('The quick brown fox')->limit(12, preserveWords: true);
// The quick...
lower
lower
메서드는 주어진 문자열을 모두 소문자로 변환합니다.
use Illuminate\Support\Str;
$result = Str::of('LARAVEL')->lower();
// 'laravel'
markdown
markdown
메서드는 GitHub Flavored Markdown을 HTML로 변환합니다.
use Illuminate\Support\Str;
$html = Str::of('# Laravel')->markdown();
// <h1>Laravel</h1>
$html = Str::of('# Taylor <b>Otwell</b>')->markdown([
'html_input' => 'strip',
]);
// <h1>Taylor Otwell</h1>
마크다운 보안
기본적으로 마크다운은 원시 HTML을 지원해 사용자의 원본 입력을 그대로 사용할 경우 교차 사이트 스크립팅(XSS) 취약점이 발생할 수 있습니다. CommonMark 보안 문서에 따라, html_input
옵션을 사용해 원시 HTML을 이스케이프하거나 제거하거나, allow_unsafe_links
옵션으로 안전하지 않은 링크 허용 여부를 지정할 수 있습니다. 일부 원시 HTML만 허용해야 하는 경우, 변환된 마크다운 결과를 HTML Purifier 등 정화 도구에 한 번 더 통과시키십시오.
use Illuminate\Support\Str;
Str::of('Inject: <script>alert("Hello XSS!");</script>')->markdown([
'html_input' => 'strip',
'allow_unsafe_links' => false,
]);
// <p>Inject: alert("Hello XSS!");</p>
mask
mask
메서드는 문자열의 일부 구간을 지정한 문자로 반복 마스킹하여, 이메일 주소나 전화번호 등 민감한 데이터의 일부를 가릴 때 사용할 수 있습니다.
use Illuminate\Support\Str;
$string = Str::of('[email protected]')->mask('*', 3);
// tay***************
필요에 따라, 세 번째나 네 번째 인자에 음수를 전달하면 문자열의 끝에서부터 지정한 길이만큼 마스킹을 시작하거나 종료할 수 있습니다.
$string = Str::of('[email protected]')->mask('*', -15, 3);
// tay***@example.com
$string = Str::of('[email protected]')->mask('*', 4, -4);
// tayl**********.com
match
match
메서드는 주어진 정규 표현식 패턴과 일치하는 문자열의 일부분을 반환합니다.
use Illuminate\Support\Str;
$result = Str::of('foo bar')->match('/bar/');
// 'bar'
$result = Str::of('foo bar')->match('/foo (.*)/');
// 'bar'
matchAll
matchAll
메서드는 주어진 정규 표현식 패턴과 일치하는 모든 부분을 포함하는 컬렉션을 반환합니다.
use Illuminate\Support\Str;
$result = Str::of('bar foo bar')->matchAll('/bar/');
// collect(['bar', 'bar'])
표현식에 매칭 그룹을 지정하면, 라라벨은 첫 번째 그룹의 일치하는 값들로 컬렉션을 반환합니다.
use Illuminate\Support\Str;
$result = Str::of('bar fun bar fly')->matchAll('/f(\w*)/');
// collect(['un', 'ly']);
매치되는 값이 없다면 비어 있는 컬렉션이 반환됩니다.
isMatch
isMatch
메서드는 문자열이 주어진 정규 표현식과 일치하면 true
를 반환합니다.
use Illuminate\Support\Str;
$result = Str::of('foo bar')->isMatch('/foo (.*)/');
// true
$result = Str::of('laravel')->isMatch('/foo (.*)/');
// false
newLine
newLine
메서드는 문자열 끝에 "줄 바꿈" 문자를 한 번 추가합니다.
use Illuminate\Support\Str;
$padded = Str::of('Laravel')->newLine()->append('Framework');
// 'Laravel
// Framework'
padBoth
padBoth
메서드는 PHP의 str_pad
함수와 동일하게, 문자열 양쪽을 지정한 문자로 패딩하여 전체 길이가 원하는 길이에 도달하도록 만듭니다.
use Illuminate\Support\Str;
$padded = Str::of('James')->padBoth(10, '_');
// '__James___'
$padded = Str::of('James')->padBoth(10);
// ' James '
padLeft
padLeft
메서드는 PHP의 str_pad
와 유사하게, 문자열 왼쪽을 지정한 문자로 채워서 전체 길이가 원하는 길이가 되도록 만듭니다.
use Illuminate\Support\Str;
$padded = Str::of('James')->padLeft(10, '-=');
// '-=-=-James'
$padded = Str::of('James')->padLeft(10);
// ' James'
padRight
padRight
메서드는 PHP의 str_pad
함수와 유사하게, 문자열 오른쪽을 지정한 문자로 채워 원하는 전체 길이를 맞춥니다.
use Illuminate\Support\Str;
$padded = Str::of('James')->padRight(10, '-');
// 'James-----'
$padded = Str::of('James')->padRight(10);
// 'James '
pipe
pipe
메서드는 현재 문자열 값을 지정한 콜러블(callable)에 전달해 문자열을 변환할 수 있게 해줍니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$hash = Str::of('Laravel')->pipe('md5')->prepend('Checksum: ');
// 'Checksum: a5c95b86291ea299fcbe64458ed12702'
$closure = Str::of('foo')->pipe(function (Stringable $str) {
return 'bar';
});
// 'bar'
plural
plural
메서드는 단수 형태의 단어 문자열을 복수형으로 변환합니다. 이 함수는 라라벨의 pluralizer가 지원하는 모든 언어를 지원합니다.
use Illuminate\Support\Str;
$plural = Str::of('car')->plural();
// cars
$plural = Str::of('child')->plural();
// children
정수 값을 두 번째 인자로 넘기면, 해당 숫자에 맞는 단수/복수형을 자동으로 반환합니다.
use Illuminate\Support\Str;
$plural = Str::of('child')->plural(2);
// children
$plural = Str::of('child')->plural(1);
// child
position
position
메서드는 문자열 안에서 특정 부분 문자열이 처음 등장하는 위치(인덱스)를 반환합니다. 만약 부분 문자열이 포함되어 있지 않으면 false
를 반환합니다.
use Illuminate\Support\Str;
$position = Str::of('Hello, World!')->position('Hello');
// 0
$position = Str::of('Hello, World!')->position('W');
// 7
prepend
prepend
메서드는 주어진 값을 문자열 앞에 추가합니다.
use Illuminate\Support\Str;
$string = Str::of('Framework')->prepend('Laravel ');
// Laravel Framework
remove
remove
메서드는 주어진 값 또는 값의 배열에 해당하는 문자열 부분을 모두 제거합니다.
use Illuminate\Support\Str;
$string = Str::of('Arkansas is quite beautiful!')->remove('quite');
// Arkansas is beautiful!
대/소문자를 구분하지 않고 문자열을 제거하려면 두 번째 파라미터에 false
를 전달할 수 있습니다.
repeat
repeat
메서드는 문자열을 지정한 횟수만큼 반복해 반환합니다.
use Illuminate\Support\Str;
$repeated = Str::of('a')->repeat(5);
// aaaaa
replace
replace
메서드는 문자열 내에서 특정 부분 문자열을 다른 값으로 교체합니다.
use Illuminate\Support\Str;
$replaced = Str::of('Laravel 6.x')->replace('6.x', '7.x');
// Laravel 7.x
replace
메서드는 caseSensitive
인자도 받을 수 있습니다. 기본적으로 이 메서드는 대/소문자를 구분합니다.
$replaced = Str::of('macOS 13.x')->replace(
'macOS', 'iOS', caseSensitive: false
);
replaceArray
replaceArray
메서드는 문자열 내 지정한 값을 배열의 각 값으로 순차적으로 대체합니다.
use Illuminate\Support\Str;
$string = 'The event will take place between ? and ?';
$replaced = Str::of($string)->replaceArray('?', ['8:30', '9:00']);
// The event will take place between 8:30 and 9:00
replaceFirst
replaceFirst
메서드는 문자열에서 지정한 값이 처음 등장하는 부분을 다른 값으로 교체합니다.
use Illuminate\Support\Str;
$replaced = Str::of('the quick brown fox jumps over the lazy dog')->replaceFirst('the', 'a');
// a quick brown fox jumps over the lazy dog
replaceLast
replaceLast
메서드는 문자열에서 지정한 값이 마지막으로 등장하는 부분을 다른 값으로 교체합니다.
use Illuminate\Support\Str;
$replaced = Str::of('the quick brown fox jumps over the lazy dog')->replaceLast('the', 'a');
// the quick brown fox jumps over a lazy dog
replaceMatches
replaceMatches
메서드는 정규 표현식 패턴에 일치하는 문자열의 모든 부분을 지정한 문자열로 교체합니다.
use Illuminate\Support\Str;
$replaced = Str::of('(+1) 501-555-1000')->replaceMatches('/[^A-Za-z0-9]++/', '')
// '15015551000'
replaceMatches
메서드는 패턴에 일치하는 각 부분에 대해 호출되는 클로저도 인자로 받을 수 있습니다. 이 경우, 클로저 안에서 직접 교체 로직을 작성하고, 그 반환값이 치환 값으로 사용됩니다.
use Illuminate\Support\Str;
$replaced = Str::of('123')->replaceMatches('/\d/', function (array $matches) {
return '['.$matches[0].']';
});
// '[1][2][3]'
replaceStart
replaceStart
메서드는 지정한 값이 문자열의 시작 부분에 나타날 때만, 그 부분을 새로운 값으로 교체합니다.
use Illuminate\Support\Str;
$replaced = Str::of('Hello World')->replaceStart('Hello', 'Laravel');
// Laravel World
$replaced = Str::of('Hello World')->replaceStart('World', 'Laravel');
// Hello World
replaceEnd
replaceEnd
메서드는 지정한 값이 문자열의 끝에 나타날 때만, 그 부분을 새로운 값으로 교체합니다.
use Illuminate\Support\Str;
$replaced = Str::of('Hello World')->replaceEnd('World', 'Laravel');
// Hello Laravel
$replaced = Str::of('Hello World')->replaceEnd('Hello', 'Laravel');
// Hello World
scan
scan
메서드는 sscanf
PHP 함수에서 지원하는 형식에 따라 문자열에서 값을 파싱하여 컬렉션으로 반환합니다.
use Illuminate\Support\Str;
$collection = Str::of('filename.jpg')->scan('%[^.].%s');
// collect(['filename', 'jpg'])
singular
singular
메서드는 문자열을 단수형으로 변환합니다. 이 함수는 라라벨의 복수화 기능에서 지원하는 언어라면 모두 사용할 수 있습니다.
use Illuminate\Support\Str;
$singular = Str::of('cars')->singular();
// car
$singular = Str::of('children')->singular();
// child
slug
slug
메서드는 주어진 문자열을 URL 친화적인 "slug" 형태로 변환합니다.
use Illuminate\Support\Str;
$slug = Str::of('Laravel Framework')->slug('-');
// laravel-framework
snake
snake
메서드는 주어진 문자열을 snake_case
로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::of('fooBar')->snake();
// foo_bar
split
split
메서드는 정규 표현식을 이용해 문자열을 컬렉션으로 분할합니다.
use Illuminate\Support\Str;
$segments = Str::of('one, two, three')->split('/[\s,]+/');
// collect(["one", "two", "three"])
squish
squish
메서드는 문자열 내의 불필요한 공백(단어 사이 포함)을 모두 제거합니다.
use Illuminate\Support\Str;
$string = Str::of(' laravel framework ')->squish();
// laravel framework
start
start
메서드는 주어진 값으로 문자열이 이미 시작하지 않는 경우, 그 값을 문자열 앞에 추가합니다.
use Illuminate\Support\Str;
$adjusted = Str::of('this/string')->start('/');
// /this/string
$adjusted = Str::of('/this/string')->start('/');
// /this/string
startsWith
startsWith
메서드는 문자열이 지정한 값으로 시작하는지 여부를 판단합니다.
use Illuminate\Support\Str;
$result = Str::of('This is my name')->startsWith('This');
// true
stripTags
stripTags
메서드는 문자열에서 모든 HTML 및 PHP 태그를 제거합니다.
use Illuminate\Support\Str;
$result = Str::of('<a href="https://laravel.com">Taylor <b>Otwell</b></a>')->stripTags();
// Taylor Otwell
$result = Str::of('<a href="https://laravel.com">Taylor <b>Otwell</b></a>')->stripTags('<b>');
// Taylor <b>Otwell</b>
studly
studly
메서드는 주어진 문자열을 StudlyCase
로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::of('foo_bar')->studly();
// FooBar
substr
substr
메서드는 지정한 시작 위치와 길이에 따라 문자열의 일부를 반환합니다.
use Illuminate\Support\Str;
$string = Str::of('Laravel Framework')->substr(8);
// Framework
$string = Str::of('Laravel Framework')->substr(8, 5);
// Frame
substrReplace
substrReplace
메서드는 문자열의 일부를 두 번째 인수에 지정한 위치에서, 세 번째 인수로 지정된 글자 수만큼 대체 문자열로 교체합니다. 세 번째 인수에 0
을 전달하면 기존 문자를 대체하지 않고 해당 위치에 새 문자열을 삽입합니다.
use Illuminate\Support\Str;
$string = Str::of('1300')->substrReplace(':', 2);
// 13:
$string = Str::of('The Framework')->substrReplace(' Laravel', 3, 0);
// The Laravel Framework
swap
swap
메서드는 PHP의 strtr
함수를 사용해, 문자열 내 여러 값을 동시에 교체합니다.
use Illuminate\Support\Str;
$string = Str::of('Tacos are great!')
->swap([
'Tacos' => 'Burritos',
'great' => 'fantastic',
]);
// Burritos are fantastic!
take
take
메서드는 문자열의 처음부터 지정한 개수만큼의 문자를 반환합니다.
use Illuminate\Support\Str;
$taken = Str::of('Build something amazing!')->take(5);
// Build
tap
tap
메서드는 문자열을 전달된 클로저에 넘깁니다. 이 메서드를 활용하면 중간에 문자열을 확인하거나 필요한 처리를 할 수 있지만, 최종적으로 tap
메서드는 클로저의 반환값과 상관없이 원래의 문자열을 반환합니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('Laravel')
->append(' Framework')
->tap(function (Stringable $string) {
dump('String after append: '.$string);
})
->upper();
// LARAVEL FRAMEWORK
test
test
메서드는 주어진 문자열이 지정한 정규 표현식 패턴과 일치하는지 여부를 확인합니다.
use Illuminate\Support\Str;
$result = Str::of('Laravel Framework')->test('/Laravel/');
// true
title
title
메서드는 주어진 문자열을 Title Case
(각 단어가 대문자로 시작)를 적용한 형태로 변환합니다.
use Illuminate\Support\Str;
$converted = Str::of('a nice title uses the correct case')->title();
// A Nice Title Uses The Correct Case
toBase64
toBase64
메서드는 주어진 문자열을 Base64로 인코딩합니다.
use Illuminate\Support\Str;
$base64 = Str::of('Laravel')->toBase64();
// TGFyYXZlbA==
toHtmlString
toHtmlString
메서드는 주어진 문자열을 Illuminate\Support\HtmlString
인스턴스로 변환합니다. 이렇게 하면 Blade 템플릿에서 렌더링될 때 이 문자열이 이스케이프되지 않습니다.
use Illuminate\Support\Str;
$htmlString = Str::of('Nuno Maduro')->toHtmlString();
transliterate
transliterate
메서드는 주어진 문자열을 가능한 가장 근접한 ASCII 표현으로 변환하려고 시도합니다.
use Illuminate\Support\Str;
$email = Str::of('ⓣⓔⓢⓣ@ⓛⓐⓡⓐⓥⓔⓛ.ⓒⓞⓜ')->transliterate()
// '[email protected]'
trim
trim
메서드는 주어진 문자열의 앞뒤 공백을 제거합니다. PHP의 기본 trim
함수와는 달리, 라라벨의 trim
은 유니코드 공백 문자도 제거합니다.
use Illuminate\Support\Str;
$string = Str::of(' Laravel ')->trim();
// 'Laravel'
$string = Str::of('/Laravel/')->trim('/');
// 'Laravel'
ltrim
ltrim
메서드는 문자열의 왼쪽(앞부분) 공백을 제거합니다. PHP의 기본 ltrim
함수와 달리, 라라벨의 ltrim
은 유니코드 공백 문자도 제거합니다.
use Illuminate\Support\Str;
$string = Str::of(' Laravel ')->ltrim();
// 'Laravel '
$string = Str::of('/Laravel/')->ltrim('/');
// 'Laravel/'
rtrim
rtrim
메서드는 문자열의 오른쪽(끝부분) 공백을 제거합니다. PHP의 기본 rtrim
함수와 달리, 라라벨의 rtrim
은 유니코드 공백 문자도 제거합니다.
use Illuminate\Support\Str;
$string = Str::of(' Laravel ')->rtrim();
// ' Laravel'
$string = Str::of('/Laravel/')->rtrim('/');
// '/Laravel'
ucfirst
ucfirst
메서드는 주어진 문자열의 첫 글자를 대문자로 변환합니다.
use Illuminate\Support\Str;
$string = Str::of('foo bar')->ucfirst();
// Foo bar
ucsplit
ucsplit
메서드는 문자열을 대문자 기준으로 분할하여 컬렉션으로 반환합니다.
use Illuminate\Support\Str;
$string = Str::of('Foo Bar')->ucsplit();
// collect(['Foo', 'Bar'])
unwrap
unwrap
메서드는 주어진 문자열의 시작과 끝에서 지정한 문자열을 제거합니다.
use Illuminate\Support\Str;
Str::of('-Laravel-')->unwrap('-');
// Laravel
Str::of('{framework: "Laravel"}')->unwrap('{', '}');
// framework: "Laravel"
upper
upper
메서드는 주어진 문자열을 모두 대문자로 변환합니다.
use Illuminate\Support\Str;
$adjusted = Str::of('laravel')->upper();
// LARAVEL
when
when
메서드는 주어진 조건이 true
일 때 클로저를 실행합니다. 이 때 클로저는 Fluent 문자열 인스턴스를 인수로 받습니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('Taylor')
->when(true, function (Stringable $string) {
return $string->append(' Otwell');
});
// 'Taylor Otwell'
필요하다면 when
메서드의 세 번째 매개변수로 또 다른 클로저를 전달할 수 있습니다. 이 클로저는 조건이 false
일 때 실행됩니다.
whenContains
whenContains
메서드는 문자열에 특정 값이 포함되어 있을 때 클로저를 실행합니다. 클로저는 Fluent 문자열 인스턴스를 인수로 받습니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('tony stark')
->whenContains('tony', function (Stringable $string) {
return $string->title();
});
// 'Tony Stark'
필요하다면 세 번째 매개변수로 또 다른 클로저를 전달할 수 있습니다. 이 클로저는 문자열이 주어진 값을 포함하지 않을 때 실행됩니다.
여러 값을 배열로 전달하면, 해당 배열에 있는 값 중 하나라도 포함되었는지 확인할 수 있습니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('tony stark')
->whenContains(['tony', 'hulk'], function (Stringable $string) {
return $string->title();
});
// Tony Stark
whenContainsAll
whenContainsAll
메서드는 문자열에 지정한 여러 문자열이 모두 포함되어 있을 때 클로저를 실행합니다. 클로저는 Fluent 문자열 인스턴스를 인수로 받습니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('tony stark')
->whenContainsAll(['tony', 'stark'], function (Stringable $string) {
return $string->title();
});
// 'Tony Stark'
필요하다면 세 번째 매개변수로 또 다른 클로저를 전달할 수 있습니다. 이 클로저는 조건이 false
일 때 실행됩니다.
whenEmpty
whenEmpty
메서드는 문자열이 비어 있을 때 클로저를 실행합니다. 클로저에서 반환한 값이 있으면 그것이 최종 반환값이 되고, 반환값이 없으면 Fluent 문자열 인스턴스가 반환됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of(' ')->trim()->whenEmpty(function (Stringable $string) {
return $string->prepend('Laravel');
});
// 'Laravel'
whenNotEmpty
whenNotEmpty
메서드는 문자열이 비어 있지 않은 경우, 전달된 클로저를 실행합니다. 클로저가 값을 반환하면, 그 값이 whenNotEmpty
메서드의 반환값이 됩니다. 클로저에서 명시적으로 값을 반환하지 않으면, fluent string 인스턴스 자체가 반환됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('Framework')->whenNotEmpty(function (Stringable $string) {
return $string->prepend('Laravel ');
});
// 'Laravel Framework'
whenStartsWith
whenStartsWith
메서드는 문자열이 지정한 하위 문자열로 시작하는 경우, 전달된 클로저를 실행합니다. 이때 fluent string 인스턴스가 클로저에 전달됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('disney world')->whenStartsWith('disney', function (Stringable $string) {
return $string->title();
});
// 'Disney World'
whenEndsWith
whenEndsWith
메서드는 문자열이 지정한 하위 문자열로 끝나는 경우, 전달된 클로저를 실행합니다. 클로저에는 fluent string 인스턴스가 전달됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('disney world')->whenEndsWith('world', function (Stringable $string) {
return $string->title();
});
// 'Disney World'
whenExactly
whenExactly
메서드는 문자열이 주어진 문자열과 정확히 일치하는 경우, 전달된 클로저를 실행합니다. 클로저에는 fluent string 인스턴스가 전달됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('laravel')->whenExactly('laravel', function (Stringable $string) {
return $string->title();
});
// 'Laravel'
whenNotExactly
whenNotExactly
메서드는 문자열이 주어진 문자열과 정확히 일치하지 않는 경우, 전달된 클로저를 실행합니다. 클로저에는 fluent string 인스턴스가 전달됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('framework')->whenNotExactly('laravel', function (Stringable $string) {
return $string->title();
});
// 'Framework'
whenIs
whenIs
메서드는 문자열이 주어진 패턴과 일치하는 경우, 전달된 클로저를 실행합니다. 패턴 값에는 와일드카드(별표)를 사용할 수 있습니다. 클로저에는 fluent string 인스턴스가 전달됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('foo/bar')->whenIs('foo/*', function (Stringable $string) {
return $string->append('/baz');
});
// 'foo/bar/baz'
whenIsAscii
whenIsAscii
메서드는 문자열이 7비트 ASCII 문자인 경우, 전달된 클로저를 실행합니다. 클로저에는 fluent string 인스턴스가 전달됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('laravel')->whenIsAscii(function (Stringable $string) {
return $string->title();
});
// 'Laravel'
whenIsUlid
whenIsUlid
메서드는 문자열이 올바른 ULID인 경우, 전달된 클로저를 실행합니다. 클로저에는 fluent string 인스턴스가 전달됩니다.
use Illuminate\Support\Str;
$string = Str::of('01gd6r360bp37zj17nxb55yv40')->whenIsUlid(function (Stringable $string) {
return $string->substr(0, 8);
});
// '01gd6r36'
whenIsUuid
whenIsUuid
메서드는 문자열이 올바른 UUID인 경우, 전달된 클로저를 실행합니다. 클로저에는 fluent string 인스턴스가 전달됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('a0a2a2d2-0b87-4a18-83f2-2529882be2de')->whenIsUuid(function (Stringable $string) {
return $string->substr(0, 8);
});
// 'a0a2a2d2'
whenTest
whenTest
메서드는 문자열이 지정한 정규 표현식에 일치하는 경우, 전달된 클로저를 실행합니다. 클로저에는 fluent string 인스턴스가 전달됩니다.
use Illuminate\Support\Str;
use Illuminate\Support\Stringable;
$string = Str::of('laravel framework')->whenTest('/laravel/', function (Stringable $string) {
return $string->title();
});
// 'Laravel Framework'
wordCount
wordCount
메서드는 문자열에 포함된 단어의 개수를 반환합니다.
use Illuminate\Support\Str;
Str::of('Hello, world!')->wordCount(); // 2
words
words
메서드는 문자열 내 단어 수를 제한합니다. 필요하다면, 잘린 문자열 끝에 추가로 붙일 문자열을 지정할 수도 있습니다.
use Illuminate\Support\Str;
$string = Str::of('Perfectly balanced, as all things should be.')->words(3, ' >>>');
// Perfectly balanced, as >>>
wrap
wrap
메서드는 주어진 문자열을 추가적인 문자열 또는 문자열 쌍으로 감쌉니다.
use Illuminate\Support\Str;
Str::of('Laravel')->wrap('"');
// "Laravel"
Str::is('is')->wrap(before: 'This ', after: ' Laravel!');
// This is Laravel!