PHP는 Yandex smtp를 통해 메일을 보냅니다. 로컬 서버에서 SMTP를 통해 메일 보내기

/ 프로그램 설치

PHPMailer는 매우 편리하고 인기 있는 라이브러리입니다. 이메일 보내기귀하의 사이트에서 보낸 메시지. 이 문서에서는 라이브러리의 기본 설정을 설명하고 메시지 전송을 위한 코드 예제를 제공합니다. PHPMailer에는 메일 작업에 필요한 모든 기능이 포함되어 있습니다. 다른 방법으로, 다음을 포함한 다양한 서버를 통해 smtp를 통해 편지를 암호화하고 서명하여 스팸으로 분류되지 않도록 하는 기능 등이 있습니다.

https://github.com/PHPMailer/PHPMailer("복제 또는 다운로드" 버튼)에서 PHPMailer 라이브러리를 다운로드할 수 있습니다.

먼저 몇 가지를 살펴보겠습니다. 간단한 예 PHPMailer를 사용하여 이메일을 보내는 방법을 명확하게 합니다.

PHPMailer를 사용하여 mail() 함수를 통해 이메일 보내기

호스팅에서 이메일을 보내려면 메일 서버, 모든 것이 매우 간단하며 다음과 같이 보일 것입니다.

// PHPMailer 라이브러리를 포함합니다. PHPMailer\PHPMailer\PHPMailer를 사용합니다. "PHPMailer/PHPMailer.php"가 필요합니다. // 편지 만들기 $mail = new PHPMailer(); $mail->setFrom(" [이메일 보호됨]", "Ivan Ivanov"); // 보낸 사람 (이메일 및 이름) $mail->addAddress(" [이메일 보호됨]", "Vasya Petrov"); // 받는 사람 (이메일 및 이름) $mail->Subject = "Test"; // 편지 제목 // HTML 텍스트편지 $mail->msgHTML("

안녕하세요!

이것은 테스트 편지입니다.

"); // 보내기 if ($mail->send()) ( echo "메시지가 전송되었습니다!"; ) else ( echo "오류: " . $mail->ErrorInfo; )

보시다시피 모든 것이 매우 간단합니다. 도서관을 연결하고 누구에게, 누구에게 편지의 제목과 텍스트를 입력하여 보냅니다. 이 방법으로 이메일을 보내는 것은 도메인의 이메일 주소에서만 작동합니다(다른 메일러에 연결되지 않은 경우).

Yandex 및 Google의 예를 사용하여 PHPMailer를 사용하여 SMTP를 통해 이메일 보내기

예를 들어 다음과 같은 다른 우편물을 통해 편지를 보낼 수도 있습니다. 얀덱스. 코드는 다음과 같습니다.

// PHPMailer 라이브러리를 포함합니다. PHPMailer\PHPMailer\PHPMailer를 사용합니다. PHPMailer\PHPMailer\SMTP를 사용하십시오. "PHPMailer/PHPMailer.php"가 필요합니다. "PHPMailer/SMTP.php"가 필요합니다. // 편지 만들기 $mail = new PHPMailer(); $mail->isSMTP(); // SMTP를 통해 보내기 $mail->Host = "smtp.yandex.ru"; // SMTP 서버 주소 $mail->SMTPAuth = true; // SMTP 인증 활성화 $mail->Username = "login"; // 사용자 이름(도메인 및 @ 제외) $mail->Password = "password"; // 비밀번호 $mail->SMTPSecure = "ssl"; // SSL 암호화 $mail->Port = 465; // 연결 포트 $mail->setFrom(" [이메일 보호됨]", "Ivan Ivanov"); // 보낸 사람 $mail->addAddress(" [이메일 보호됨]", "Vasya Petrov"); // $mail->Subject = "Test"; $mail->msgHTML("

안녕하세요!

이것은 테스트 편지입니다.

"); // 보내기 if ($mail->send()) ( echo "메시지가 전송되었습니다!"; ) else ( echo "오류: " . $mail->ErrorInfo; )

Google을 통해 이메일 보내기한 가지 주의사항이 있습니다. 구글 계정 신뢰할 수 없는 애플리케이션에 대한 액세스 허용. 이렇게 하려면 https://myaccount.google.com 계정에 로그인하고 보안으로 이동한 후 '계정에 액세스할 수 있는 신뢰할 수 없는 애플리케이션' 섹션으로 이동하여 '허용됨'으로 전환해야 합니다. 글을 쓰는 시점에서 이 페이지는 https://myaccount.google.com/u/0/lesssecureapps입니다.

$mail->호스트 = "smtp.gmail.com"; // SMTP 서버 주소 $mail->SMTPAuth = true; // SMTP 인증 활성화 $mail->Username = "login"; // 사용자 이름 $mail->Password = "password"; // 비밀번호 $mail->SMTPSecure = "ssl"; // SSL 암호화 $mail->Port = 465; // 연결 포트

smtp로 보내기 프로그램을 처음 실행하는 경우에는 보내기 전에 추가로 사용하는 것이 좋습니다. $mail->SMTPDebug = 1;클라이언트와 smtp 서버로부터 모든 메시지를 수신합니다. 즉, 연결, 인증 등의 전체 프로세스가 화면에 표시되므로 프로그램 디버깅에 매우 유용합니다.

PHPMailer를 사용하여 첨부 파일이 포함된 이메일 보내기

여기에서는 모든 것이 매우 간단합니다. 방법을 사용하면됩니다. 첨부파일 추가. 예를 들면서 동시에 몇 가지를 더 보여 드리겠습니다. 추가 기능:

// PHPMailer 라이브러리를 포함합니다. PHPMailer\PHPMailer\PHPMailer를 사용합니다. PHPMailer\PHPMailer\Exception을 사용하십시오. "PHPMailer/PHPMailer.php"가 필요합니다. "PHPMailer/Exception.php"가 필요합니다. // 편지 만들기 $mail = new PHPMailer; $mail->CharSet = "UTF-8"; $mail->setFrom(" [이메일 보호됨]", "Ivan Ivanov"); // 보낸 사람 $mail->addReplyTo(" [이메일 보호됨]", "Ivan Ivanov"); // 반환 주소 $mail->addAddress(" [이메일 보호됨]", "Vasya Petrov"); // 받는 사람 $mail->Subject = "Test"; // 제목 $mail->msgHTML(file_get_contents("contents.html"), __DIR__); // "body" 가져오기 파일의 문자 $mail->AltBody = "Plain text letter"; // 클라이언트가 html을 지원하지 않는 경우 일반 텍스트 문자 $mail->addAttachment("my_file.txt") // 하나의 파일 첨부 $mail- >addAttachment("phpmailer) .jpg"); // 두 번째 파일 첨부 // Send if ($mail->send()) ( echo "Message sent!"; ) else ( echo "Error: " . $mail- >오류정보 )

