찾다
백엔드 개발PHP 튜토리얼Laravel 애플리케이션에 전자 메일을 배관합니다

Piping Emails to a Laravel Application

코어 포인트

Laravel의 Command Line Tool Artisan을 연장하여 원시 메일을 받고 응용 프로그램에서 사용할 수 있습니다. 여기에는 IO 스트림에서 원본 메시지를 검색하기 위해 장인에 등록하고 실행할 수있는 와 같은 새 명령을 작성하는 것이 포함됩니다.

    등을 사용하여 원본 메시지를 별도의 섹션으로 해결하십시오. 이를 통해 이메일의 주제 및 본문과 같은 헤더를 검색 할 수 있습니다. 그런 다음 구문 분석 메일을 데이터베이스에 쉽게 저장할 수 있습니다.
  • 이 설정은 메시지의 첨부 파일을 처리 할 수도 있습니다. 첨부 파일을 검색 한 후 파일 시스템 객체를 만들어 서버에 파일을 저장할 수 있습니다. 또한 사용 된 도구 또는 메일 서버에 따라 다른 방법을 사용하여 애플리케이션에 메일을 전달할 수 있습니다. php artisan email:parse
  • 소개
  • php-mime-mail-parser 프로젝트 관리 또는 지원 관리 도구에서 자주 볼 수 있습니다. 이메일에 회신 할 수 있으며 웹 응용 프로그램에 자동으로 나타납니다. 이러한 도구는 이러한 이메일을 시스템으로 직접 가져올 수 있습니다.
  • 이 기사에서는 Laravel 4 응용 프로그램에 이메일을 전달하는 방법을 배웁니다. 이를 위해, 우리는 아래와 같이 작곡가를 통해 설치된 새로운 Laravel 4 프로젝트로 시작했습니다.
  • 장인 명령을 만들어
이메일을 응용 프로그램에 가져 오려면 명령 줄을 통해 이메일을 응용 프로그램으로 전달해야합니다. 다행히 Laravel에는 여러 작업을 수행 할 수있는 Artisan이라는 명령 줄 도구가 있습니다. Artisan이 실행할 수있는 모든 작업의 ​​목록을 보려면 프로젝트의 루트 디렉토리에서

를 실행할 수 있습니다. 이 경우 매우 구체적인 작업을 수행하려고합니다. 원래 이메일을 수락하여 응용 프로그램에서 사용하십시오. 불행히도, 이것은 장인이 처리 할 수있는 기본 기능 중 하나가 아닙니다. 새로운 명령으로 쉽게 확장 할 수 있습니다. 그런 다음 장인을 시작 하고이 경우 라는 특정 작업을 수행합니다.

첫 번째 단계는이 명령을 만드는 것입니다. Artisan 자신의 명령을 통해 새 명령을 만들어 새 명령을 만들 수 있습니다. 프로젝트의 루트 디렉토리에서 다음 명령을 실행하기 만하면됩니다.

모든 것이 잘 진행되면 이제 디렉토리에서 라는 파일이 있습니다. 좋아하는 편집기에서 열고

속성을 ​​봅니다. 필요에 따라 사용자 정의 할 수 있습니다. 명확한 이름과 설명을 제공함으로써 명령은 Artisan 명령 목록에 잘 나열됩니다.

예를 들어, 나는 이것을 이것으로 변경했다 :
composer create-project laravel/laravel your-project-name --prefer-dist

순서 등록 프로젝트의 루트에서

를 실행하면이 명령이 아직 등록되지 않았다는 메시지를 받게됩니다. 다음 단계는이 명령이 Artisan에 등록되어 있는지 확인하는 것입니다. 새로 생성 된 명령을 등록하려면 파일을 열고 파일 끝에 를 추가합시다. 우리는 이제 명령을 다시 실행하여 우리가 나열한 php artisan email:parse 명령을 볼 수 있습니다. 방금 작성한 이름과 설명이 여기에 표시됩니다. app/start/artisan.php Artisan::add(new EmailParserCommand); 원래 이메일 검색 명령이 장인을 통해 호출 될 때마다 항상 list 메소드라고합니다. 처음에는 여기에 이메일 구문 분석을 추가해야합니다. 이메일은 현재 IO 스트림에 있으며 에서 검색 할 수 있습니다. 이 IO 스트림을 열고 전체 스트림을 읽을 때까지 소량의 이메일을 수집합니다. email:parse

Artisan Command로 전송 된 이메일은 이제

변수에 있습니다. 헤더, 본문 및 첨부 파일이 포함 된 전체 이메일입니다. 일정 이메일

이제 우리는 원래 이메일이 있지만 이메일을 여러 부분으로 나누는 것이 좋습니다. 주제 및 이메일 본문과 같은 헤더를 검색하고 싶습니다. 우리는이 모든 부분을 분할하기 위해 자체 코드를 작성할 수 있지만 누군가는 응용 프로그램에서 사용할 수있는 패키지를 만들었습니다. 이 패키지는 전체 이메일을 논리적 부분으로 나눌 수 있습니다. 파일에 다음 줄을 추가하고

