찾다
PHP 프레임워크LaravelPHP 프레임워크 Laravel의 최신 SQL 주입 취약점에 대한 간략한 분석

잘 알려진 PHP 개발 프레임워크인 Laravel은 이전에 공식 블로그에 고위험 SQL 주입 취약점을 보고했습니다.

PHP 프레임워크 Laravel의 최신 SQL 주입 취약점에 대한 간략한 분석

우선 이 취약점은 웹사이트의 불규칙한 코딩에 속합니다. 공식은 다음과 같이 힌트를 주었습니다.

PHP 프레임워크 Laravel의 최신 SQL 주입 취약점에 대한 간략한 분석

하지만 공식은 여전히 ​​패치를 만들었고 최신 버전인 V5로 업그레이드하면 문제가 해결될 수 있습니다. .8.7.

먼저 여기를 찾으세요:

Illuminate\Validation\Rule

공식적으로 권장되는 작성 방법은:

Rule::unique('users')->ignore($id),

웹사이트 코딩이 $id의 값을 미리 처리하지 않으면 사용자가 악성 데이터를 무시 함수에 직접 전달할 수 있습니다. SQL 주입에.

함수에 대해 이야기해 보겠습니다.

\Illuminate\Validation\Rules\Unique.php class Unique {
... public function ignore($id, $idColumn = null) { if ($id instanceof Model) { return $this->ignoreModel($id, $idColumn);
        } $this->ignore = $id; $this->idColumn = $idColumn ?? 'id'; return $this;
    }

여기에서는 $id를 인스턴스로 작성하는 것을 고려하지 않습니다. $id가 사용자가 제어할 수 있는 경우 $idColumn을 비어 있는 상태로 직접 작성할 수 있습니다.

$this->ignore = $id; $this->idColumn = 'id';

웹사이트의 코드가 다음과 같이 구성되어 있다면 해커가 입력한 값은 제어 가능한 상태입니다:

$id = $request->input('id');

마지막으로 여기에 도달합니다:

Illuminate\Validation\Rules\Unique.php public function __toString() {
        ...
        ...
    }

키 코드 변경 사항을 살펴보겠습니다:

Illuminate\Validation\Rules\Unique.php
V5.8.7【最新版】 public function __toString() { $this->ignore ? '"'.addslashes($this->ignore).'"' : 'NULL',
    } 
Illuminate\Validation\Rules\Unique.php
V5.8.4 public function __toString() { $this->ignore ? '"'.$this->ignore.'"' : 'NULL',
    }

The 최신 코드 v5.8.7 여기에 $ this->ignore를 직접 추가하면 이전에는 보호 기능이 없었습니다.

흥미롭게도 저자는 차이점을 비교했는데, 그 동안 관계자는 다른 인용 장소도 필터링하려고 했습니다. 마지막으로 __toString에서 통합 필터링이 수행되었습니다.

마지막으로 다음 코드는 후속 SQL 규칙 일치를 위해 DatabaseRule을 입력합니다.

Illuminate\Validation\Rules\DatabaseRule.php

이후 더 이상의 처리는 없었고, 그러다가 SQL인젝션이 형성되었습니다.

더 많은 Laravel 관련 기술 기사를 보려면 Laravel Framework Getting Started Tutorial 칼럼을 방문하여 알아보세요!

위 내용은 PHP 프레임워크 Laravel의 최신 SQL 주입 취약점에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 FreeBuf에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Laravel의 영향 : 웹 개발 단순화Laravel의 영향 : 웹 개발 단순화Apr 21, 2025 am 12:18 AM

Laravel은 웹 개발 프로세스를 단순화하고 강력한 기능을 제공함으로써 두드러집니다. 장점은 1) 간결한 구문 및 강력한 ORM 시스템, 2) 효율적인 라우팅 및 인증 시스템, 3) 풍부한 타사 라이브러리 지원으로 개발자가 우아한 코드 작성에 집중하고 개발 효율성을 향상시킬 수 있도록합니다.

Laravel : 프론트 엔드 또는 백엔드? 프레임 워크의 역할을 명확히합니다Laravel : 프론트 엔드 또는 백엔드? 프레임 워크의 역할을 명확히합니다Apr 21, 2025 am 12:17 AM