addAddress를 사용하여 여러 수신자 주소를 추가할 수 있습니다. 또는 필요한 경우 다음 방법을 사용하여 모든 수신자 주소를 지울 수도 있습니다. 클리어주소(). 다음을 사용하여 모든 첨부 파일을 지울 수 있습니다. 클리어어태치먼트().

당신은 또한 사용할 수 있습니다 내장된 이미지 추가 HTML 코드에 사용하기 위한 첨부 파일(일반적으로 이미지)을 이메일에 추가하려면 다운로드할 수 없습니다. 다운로드할 수 없는 편지에 그림을 사용하는 예:

// PHPMailer 라이브러리를 포함합니다. PHPMailer\PHPMailer\PHPMailer를 사용합니다. "PHPMailer/PHPMailer.php"가 필요합니다. //편지 만들기 $mail = new PHPMailer; $mail->IsHTML(true); $mail->setFrom(" [이메일 보호됨]", "이반 이바노프"); $mail->addAddress(" [이메일 보호됨]", "Vasya Petrov"); $mail->Subject = "Test"; $mail->AddEmbeddedImage("phpmailer.jpg","testImage"); $mail->Body = "

HTML 코드의 이미지

"; // $mail 보내기->send();

그래서 보낼 수 있습니다 이미지가 있는 편지, 편지 본문에만 있고 첨부 파일로 다운로드 할 수 없습니다. 이러한 이미지는 편지의 HTML 코드 어디에서나 사용할 수 있으며, URL 주소 대신 AddEmbeddedImage에서 사용한 이미지 cid를 지정하기만 하면 됩니다.

PHPMailer를 통해 서명되고 암호화된 이메일 보내기

기본적으로 PHPMailer는 보낸 모든 메시지를 암호화합니다. 다음 코드를 사용하여 SMTP를 통해 이메일을 보낼 때만 이메일 암호화를 비활성화할 수 있습니다.

$mail->SMTPSecure = 거짓; $mail->SMTPAutoTLS = 거짓;

에게 DKIM 서명으로 편지에 서명하세요, 여러 단계를 수행해야 합니다.

  • 도메인에 대한 개인 및 공개 키 생성
  • 공개 키를 사용하여 TXT 도메인에 대한 DNS 레코드 추가
  • 이메일을 보내기 전에 PHPMailer에서 DKIM 서명을 구성하세요.

이제 각 단계에 대해 좀 더 자세히 설명하겠습니다.

개인 및 공개 키 생성

Linux 호스팅이 있고 Shell에 액세스할 수 있는 경우 키 파일을 생성하는 것은 일반 사용자 권한으로 2개의 명령만 실행하면 됩니다.

Openssl genrsa -out test-private.pem 1024 openssl rsa -in test-private.pem -out test-public.pem -pubout

각기, 테스트-private.pem그리고 test-public.pem- 개인 키와 공개 키입니다. 사이트 방문자나 귀하를 제외한 다른 사람이 접근할 수 없는 폴더에 저장해야 합니다.

셸에서 명령을 실행할 수 없는 경우 개인 및 공개 키를 생성하여 파일에 저장하려면 다음 코드를 사용할 수 있습니다.

$domain = "test.ru"; // 귀하의 도메인 $privatekeyfile = "test-private.pem"; // 개인키가 기록될 파일명 $publickeyfile = "test-public.pem"; // 공개 키가 기록될 파일 이름 if (file_exists($privatekeyfile)) ( echo "

기존 키 사용

"; $privatekey = file_get_contents($privatekeyfile); $publickey = file_get_contents($publickeyfile); ) else ( echo "

키 생성"; $pk = openssl_pkey_new([ "digest_alg" => "sha256", "private_key_bits" => 2048, "private_key_type" => OPENSSL_KEYTYPE_RSA, ]); openssl_pkey_export_to_file($pk, $privatekeyfile); $pubKey = openssl_pkey_get_details($pk ); $publickey = $pubKey["key"]; file_put_contents($publickeyfile, $publickey);

개인 키(비공개로 유지하세요!):

" . $privatekey . "
"; 에코 "

공개 키:

" . $공개키 ."
";

주목!파일이 저장될 폴더에 쓰기 가능한지 확인하는 것을 잊지 마세요.

공개 키를 사용하여 DNS 레코드 추가

편지를 받을 메일 서버가 도메인의 DNS 레코드를 읽어 편지의 서명을 확인할 수 있도록 하려면 DNS 레코드가 필요합니다. 일반적으로 도메인 제어판이나 호스팅 제어판에서 DNS 레코드를 추가할 수 있습니다. 항목을 추가하는 방법을 모르는 경우 호스팅 공급자의 지원에 문의하세요.

다음과 같이 DNS 레코드를 추가해야 합니다.

항목 이름: mail._domainkey.test.ru. (마지막에 점 "."이 있습니다)

TTL: 3600 (또는 기본값이 될 것임)

게시물 유형: TXT

의미: v=DKIM1; h=sha256; t=s; p=YOUR_PUBLIC_KEY

항목 이름에 test.ru도메인 이름으로 바꿔야 합니다. "YOUR_PUBLIC_KEY"라는 단어를 "-----BEGIN PUBLIC KEY-----" 및 "------END PUBLIC KEY- 없이 "공개 키" 다음 이전 단계에서 받은 텍스트로 바꿉니다. -- --", 키 자체만 해당됩니다. 이 경우 키의 모든 라인이 필요합니다 하나의 긴 줄로 연결줄 바꿈이 없도록 합니다.

PHPMailer에서 DKIM 서명 설정 및 이메일 보내기

이제 남은 것은 편지를 보내기 전에 몇 가지 PHPMailer 설정을 지정하는 것뿐입니다. 그러면 편지가 서명됩니다. 다음 예를 보면 모든 것이 명확해질 것이라고 생각합니다.

// 라이브러리를 포함합니다. PHPMailer\PHPMailer\PHPMailer를 사용합니다. "PHPMailer/PHPMailer.php"가 필요합니다. // 편지 만들기 $mail = new PHPMailer; $mail->CharSet = "UTF-8"; $mail->setFrom(" [이메일 보호됨]"); $mail->addAddress(" [이메일 보호됨]"); $mail->Subject = "테스트입니다"; $mail->msgHTML("

이것은 테스트입니다

"); // DKIM 서명 설정 $mail->DKIM_domain = "test.ru"; $mail->DKIM_private = "test-private.pem"; $mail->DKIM_selector = "mail"; // $ 보내기 메일->send();

물론 test.ru도메인 이름으로 변경해야 하며, 테스트-private.pem키 생성 단계에서 생성된 개인 키 파일의 전체 경로와 이름입니다.

이제 PHPMailer를 통해 전송된 이메일은 개인 키로 DKIM 서명됩니다.