를 실행하십시오. fire 이제 우리는 실제로 명령 에서이 패키지를 사용할 수 있는지 확인해야하므로 다시 php://stdin를 열고 다음 줄을 맨 위에 추가합니다.

이제 원래 이메일을 별도의 섹션으로 구문 분석 할 수 있습니다. 다음 코드 줄을
composer create-project laravel/laravel your-project-name --prefer-dist
메소드의 끝에 추가하십시오.

$rawEmail 우리는 먼저 새 파서를 만듭니다. 다음으로 원래 이메일을 파서의 텍스트로 설정하고 마지막으로 다양한 방법으로 호출하여 헤더 나 본문에서 데이터를 얻습니다.

이제 데이터베이스에 이메일을 쉽게 저장할 수 있습니다. 예를 들어, 이메일 엔티티가있는 경우 다음과 같은 데이터베이스에 이메일을 저장할 수 있습니다.

처리 첨부 파일

서버에 이메일에 첨부 된 첨부 파일을 저장할 수도 있습니다. 전자 메일 파서 클래스는 사용 가능한 첨부 파일을 처리 할 수 ​​있습니다. 먼저 다음 줄을

클래스의 상단에 다시 추가하십시오. composer.json composer update 이제 우리는

메소드를 확장해야합니다
composer create-project laravel/laravel your-project-name --prefer-dist
이 부분이 실제로 무엇을하는지 보자. 첫 번째 줄은 이메일에서 첨부 파일을 검색합니다. 변수는 부착 객체의 배열입니다. 다음으로 서버에서 파일 저장을 처리 할 새 파일 시스템 객체를 작성해야합니다. 그런 다음 모든 첨부 파일을 반복하기 시작합니다. 파일 시스템 객체의

메소드를 호출하여 파일의 경로와 내용을 수락합니다. 이 경우 파일을 $attachments 디렉토리에 추가하고 첨부 파일 이름을 사용하려고합니다. 두 번째 매개 변수는 실제 파일의 내용입니다. put 그게 다야! 파일은 이제 public/uploads에 저장됩니다. 올바른 권한을 설정하여 메일 서버가 실제로이 디렉토리에 파일을 추가 할 수 있는지 확인하십시오.

메일 서버를 구성

public/uploads 지금까지, 우리는 전체 앱을 검색, 분할 및 저장할 수 있도록 준비했습니다. 그러나 실제로 새로 생성 된 Artisan Command에 이메일을 실제로 보내는 방법을 모르는 경우이 코드는 쓸모가 없습니다.

아래에 사용중인 도구 또는 메일 서버에 따라 애플리케이션에 이메일을 제공하는 다양한 방법을 찾을 수 있습니다. 예를 들어,

에있는 에 전달하고 싶습니다. 실제 명령에서 아래에서 볼 수있는 실제 명령에서는 Artisan이 개발 기계에서 수행하는 것처럼 를 추가했습니다. 생산 환경에있는 경우이 섹션을 삭제할 수 있습니다.

cpanel CPANEL을 사용하는 경우 일반 메뉴에서 전달자를 클릭 할 수 있습니다. 새 전달자를 추가하고 응용 프로그램으로 전달하려는 주소를 정의하십시오. 고급 설정을 클릭하고 프로그램 옵션 옵션을 선택하십시오. 입력 필드에서 다음 줄을 삽입 할 수 있습니다.

CPANEL은 홈 디렉토리와 관련된 경로를 사용합니다.

exim support@peternijssen.nl exim에서 파일을 엽니 다. 이 파일에 다음 줄이 있는지 확인하십시오 : /var/www/supportcenter --env=local

run alias 데이터베이스를 재구성하려면.

postfix PostFix에서 계속되기 전에 다음 줄이 파일에 존재하고 댓글이 없는지 확인하십시오.

파일을 변경 해야하는 경우 를 실행하여 PostFix를 다시로드하십시오.

이제 우리는 응용 프로그램에 전달 될 새로운 별칭을 만들 수 있습니다. 를 열고 다음 줄을 추가하십시오 :

php artisan command:make EmailParserCommand
run alias 데이터베이스를 재구성하려면.

sendmail sendmail을 사용하면 먼저 파일에서 별칭을 만들어야합니다.

run alias 데이터베이스를 재구성하려면. 다음으로, 장인 파일의 CHMOD가 실행될 수 있도록 755인지 확인하십시오.

마지막으로 Artisan 파일을 Symlink하고 php 자체는

입니다. /etc/smrsh qmail 설치에 따라 다음 파일이 있는지 확인해야합니다.

composer create-project laravel/laravel your-project-name --prefer-dist
또는 :

모든 파일을 열고 다음 줄을 내용으로 추가하십시오.

결론

사용 가능한 명령 줄 도구가 포함 된 모든 프레임 워크에서는 이메일을 처리 할 수 ​​있습니다. 여기에 제공된 코드는 기본 설정 일뿐입니다. 프로젝트에 따라 특정 이메일 주소가 앱에 이메일을 보내도록 허용 할 수 있습니다. 응용 프로그램에 전달하기 전에 PostFix와 같은 도구로 이메일을 필터링했는지 확인하십시오.
php artisan command:make EmailParserCommand
어떤 종류의 발권 시스템을 사용하려면 이메일 주제에서 지원 티켓 ID를 쉽게 추출하고 해당 ID를 기반으로 이메일에서 여러 가지 다른 작업을 수행 할 수 있습니다.