LaravelispredominallyAbackendFramework, DesignForserver-SideLogic, DatabaseManagement 및 inapidevelopment, thitalSupportsfrontendDevelopment와 함께 BithBladetemPlates.

Laravel vs. Python : 성능과 확장 성 탐색Laravel vs. Python : 성능과 확장 성 탐색Apr 21, 2025 am 12:16 AM

Laravel과 Python은 성능과 확장 성 측면에서 고유 한 장점과 단점이 있습니다. Laravel은 비동기 처리 및 대기열 시스템을 통해 성능을 향상 시키지만 PHP 제한으로 인해 높은 동시성이있을 때 병목 현상이있을 수 있습니다. Python은 비동기 프레임 워크 및 강력한 라이브러리 생태계와 잘 어울리지 만 다중 스레드 환경에서 GIL의 영향을받습니다.

Laravel vs. Python (프레임 워크 포함) : 비교 분석Laravel vs. Python (프레임 워크 포함) : 비교 분석Apr 21, 2025 am 12:15 AM

Laravel은 팀이 PHP에 익숙하고 풍부한 기능이 필요한 프로젝트에 적합하지만 Python 프레임 워크는 프로젝트 요구 사항에 따라 다릅니다. 1. Laravel은 빠른 개발과 유연성이 필요한 프로젝트에 적합한 우아한 구문 및 풍부한 기능을 제공합니다. 2. Django는 "배터리 포함"개념으로 인해 복잡한 응용 프로그램에 적합합니다. 3. 플라스크는 빠른 프로토 타입과 소규모 프로젝트에 적합하여 유연성이 뛰어납니다.

Laravel과의 프론트 엔드 : 가능성 탐색Laravel과의 프론트 엔드 : 가능성 탐색Apr 20, 2025 am 12:19 AM

Laravel은 프론트 엔드 개발에 사용될 수 있습니다. 1) 블레이드 템플릿 엔진을 사용하여 HTML을 생성하십시오. 2) Vite를 통합하여 프론트 엔드 리소스를 관리합니다. 3) 스파, PWA 또는 정적 웹 사이트를 구축하십시오. 4) 라우팅, 미들웨어 및 eloquentorm을 결합하여 완전한 웹 애플리케이션을 만듭니다.

PHP 및 Laravel : 서버 측 응용 프로그램 구축PHP 및 Laravel : 서버 측 응용 프로그램 구축Apr 20, 2025 am 12:17 AM

PHP 및 Laravel을 사용하여 효율적인 서버 측 응용 프로그램을 구축 할 수 있습니다. 1.PHP는 웹 개발에 적합한 오픈 소스 스크립팅 언어입니다. 2. Laravel은 개발을 단순화하기 위해 라우팅, 컨트롤러, eloquentorm, 블레이드 템플릿 엔진 및 기타 기능을 제공합니다. 3. 캐싱, 코드 최적화 및 보안 조치를 통해 응용 프로그램 성능 및 보안을 향상시킵니다. 4. 응용 프로그램의 안정적인 운영을 보장하기위한 테스트 및 배포 전략.

Laravel vs. Python : 학습 곡선과 사용 편의성Laravel vs. Python : 학습 곡선과 사용 편의성Apr 20, 2025 am 12:17 AM

Laravel과 Python은 학습 곡선과 사용 편의성 측면에서 고유 한 장점과 단점이 있습니다. Laravel은 웹 응용 프로그램의 빠른 개발에 적합합니다. 학습 곡선은 비교적 평평하지만 고급 기능을 마스터하는 데 시간이 걸립니다. 파이썬의 문법은 간결하고 학습 곡선은 평평하지만 동적 유형 시스템은 조심해야합니다.

Laravel의 강점 : 백엔드 개발Laravel의 강점 : 백엔드 개발Apr 20, 2025 am 12:16 AM

백엔드 개발에서 Laravel의 장점은 다음과 같습니다. 1) 우아한 구문 및 Eloquentorm은 개발 프로세스를 단순화합니다. 2) 풍부한 생태계 및 적극적인 커뮤니티 지원; 3) 개발 효율성 및 코드 품질 향상. Laravel의 디자인을 통해 개발자는 강력한 기능과 도구를 통해보다 효율적으로 개발하고 코드 품질을 향상시킬 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)