특정 웹 사이트가 효율적이고 생산적으로 작동할 수 있는 기회를 가지려면 가능한 한 책임감 있고 신중하게 웹 사이트 생성에 접근해야 합니다. 온라인 상점을 만드는 데 사용할 시스템 선택에는 특별한 주의가 필요합니다. 사실 상품이나 서비스 판매를 전문으로 하는 상업 플랫폼은 사이트 유지 관리 및 채우기에 관련된 관리자와 온라인 상점 고객 모두에게 필요한 모든 기능을 구현하고 사용하기 쉬워야 합니다. 자신에게 적합한 CMS를 선택해야 하는 문제에 직면한 많은 사람과 회사는 Magento를 선택할지, OkkaCMS를 선택할지 분석합니다. 이러한 웹사이트 엔진의 특징과 성능을 비교해 보겠습니다.

자신의 웹사이트를 만들 때 개인이나 회사는 많은 노력을 기울여야 합니다. 이 경우에만 믿을 수 있습니다. 긍정적인 결과정말 효과적인 도구를 얻는 것입니다. 웹사이트 제작을 시작하기 전에 먼저 해결해야 할 근본적인 질문 중 하나는 가장 적합한 CMS 옵션을 어떻게 결정하느냐 하는 것입니다. 다음으로 두 가지 CMS인 Joomla와okayCMS를 비교하고 각각의 기능에 주목하겠습니다.

자신만의 웹사이트를 갖는 것은 효과적이고 성공적으로 운영되는 비즈니스를 위한 기본 요구 사항 중 하나입니다. 통계에 따르면 인터넷을 통한 다양한 상품 구매 및 서비스 주문 수가 증가한 것으로 나타났습니다. 이를 고려하여 대부분의 상업 회사는 이미 자체 웹 사이트의 필요성을 인식하고 있습니다. 그러나 인터넷 리소스를 보유하고 있다는 단순한 사실만으로는 그 효율성, 수익성 및 기대되는 비즈니스 이점을 기대하기에 충분하지 않습니다.

자신만의 웹사이트를 만들거나 온라인 상점을 오픈하려고 준비할 때, 많은 문제를 고려하고 분석하고 다양한 문제를 해결해야 합니다. 이 경우에만 귀하의 프로젝트가 긍정적인 결과를 가져오고 귀하의 기대를 완전히 충족시킬 수 있다는 사실을 믿을 수 있습니다. 온라인 상점 개발과 관련된 다양한 문제 중 CMS 선택 문제는 특히 주목할 만합니다. 귀하가 최적의 엔진을 스스로 쉽게 결정할 수 있도록

미래의 온라인 상점을 위한 자체 웹 사이트를 만들 계획을 세울 때 상당히 많은 수의 사람들과 심지어 판매 전문 회사조차도 기존 CMS 중 무엇을 선택할 것인지 어렵고 매우 중요한 선택에 직면합니다. 무엇을 선택할지 고민 중이라면 PrestaShop 또는 OKCMS를 읽어 보시기 바랍니다. 여기서는 인터넷 사이트, 특히 온라인 상점을 만들기 위한 두 시스템을 비교할 것입니다.

2019-08-05

안녕하세요, 방문객 여러분!

블로그 업데이트가 늦어진 점 양해 부탁드립니다. 그러나 이에 대한 완전히 이해 가능한 설명이 있습니다. 결국 여름, 다차, 손님, 숲, 물 등이 있었기 때문에 웹 사이트를 만드는 문제를 해결할 수 없었습니다. 그런데 이제 좀 여유가 생겼고, 손님들도 떠났고, 이제는 확실히 이것에 주의를 기울일 수 있을 것 같아요.

따라서 지난 기사에서 우리 도메인의 메일을 메일 서비스 중 하나에 연결한 후 이제 사이트에서 이메일을 보내는 방법을 살펴보겠습니다. 더욱이, 우리의 편지가 SPAM으로 끝나지 않고 높은 확률로 수신자에게 안정적으로 전달되는 방식으로 말입니다.

일반적으로 PHP에는 편지를 보내는 mail() 함수가 내장되어 있습니다. 그러나 이 방법의 단순성에도 불구하고(이 경우 문자를 보내려면 특정 매개 변수를 사용하여 한 줄의 코드만 지정하면 충분함) 이 옵션을 사용하면 SPAM 문제와 관련된 심각한 단점이 있습니다. .

사실 수신자 측 메일 서버의 스팸 방지 필터는 실제로 mail() 기능을 통해 전송된 편지를 선호하지 않습니다. 그리고 대부분의 경우 이러한 메시지는 수취인에게 도달하기 전에 필터링되거나 삭제되기도 합니다.

그리고 이러한 경우를 최대한 없애기 위해 일반적으로 타사 메일 서비스에서 보낸 것처럼 편지를 보내는 또 다른 옵션이 사용됩니다.

이 방법을 인증을 통해 SMTP를 통해 메일을 보내는 것입니다. 오늘은 양식 제출의 예를 사용하여 살펴보겠습니다. 피드백. 또한 이를 위해 꽤 유명하고 인기 있는 PHPMailer 라이브러리를 사용하여 SMTP를 통해 보내는 편지를 매우 간단하게 구성할 수 있습니다.

  • 피드백 편지를 보내는 방법
  • 피드백 양식 만들기
  • PHPMailer 라이브러리 설치
  • SMTP를 통해 메일을 보내기 위한 스크립트를 만듭니다.
  • 이메일 발송 확인 중
  • 소스 파일대지

피드백 편지를 보내는 방법

시작하기 전에 실무피드백 편지를 보낸 후 먼저 어떻게 할지 결정하겠습니다.

피드백 양식은 사용자가 사이트 관리자와 소통하고 메시지를 전달할 수 있도록 설계되었습니다. 일반적으로 이 양식은 여러 필드와 "제출" 버튼으로 구성됩니다.

원칙적으로 이메일을 보내려면 다음과 같이 사용자 및 메시지 내용에 대한 충분한 정보를 제공하는 몇 가지 필드만 사용하면 충분합니다.

  • "이름" - 메시지 보낸 사람의 이름을 입력합니다.
  • "이메일" - 주소용 이메일보내는 사람;
  • "메시지 제목";
  • "메시지 텍스트".

다른 사람을 추가할 수도 있지만. 예를 들어 전화번호(정말 필요한 경우)입니다.

우리의 경우 이러한 편지는 도메인이 연결된 메일 서비스에 대한 승인을 받아 실제 사서함에서 사이트 관리자의 주소로 전송됩니다.

이전 기사에서는 도메인 메일과 Yandex.Mail 서비스의 연결을 확인하는 데 중점을 두었으므로 이 옵션에 대한 메일을 보내겠습니다. 이것은 중요하지 않지만. 아래에는 변경 시 Mail.ru 메일 서버를 통해 이메일을 보낼 수 있는 옵션이 표시됩니다.