메일 서버의 로그 파일에주의하십시오. 실제 파이프 라인이 해결 방법에 실패하면 몇 가지 팁을 제공합니다.

/**
 * 控制台命令名称。
 *
 * @var string
 */
protected $name = 'email:parse';

/**
 * 控制台命令描述。
 *
 * @var string
 */
protected $description = '解析传入的电子邮件。';
(공간 제한으로 인해 FAQ의 일부는 생략됩니다. 원래 FAQ 내용은 기사의 주제와 약하게 관련되어 있으며 일부 내용은 기사의 내용과 복제되므로 의사는 없습니다. -원천 처리가 수행됩니다.)

위 내용은 Laravel 애플리케이션에 전자 메일을 배관합니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP는 사용자 세션을 어떻게 식별합니까?PHP는 사용자 세션을 어떻게 식별합니까?May 01, 2025 am 12:23 AM

phpidifiesauser의 sssessionusessessioncookiesandssessionids.1) whensession_start () iscalled, phpgeneratesauniquessessionStoredInacookienamedPhpsSessIdonSeuser 'sbrowser.2) thisidallowsphptoretrievessessionDataTromServer.

PHP 세션을 확보하기위한 모범 사례는 무엇입니까?PHP 세션을 확보하기위한 모범 사례는 무엇입니까?May 01, 2025 am 12:22 AM

PHP 세션의 보안은 다음 측정을 통해 달성 할 수 있습니다. 1. Session_REGENEREAT_ID ()를 사용하여 사용자가 로그인하거나 중요한 작업 일 때 세션 ID를 재생합니다. 2. HTTPS 프로토콜을 통해 전송 세션 ID를 암호화합니다. 3. 세션 _save_path ()를 사용하여 세션 데이터를 저장하고 권한을 올바르게 설정할 보안 디렉토리를 지정하십시오.

PHP 세션 파일은 기본적으로 어디에 저장됩니까?PHP 세션 파일은 기본적으로 어디에 저장됩니까?May 01, 2025 am 12:15 AM

phpsessionfilesarestoredInTheRectorySpecifiedBysession.save_path, 일반적으로/tmponunix-likesystemsorc : \ windows \ temponwindows.tocustomizethis : 1) austession_save_path () toSetacustomDirectory, verlyTeCustory-swritation;

PHP 세션에서 데이터를 어떻게 검색합니까?PHP 세션에서 데이터를 어떻게 검색합니까?May 01, 2025 am 12:11 AM

toretrievedatafromAphPsession, startSessionstart_start () andaccessvariblesinthe $ _sessionArray.forexample : 1) startthessession : session_start (). 2) retrievedata : $ _ session [ 'username']; echo "Welcome,". $ username;

세션을 사용하여 쇼핑 카트를 구현할 수있는 방법은 무엇입니까?세션을 사용하여 쇼핑 카트를 구현할 수있는 방법은 무엇입니까?May 01, 2025 am 12:10 AM

세션을 사용하여 효율적인 쇼핑 카트 시스템을 구축하는 단계에는 다음이 포함됩니다. 1) 세션의 정의와 기능을 이해합니다. 세션은 요청에 따라 사용자 상태를 유지하는 데 사용되는 서버 측 스토리지 메커니즘입니다. 2) 쇼핑 카트에 제품 추가와 같은 기본 세션 관리를 구현합니다. 3) 제품 수량 관리 및 삭제 지원 고급 사용으로 확장; 4) 세션 데이터를 지속하고 보안 세션 식별자를 사용하여 성능 및 보안을 최적화합니다.

PHP에서 인터페이스를 어떻게 생성하고 사용합니까?PHP에서 인터페이스를 어떻게 생성하고 사용합니까?Apr 30, 2025 pm 03:40 PM

이 기사는 PHP의 인터페이스를 생성, 구현 및 사용하는 방법을 설명하여 코드 구성 및 유지 관리에 대한 이점에 중점을 둡니다.

crypt ()와 password_hash ()의 차이점은 무엇입니까?crypt ()와 password_hash ()의 차이점은 무엇입니까?Apr 30, 2025 pm 03:39 PM

이 기사에서는 PHP의 암호 해싱에 대한 Crypt ()와 Password_hash ()의 차이점에 대해 논의하여 최신 웹 애플리케이션에 대한 구현, 보안 및 적합성에 중점을 둡니다.

PHP의 크로스 사이트 스크립팅 (XSS)을 어떻게 방지 할 수 있습니까?PHP의 크로스 사이트 스크립팅 (XSS)을 어떻게 방지 할 수 있습니까?Apr 30, 2025 pm 03:38 PM

기사는 입력 유효성 검사, 출력 인코딩 및 OWASP ESAPI 및 HTML 청정기와 같은 도구를 통해 PHP의 크로스 사이트 스크립팅 (XSS) 방지에 대해 논의합니다.

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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.