편지가 전송되는 실제 사서함으로 새로 생성된 도메인 메일 사용자의 계정을 주소와 함께 사용합니다. [이메일 보호됨]. 그리고 우리는 이 편지를 다음에게 보낼 것입니다. 사서함관리자 [이메일 보호됨], 이전 기사에서 이전에 만든 것입니다.

따라서 피드백 양식의 편지를 보낸 사람이 사서함이 됩니다. [이메일 보호됨]., 그리고 수신자 - [이메일 보호됨]. 이 경우, 메시지를 보낸 사용자에 대한 모든 정보와 그 내용이 보낸 편지의 본문에 포함되어 전송됩니다.

피드백 양식 만들기

편지를 보내는 절차를 결정한 후에는 이를 수행할 피드백 양식을 작성하겠습니다.

다음은 "연락처" 페이지(기사 디렉토리의 kontakty.php 파일)에 배치할 이 양식의 HTML 코드입니다.

    "기사" >

    콘택트 렌즈

    피드백

    "연락하다"행동 = "#" 방법 = "우편" >

    피드백 양식

    모든 질문, 요청, 사업 제안에 대해서는 아래 피드백 양식을 통해 문의하실 수 있습니다.

    "접촉 블록" >

    "연락처 입력" >

    "텍스트"아이디 = "연락처 이름"이름 = "연락처 이름"제목 = "이름은 러시아어로 되어 있어야 하며 3자 이상이어야 합니다." 패턴 = "{3,}" 필수 >

  1. "빈 접촉" >

    "연락처 입력" >

    "이메일"아이디 = "연락처 이메일"이름 = "연락처 이메일"필수 >

  2. "연락처 제목" >

  3. "연락처-댓글" >

  4. "연락처 버튼" >

    "제출하다"이름 = "연락처 버튼"값 = "보내다" >

Fig.1 피드백 양식의 HTML 코드

여기에 표시된 피드백 양식이 다음 스크린샷에서 최종적으로 어떻게 보이는지 확인할 수 있습니다.

따라서 원하는 형태가 생성됩니다. 이제 이메일 메시지 형식으로 데이터를 처리하고 전송하는 문제로 넘어갈 수 있습니다.

PHPMailer 라이브러리 설치

이전에 언급한 대로 메일을 보내기 위해 PHPMailer 라이브러리를 사용합니다. 이는 PHPMailer 라이브러리를 통해 이메일 보내기를 크게 단순화합니다. SMTP 프로토콜제3자 메일 서비스에 대한 승인을 받아.

설치하려면 다운로드가 필요합니다 필요한 파일. 이는 Composer(PHP용 패키지 종속성 관리자)를 사용하여 GitHub 웹 서비스에서 수행할 수 있습니다. 아니면 일반적인 방법으로 필요한 파일을 다운로드하면 됩니다.

스크린샷 73

아래는 PHPMailer 라이브러리의 일반 다운로드 링크가 표시된 GitHub 웹 서비스 페이지입니다.

이 외에도 최신 버전본 글 작성 당시 저장되어 있던 6.0.7은 첨부된 자료에서 다운로드 받으실 수 있습니다.

어떤 경우든 결과 아카이브 파일의 압축을 풀어야 하며, 그 후에 모든 내용이 포함된 추출된 PHPMailer-master 폴더를 사이트 루트에 배치해야 합니다. 동시에 단순화를 위해 이름을 PHPMailer로 바꿀 수 있습니다. 아래는 사이트의 루트 디렉터리에 있는 PHPMailer 폴더의 내용입니다.

따라서 우리는 PHPMailer 라이브러리를 설치했습니다. 그런 다음 웹사이트에서 이메일 메시지를 보내는 데 사용할 스크립트 작성을 시작할 수 있습니다.

SMTP를 통해 메일을 보내기 위한 스크립트를 만듭니다.

스크립트를 작성하려면 이전에 라이브러리를 다운로드하는 데 사용했던 GitHub 페이지에 제공된 PHPMailer 사용에 대한 권장 사항을 사용하면 충분합니다.

특히 스크립트 시작 부분에서 PHPMailer 클래스를 전역 네임스페이스로 가져와야 함을 나타냅니다. 그리고 해당 코드의 특정 줄이 제공됩니다. SMTP를 통해 메일을 보내는 옵션을 포함하여 PHPMailer의 속성과 메서드를 사용하는 예도 있습니다.

하지만 이것이 충분하지 않다면 이 라이브러리의 모든 속성과 메서드에 대한 설명이 포함된 설명서를 사용할 수도 있습니다.

스크린샷 74

아래는 승인을 받아 SMTP를 통해 피드백 양식의 메일을 보내기 위한 스크립트 코드입니다. PHPMailer와 관련된 모든 라인에 대한 설명이 제공되고 밝은 배경으로 강조 표시됩니다.

이전에 다른 프로세서에서 사용해야 했던 양식의 데이터 수신 및 처리와 관련된 조각을 포함한 나머지 부분은 어두운 배경으로 표시됩니다. 이는 PHP의 양식에서 데이터를 얻고 확인하는 문제를 구체적으로 다룬 기사의 앞부분에서 자세히 논의되었습니다. 양식 데이터의 유효성을 검사하고 처리하기 위한 범용 사용자 기능에 대해서도 이야기했습니다. check_symbol().

이 스크립트를 이전에 피드백 양식을 생성했던 것과 동일한 kontakty.php 파일에 배치하겠습니다.

    //----PHPMailer를 사용하여 SMTP를 통해 메일을 보내는 스크립트----

    //PHPMailer 클래스를 전역 네임스페이스로 가져옵니다. 함수 내부가 아닌 스크립트 상단에 있어야 합니다.

    사용 PHPMailer\PHPMailer\PHPMailer ;

    사용 PHPMailer\PHPMailer\Exception ;

    만약에 (!비어 있는($_POST["연락처 버튼" ])) (

    $name = $_POST["연락처 이름" ];

    $name = check_symbol ($name, "이름" , "1" , "/^+\z/iu" );

    $email = $_POST["연락처-이메일" ];

    $email = check_symbol ($email, "이메일" , "1" , "/^+@(+\.)+(2,6)\z/i");

    $subject = $_POST["연락처-제목" ];

    $subject = check_symbol ($subject, "메시지 제목" , "1" , "0" );

    $comment = $_POST["연락처-댓글" ];

    $comment = check_symbol($comment, "메시지 텍스트", "1" , "0" );

    만약에 (!비어 있는($GLOBALS["경고" ])) (

    $경고 = "양식 데이터가 전송되지 않았습니다. 다음 오류가 발견되었습니다:\n".$경고;

    포함하다"경고.php" ;

    또 다른 {

    //라이브러리 연결

    필요하다"PHPMailer/src/PHPMailer.php" ;

    필요하다"PHPMailer/src/Exception.php" ;

    필요하다"PHPMailer/src/SMTP.php" ;

    $메일 = 새로운 PHP메일러(); //클래스 초기화

    $에서 = " [이메일 보호됨]" ; //편지를 보낸 이메일 주소

    $에 = " [이메일 보호됨]" ; //받는 사람의 주소

    $mail -> isSMTP(); //SMTP 프로토콜 사용

    $mail -> 호스트 = "smtp.yandex.ru" ; //메일서버 주소

    $mail -> SMTPAuth = 진실 ; //인증 모드 활성화

    $mail -> 사용자 이름 = " [이메일 보호됨]" ; //타사 이메일 서비스(이 경우 Yandex.Mail)에 연결된 도메인 이메일에서 로그인

    $mail -> 비밀번호 = "27MrDon89" ; //도메인 메일 비밀번호

    $mail -> SMTPSecure = "ssl" ; //암호화 프로토콜

    $mail -> 포트 = "465" ; //SMTP 서버 포트

    $mail -> CharSet = "UTF-8" ; //부호화

    $mail -> setFrom ($from, "관리자" ); //보내는 사람의 주소와 이름

    $mail -> addAddress ($to, "관리자" ); //받는 사람의 주소와 이름

    $mail -> isHTML( 진실 ); //이메일 형식을 HTML로 설정

    $mail -> 제목 = '의견 양식이 제출되었습니다.'; //이메일 제목(heading)

    $mail -> 본문 = "

    보낸 사람 이름: $name

    보내는 사람의 주소: $이메일

    메시지 제목: $주제

    메시지 내용: $댓글

    " ; //메시지 내용

    $mail -> AltBody = "대체 문자 텍스트"; //이메일 클라이언트가 HTML 형식을 지원하지 않는 경우 대체 이메일

    $mail -> SMTPDebug = 0 ; //SMTP 디버깅 활성화: 0 - 꺼짐(일반 사용의 경우), 1 = 클라이언트 메시지, 2 - 클라이언트 및 서버 메시지

    만약에($mail -> 보내기()) (

    $경고 = "메시지가 전송되었습니다"; //성공적인 편지 전송에 대한 메시지를 브라우저 대화 상자에 출력합니다.

    또 다른 {

    $경고 = "오류, 이메일을 보낼 수 없습니다: ".$mail -> 오류정보 ; //오류 메시지 출력

    포함하다"경고.php" ;

그림 5 인증을 통해 SMTP를 통해 이메일을 보내는 스크립트

보시다시피, 필요한 방법과 속성이 지정된 전자 메일 메시지 보내기와 직접 관련된 모든 줄에는 주석이 함께 제공됩니다. 따라서 반복하는 것은 의미가 없지만 실제로 추가 설명이 필요한 일부에만 머물 수 있습니다. 즉:

1. 편지가 타사 메일 서비스에서 전송된다는 사실로 인해 특정 SMTP 서버에 해당하는 설정이 여기에 적용됩니다. 이 경우 Yandex.Mail 서버 사용 사례의 경우 다음 속성 값이 적용됩니다.

  • 재산 주인(pos.28) - 값이 smtp.yandex.ru인 메일 서버 주소;
  • 재산 SMTP보안
  • 재산 포트

이러한 속성 값은 다음 스크린샷에 표시된 Yandex.Help 페이지에서 가져왔습니다.

그러나 그러한 정보는 다른 리소스에서도 얻을 수 있습니다. 이렇게 하려면 검색 엔진에 "Yandex smtp 서버"와 같은 적절한 쿼리를 입력하기만 하면 됩니다. 이 문제에 대한 많은 참고 자료를 어디에서 찾을 수 있습니까?

비슷한 방법으로 다른 SMTP 서버에서도 설정 값을 얻을 수 있습니다. 다음은 Mail.ru 메일 서비스의 SMTP 서버 설정을 표시하는 Mail.ru 도움말 페이지의 스크린샷입니다.

따라서 Mail.ru를 타사 SMTP 서버로 사용하는 경우 PHPMailer 클래스 속성의 다음 값을 적용해야 합니다.

  • 재산 주인(pos.28) - 메일 서버 주소 (smtp.mail.ru);
  • 재산 SMTP보안(pos.32) - 암호화 프로토콜(ssl);
  • 재산 포트(위치 33) - SMTP 서버 포트(465).

다른 이메일 서비스에도 유사한 접근 방식을 적용해야 합니다.

2. 부동산 내 사용자 이름(pos. 30) 도메인 메일함의 전체 주소를 표시해야 합니다. 이 경우 " [이메일 보호됨]".

다만, 편지발송을 위해 도메인 메일 계정이 아닌 계정을 사용하되, 메일 서비스와 직접적으로 관련된 주소를 사용하는 경우에는 " [이메일 보호됨]"인 경우 로그인은 "@" 기호까지의 주소 부분이어야 합니다. 이 경우 로그인의 값은 "feedback"입니다.

3. PHPMailer는 속성을 제공합니다 SMTP디버그(pos. 50), 이를 통해 브라우저 화면에 다양한 수준의 오류를 표시할 수 있습니다. 이 기능은 스크립트를 디버깅할 때 문제를 찾는 것을 크게 단순화합니다.

일반적으로 일반 모드에서는 값을 0으로 설정하면 자세한 오류 정보 출력이 비활성화됩니다. 그러나 메일 전송이나 디버깅 중에 문제가 발생하는 경우 다른 값을 사용하여 오류에 대한 보다 의미 있는 정보를 표시할 수 있습니다.

이것이 실제로 어떻게 보이는지 확인하기 위해 일시적으로 설정에 일부 오류를 도입해 보겠습니다. 예를 들어, 도메인 메일 비밀번호(속성 비밀번호, 31항). 또한 오류에 대한 자세한 정보를 표시하기 위해 속성에 임시로 설정됩니다. SMTP디버그(pos.50) 값 1. 모든 것이 디버깅되고 확인되면 SMTP 디버깅 모드를 비활성화하고 1을 0으로 바꿉니다.

스크립트의 마지막 부분에서는 필요한 모든 속성과 메서드를 지정한 후 해당 메서드를 사용하여 편지를 보냅니다. 보내다()) (위치 51). 그리고 편지를 보낸다면, 그리고 방법은 보내다()대상을 위해 $mail true를 반환한 다음 브라우저 대화 상자에서 변수를 통해 $경고메일 전송 성공에 대한 메시지가 표시됩니다(52번).

어떤 이유로 메일을 보낼 수 없고 그에 따라 메서드가 true를 반환할 수 없는 경우 이 상태에는 해당 오류 메시지가 표시됩니다(위치 55).

이메일 발송 확인 중

메일을 보내기 위한 스크립트를 만든 후에는 당연히 "창의성"의 결과를 살펴봐야 합니다. 여기에서 모든 것을 고려했는데 실수는 없었나요?

이를 위해 의도한 대로 피드백 양식에서 사용자가 사이트 관리자에게 메시지를 보내도록 시도해 보겠습니다. 다음은 제출 전 필드가 채워진 피드백 양식의 스크린샷입니다.

그리고 다음은 양식을 제출한 결과입니다.

브라우저 대화 상자의 메시지를 보면 SMTP 연결 문제로 인해 편지를 보낼 수 없다는 것이 분명합니다.

하지만 이제부터 부동산은 SMTP디버그(pos. 50)에 값 1이 할당되면 발생한 오류에 대한 자세한 정보를 볼 수 있고 오류 발생 이유를 알아낼 수 있습니다.

다음 스크린샷은 연결을 시도할 때 잘못된 로그인 또는 비밀번호 사용을 의미하는 인증 오류가 감지되었음을 보여줍니다.

비밀번호 불일치(이전에는 오류에 대한 추가 정보 출력을 확인하기 위해 잘못된 비밀번호를 사용했음)를 제거한 후 메일을 다시 보내도록 시도합니다.

이번에는 모든 일이 순조롭게 진행되는 것 같았고 메일이 성공적으로 전송되었다는 메시지를 받았습니다. 분명히 도메인 메일 비밀번호에 고의로 도입된 일시적인 오류를 제외하고는 다른 실수를 저 지르지 않았습니다.

하지만 편지가 실제로 수취인에게 전달되었는지 확인하기 위해 메일에 주소를 입력해 보겠습니다. [이메일 보호됨]그리고 결과를 보세요.

보시다시피 주소에서 온 편지입니다. [이메일 보호됨], "Feedback"이라는 이름의 이메일 메시지가 사이트 관리자에게 성공적으로 전달되었습니다. 동시에 편지 본문에는 피드백 양식에서 받은 데이터를 사용하여 스크립트에서 생성한 모든 콘텐츠가 포함됩니다.

  • 보낸 사람 이름: Nikolay;
  • 보내는 사람의 주소: [이메일 보호됨];
  • 메시지 제목: 메일 발송 확인 중;
  • 메시지 내용: 테스트 메시지입니다.

이제 메일 전송을 성공적으로 확인한 후 속성을 할당하여 SMTP 디버깅 모드를 비활성화할 수 있습니다. SMTP디버그(pos.50) 값 0.

따라서 우리는 타사 메일 서버를 사용하여 인증을 받아 SMTP를 통해 메일을 보내는 도구를 만드는 작업을 완료했습니다.

예를 들어, 다음 기사에서는 등록된 사용자 계정 데이터를 복구하기 위해 확인 이메일을 보내는 방법을 살펴보겠습니다.

사이트 소스 파일

이 기사에서 업데이트된 사이트의 소스 파일은 첨부된 추가 자료에서 다운로드할 수 있습니다.

  • www 디렉토리 파일
  • MySQL 데이터베이스 테이블

PHP에서는 편지 전송 프로세스를 자동화하는 스크립트를 사용하는 것이 매우 일반적입니다. 이 기사에서는 SMTP를 통해 수신자에게 편지를 보내는 간단한 스크립트를 살펴보겠습니다. 단순 메일 전송 프로토콜 ). 이 기능으로만 제한하는 것은 너무 쉽습니다. 스크립트는 첨부 파일도 지원합니다. 즉, 편지에 pdf, txt 또는 doc 파일을 첨부할 수 있습니다.

스크립트를 설정하는 것은 매우 간단합니다. 필요한 것은 편지를 보낼 이메일에 대한 보낸 사람의 로그인과 비밀번호뿐입니다.

이 스크립트는 km_smtp_class.php 클래스와 함께 작동하며 클래스의 좋은 점은 안전한 데이터 전송을 제공하는 다양한 SSL 및 TLS 프로토콜을 지원한다는 것입니다.

스크립트 자체는 다음과 같습니다.

"smtp.mail.ru", "SMTP_port" => "25", "SMTP_email" => " [이메일 보호됨]", "SMTP_pass" => "1111111", "SMTP_type" => "null"); // 수신자 이메일 $Receiver = " [이메일 보호됨]"; // 메시지 제목 $Subject = "PHP에서 이메일 보내기"; // 메시지 텍스트(HTML) $Text = "안녕하세요!
스크립트에서 보낸 메시지 모우숀웹사이트: http://site"; // 편지 첨부 - 파일 주소 $Attachment = ""; /* $mail = new KM_Mailer(서버, 포트, 사용자, 비밀번호, 유형); */ /* 유형은 null, tls 또는 ssl일 수 있습니다. */ $mail = new KM_Mailer($SenderConfig["SMTP_server"], $SenderConfig["SMTP_port"], $SenderConfig["SMTP_email"], $SenderConfig["SMTP_pass"], $ SenderConfig[" SMTP_type"]); if($mail->isLogin) ( // 파일 첨부 if($Attachment) ($mail->addAttachment($Attachment);) // 더 많은 수신자 추가 $mail->addRecipient( " [이메일 보호됨]"); $mail->수신자 추가(" [이메일 보호됨]"); /* $mail->send(From, For, Subject, Text, Subject = 선택사항) */ $SendMail = $mail->send($SenderConfig["SMTP_email"], $Receiver, $Subject, $Text ); // 수신자 목록 지우기 $mail->clearBCC(); $mail->clearAttachments(); else ( echo "SMTP 서버에 연결하는 동안 오류가 발생했습니다."; )

스크립트 설정은 주로 $SenderConfig 배열을 기반으로 하며 여기서는 SMTP:서버, 포트, 로그인 및 이메일 비밀번호를 지정해야 합니다. 각 배열 키를 설명하겠습니다.

SMTP_server - SMTP 서버 주소(다른 이메일에 대한 개별 주소)

Mail.ru 메일: smtp.mail.ru 포트: 25, 587 및 465(SSL 암호화 사용)

Yandex 메일: smtp.yandex.ru 포트: 25, 587 465(SSL 포트)

램블러 메일: mail.rambler.ru 포트: 25, 587 465 (SSL 포트)

야후 메일: smtp.mail.yahoo.com SSL 포트: 465

(목록에 없는 smtp 서버 주소가 필요하시면 댓글로 남겨주세요)

SMTP_port - 각 smtp 서버에 대해 위에서 이미 설명했습니다.

SMTP_email - 사용자가 더 정확하겠지만 명확성을 위해 이메일을 작성했으며 이메일 주소를 표시합니다.

SMTP_pass - SMTP_email 키의 값으로 지정된 이메일의 비밀번호


SMTP_type - 기본값은 NULL입니다. 편지가 전송되는 프로토콜입니다. 프로토콜: SSL 및 TLS

$Attachment 변수(/var/patch/to/file/File.pdf)에 파일의 전체 주소를 지정하면 편지에 첨부 파일을 추가할 수 있습니다.

질문이 있으시면 아래 댓글에 적어주세요.

Windows 가상 호스팅 서버에서 익명으로 메시지를 보내는 것은 금지되어 있으므로 편지를 보내는 것은 SMTP 서버를 통해 이루어져야 하며, 이 경우 당사의 메일 시스템도 사용할 수 있습니다.

PHP를 사용하여 이메일을 보내는 방법은 무엇입니까?

smtp 서버에서 인증을 지원하는 PHP 클래스를 사용합니다. 예를 들어 PHPMailer 클래스 세트를 사용할 수 있습니다.

인증이 필요한 smtp 서버를 사용하여 편지 보내기를 구현하는 예제를 사용할 수도 있습니다. 따라서 스크립트에 적절한 액세스 세부정보를 추가하는 것을 잊지 마세요. 예:

// SMTP 세션 로그를 표시해야 하는 경우 다음 줄의 주석 처리를 제거할 수 있습니다. // $_SERVER["debug"] = true;기능 MailSmtp ($reciever, $subject, $content, $headers, $debug = 0) ( $smtp_server = "smtp.site"; // SMTP 서버 주소$smtp_port = 25 ; // SMTP 서버 포트$smtp_user = " [이메일 보호됨]" ; // SMTP 서버 인증을 위한 사용자 이름$smtp_password = "pAsSwORd" ; // SMTP 서버 인증을 위한 비밀번호$mail_from = " [이메일 보호됨]" ; // 편지가 발송된 우편함$sock = fsockopen($smtp_server, $smtp_port, $errno, $errstr, 30); $str = fgets($sock, 512);<" . $mail_from . ">if (! $sock ) ( printf ( "소켓이 생성되지 않았습니다\n" ); exit(1 ); ) smtp_msg ($sock , "HELO " . $_SERVER [ "SERVER_NAME" ]); smtp_msg($sock, "인증 로그인"); smtp_msg($sock, base64_encode($smtp_user)); smtp_msg($sock, base64_encode($smtp_password)); smtp_msg ($sock , "메일 보낸 사람:<" . $reciever . ">" ); smtp_msg ($sock , "DATA" ); $headers = "제목: " . $subject . "\r\n" . $headers ; $data = $headers . "\r\n\r\n" . $content . "\r\n." ; smtp_msg ( $sock , $data ) ( if ( ! $sock ) ( printf ("깨진 소켓!\n" ); exit(1 ); ) _SERVER [ "디버그" ]) && $_SERVER [ "디버그" ]) ( printf ( "우리에게서 보내기: %s
" , nl2br (htmlspecialchars ($msg )); ) fputs ($sock , " $msg \r\n" ); $str = fgets ($sock , 512 ); if (! $sock ) ( printf ( "소켓은 down\n" ); exit(1); ) else ( if (isset($_SERVER [ "debug" ]) && $_SERVER [ "debug" ]) ( printf ("서버에서 가져옴: %s
" , nl2br (htmlspecialchars ($str )); ) $e = 분해 (" " , $str ); $code = array_shift ($e ); $str = 파열 ( " " , $e ); if ($code > 499 ) ( printf ( "SMTP 대화에 문제가 있습니다.

코드 %d.
메시지 %s
"
, $code , $str );

출구(1);

) ) ) ?>

MailSmtp() 함수가 포함된 미리 만들어진 스크립트의 예를 다운로드하세요: smtpauth.php.sample위에서 설명한 MailSmtp() 함수를 사용하여 mail() 함수를 직접 대체할 수 있습니다. PHP에서 가장 간단한 형식의 예를 살펴보겠습니다. // 메시지 헤더는 메시지 인코딩, 보낸 ​​사람, 받는 사람 필드 등을 정의합니다.$headers = "MIME 버전: 1.0\r\n" ; $헤더 .= "콘텐츠 유형: text/html; charset=windows-1251\r\n" " ; ; $headers .= "받는 사람: $to \r\n" ; $헤더 .="보낸 사람: 보낸 사람 이름
// 메일($to, $subject, $message, $headers); require_once "smtpauth.php" ;  MailSmtp($to, $subject, $message, $headers);  ) ?> 누구에게: 
 
 

텍스트:

보내다!

이 양식이 mail() 함수 없이 작동하도록 하려면 require_once를 통해 smtpauth.php 파일을 포함시키고 mail()과 유사한 인수를 사용하여 여기에 설명된 MailSmtp() 함수를 호출했습니다. 동시에 스크립트 실행 시 오류를 방지하기 위해 코드에서 mail() 호출 자체를 주석 처리했습니다. ASP.NET을 사용하여 이메일을 보내는 방법은 무엇입니까?버전 2.0을 사용하는 경우 MailMessage 클래스를 사용하세요.

System.Net.Mail

), 잘 설명되어 있습니다.

<% @Page Language="c#" %> <% @Import Namespace="System.Net.Mail" %> <% @Import Namespace="System.Net" %> <% MailMessage message = new MailMessage(); 다음은 C# 및 VisualBasic 언어에 대한 사용 예입니다. C# 언어의 예: [이메일 보호됨]"); //새 문자 만들기메시지.대상.추가(" // 수신자 주소 추가 message.From = 새로운 MailAddress("from@ domain.tld", "발신자_이름"); // 보낸 사람의 이름과 주소를 지정합니다. message.Subject = "메시지 제목"; // 편지의 제목 지정 message.BodyEncoding = System.Text.Encoding.UTF8; // 문자 인코딩 지정 message.Body = "메시지 텍스트"; // 편지의 텍스트(본문) 지정 SmtpClient 클라이언트 = new SmtpClient("smtp.site",25); // "smtp.site" 서버에 대한 새 연결 생성 client.DeliveryMethod = SmtpDeliveryMethod.Network; // 메시지 전송 방법을 정의합니다.클라이언트.EnableSsl = 거짓; // 서버에 대한 보안 연결을 사용할 필요가 없도록 합니다. client.UseDefaultCredentials = false; // 기본 인증 세부정보 사용을 비활성화합니다. client.Credentials = new NetworkCredential("postmaster@ // 수신자 주소 추가", "***비밀번호***"); // SMTP 서버 인증에 필요한 세부 정보(사용자 이름 및 비밀번호) 지정클라이언트.Send(메시지); // 메시지 보내기 %>

이 방법의 사용을 보여주는 완성된 양식의 예인 MailForm.aspx를 다운로드하세요.

VisualBasic 언어의 예:

<% @Page Language="VB" Debug="true" %> <% @Import Namespace="System.Net.Mail" %> <% @Import Namespace="System.Net" %> <% Dim smtpMssg AS new MailMessage smtpMssg.From = New MailAddress ("admin@// 수신자 주소 추가", "Sender_name") smtpMssg.To.Add (" [이메일 보호됨]") "수취인 주소 추가 smtpMssg.Subject = "이메일 제목" "편지의 주제 표시 smtpMssg.Body = "메시지 텍스트" " 편지의 내용(본문) 표시 smtpMssg.BodyEncoding = System.Text.Encoding.UTF8 " 문자 인코딩 표시 smtpMssg.IsBodyHtml = 거짓 " 문자 형식 표시(true - HTML, false - HTML 아님) SmtpMail을 새 SmtpClient("smtp.site", 25)로 희미하게 표시 " "SmtpClient" 유형의 새 객체 선언 SmtpMail.DeliveryMethod = SmtpDeliveryMethod.Network "편지 배송 방법 안내 SmtpMail.UseDefaultCredentials = False "기본적으로 인증 자격 증명 사용을 비활성화합니다" SmtpMail.EnableSsl = 거짓 "는 서버에 대한 보안 연결을 사용할 필요성을 비활성화합니다. SmtpMail.Credentials = new NetworkCredential("postmaster@ // 수신자 주소 추가", "***비밀번호***") "SMTP 서버 인증에 필요한 세부 정보(사용자 이름 및 비밀번호)를 나타냅니다. SmtpMail.Send(smtpMssg) " 메시지를 보내는 중 %>

더 이상 사용되지 않는(그리고 더 이상 사용되지 않는) SmtpMail 클래스도 있습니다(네임스페이스 사용). 시스템.웹.메일). 다음은 VisualBasic 언어에 대한 사용 예입니다.

<% @Page Language="VB" Debug="true" %> <% @Import Namespace="System.Web" %> <% @Import Namespace="System.Web.Mail" %> <% Dim smtpMssg = new MailMessage " "MailMessage" 유형의 새 객체 선언 smtpMssg.From = "발신자_이름 // 수신자 주소 추가>" "발송인의 이름과 주소 표시 smtpMssg.To = "관리자@ // 수신자 주소 추가" "수취인의 주소 표시 smtpMssg.BodyFormat = MailFormat.Text "문자 형식 표시 smtpMssg.BodyEncoding = 인코딩.UTF8 "문자 인코딩을 나타냅니다. smtpMssg.Subject = "이메일 제목" "편지의 주제 표시 smtpMssg.Body = "메시지 텍스트" " 편지 내용 표시 smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate",1) "서버에서 SMTP 인증이 필요함을 나타냅니다. smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/sendusername", "admin@ // 수신자 주소 추가") "인증을 위한 사용자 이름 smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/sendpassword", "***비밀번호***") "인증용 비밀번호 SmtpMail.SmtpServer = "smtp.site" "SMTP 서버 주소 지정 SmtpMail.Send(smtpMssg) " 메시지를 보내는 중 %>

ASP를 사용하여 이메일을 보내는 방법은 무엇입니까?

당사의 smtp 서버를 사용하는 경우 인증이 필요하므로 스크립트에 적절한 액세스 세부정보를 추가하는 것을 잊지 마십시오. 예:

<% iConfig = Server.CreateObject("CDO.Configuration") Set iConfig = Server.CreateObject("CDO.Configuration") With iConfig.Fields .Item("http://schemas.microsoft.com/cdo/configuration/smtpserver") = "smtp.сайт" .Item("http://schemas.microsoft.com/cdo/configuration/smtpserverport") = 25 .Item("http://schemas.microsoft.com/cdo/configuration/sendusing") = 2 .Item("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate") = 1 .Item("http://schemas.microsoft.com/cdo/configuration/languagecode") = "ru" .Item("http://schemas.microsoft.com/cdo/configuration/sendusername") = "postmaster@// 수신자 주소 추가" .Item("http://schemas.microsoft.com/cdo/configuration/sendpassword") = "password" .Update End With Set cdoMessage = CreateObject("CDO.Message") With cdoMessage Set .Configuration = iConfig .From = "테스트 사용자 // 수신자 주소 추가>" .To = "사용자 " .Subject = "안녕하세요, 사용자" .TextBody = "ASP 스크립트에서 이 메시지를 작성합니다." .Send End With Set cdoMessage = Nothing Set iConfig = Nothing %>

일부 CMS에는 이미 서신이나 해당 모듈을 보내기 위한 도구가 내장되어 있습니다. 가장 인기 있는 도구를 살펴보겠습니다.

워드프레스

이 CMS에는 "WP Mail SMTP"라는 특수 모듈이 있으며, 구성 예는 모듈 페이지에 설명되어 있습니다.

예제의 그림에 주의하세요. 메일 시스템에서는 포트 25를 사용해야 하며 SSL 암호화는 필요하지 않습니다.

줌라

관리 패널에서 "일반 설정" 섹션으로 이동하여 "서버" 탭을 선택합니다. "메일" 필드에서 전송 방법을 "SMTP 서버"로 선택해야 하며, "SMTP 서버 주소", "SMTP 로그인" 및 "SMTP 비밀번호" 필드에서 메일 시스템의 적절한 세부 정보를 지정해야 합니다. 예: smtp.site, 상자@your_domain그리고 그에 상응하는 비밀번호.

드루팔

이 CMS에는 또한 SMTP 서버와 작업하기 위한 자체 모듈이 있습니다. PHP메일러. CMS Drupal 웹사이트의 해당 페이지에서 이 모듈을 다운로드할 수 있습니다. 모듈 설치에 대한 설명은 모듈과 함께 제공됩니다.

넷캣

이 CMS에는 SMTP 서버 작업을 위한 내장 기능이 없습니다. 사이트 스크립트를 사용하여 메일을 보내려면 당사 솔루션을 사용하여 연결하도록 제안할 수 있습니다. 다음 단계를 수행해야 합니다.

  • 당사 웹사이트에서 필요한 파일이 포함된 아카이브를 다운로드하세요( send_auth_mail.php그리고 mail.inc.php) 컴퓨터에서 압축을 풀어보세요.
  • 파일 편집 send_auth_mail.php아카이브에서 원하는 SMTP 서버에 대한 연결 세부 정보를 나타냅니다.

    • $mail_smtpServer = "smtp.site"; (SMTP 서버 주소)
    • $mail_port = "25" ; (연결 포트)
    • $mail_username = "[이메일 보호됨]" ; (SMTP 서버 인증을 위한 사용자 이름)
    • $mail_password = "비밀번호"; (SMTP 서버 인증을 위한 비밀번호)
  • 파일의 백업 복사본 만들기 domain.tld/www/netcat/admin/mail.inc.php;
  • 파일 업로드 send_auth_mail.php그리고 mail.inc.php디렉토리의 가상 사이트로 domain.tld/www/netcat/admin/

// 수신자 주소 추가귀하의 도메인 이름으로 바꿔야 합니다.

제안된 솔루션은 이 CMS의 표준 기능을 사용하여 메일을 보내는 모든 NetCat 모듈에서 작동합니다.

© 2024 ermake.ru - PC 수리 정보 - 정보 포털