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"이라는 이름의 이메일 메시지가 사이트 관리자에게 성공적으로 전달되었습니다. 동시에 편지 본문에는 피드백 양식에서 받은 데이터를 사용하여 스크립트에서 생성한 모든 콘텐츠가 포함됩니다.
- 보낸 사람 이름: 니콜라이;
- 보내는 사람의 주소: [이메일 보호됨];
- 메시지 제목: 메일 발송 확인 중;
- 메시지 내용: 테스트 메시지입니다.
이제 메일 전송을 성공적으로 확인한 후 속성을 할당하여 SMTP 디버깅 모드를 비활성화할 수 있습니다. SMTP디버그(pos.50) 값 0.
따라서 우리는 타사 메일 서버를 사용하여 인증을 받아 SMTP를 통해 메일을 보내는 도구를 만드는 작업을 완료했습니다.
예를 들어, 다음 기사에서는 등록된 사용자 계정 데이터를 복구하기 위해 확인 이메일을 보내는 방법을 살펴보겠습니다.
사이트 소스 파일
이 기사에서 업데이트된 사이트의 소스 파일은 첨부된 추가 자료에서 다운로드할 수 있습니다.
- www 디렉토리 파일
- MySQL 데이터베이스 테이블
로컬 서버에서 SMTP를 통해 메일을 보내면 로컬 컴퓨터에 있는 사이트, 더 간단하게는 로컬 서버에서 메시지 보내기를 테스트할 수 있습니다. 이를 위해 Yandex, Google 또는 mail.ru 메일 서비스를 사용할 수 있습니다.
우선, SMTP(Simple Mail Transfer Protocol)는 TCP/IP 네트워크를 통해 이메일을 전송하도록 설계된 널리 사용되는 네트워크 프로토콜입니다. 그리고 널리 사용되는 모든 이메일 서비스에는 이러한 프로토콜이 있습니다.
로컬 서버의 출현으로 개별 스크립트나 cms 시스템의 성능을 확인하기 위해 더 이상 호스팅 제공업체를 선택할 필요가 없었고 그에 따른 비용도 더 이상 들지 않았습니다. 컴퓨터에서 모든 것을 테스트하는 것이 훨씬 쉬우며, 자신이 "수행한" 작업을 모든 사람에게 보여줄 수 있습니다.
이러한 서버 중 다수에는 이미 소프트웨어와 메일 작업에 필요한 기능이 내장되어 있으므로 올바르게 구성하기만 하면 됩니다.
해당 메일의 기능을 확인하려면 최소한 다음 사항이 필요합니다.
- Openserver를 로컬 서버로 사용할 수 있습니다.
- 그리고 간단한 스크립트는 바로 아래에서 찾을 수 있는 템플릿입니다.
- 모든 메일 서버를 사용할 수 있습니다.
SMTP 스크립트 설정을 통해 PHP 메일 보내기
아래에서 복사하거나 수백 개의 유사한 사이트에서 다운로드할 수 있는 간단한 스크립트 템플릿을 편집해야 합니다.
먼저 스크립트 템플릿에서 일부 값을 변경해야 합니다.
에게
— 메일 메시지가 전송될 우편 주소로 변경합니다.
주제
- 편지 제목
메시지
— 메시지 자체 또는 편지 본문.
내 스크립트의 예:
물론 기능을 약간 확장하여 스크립트가 메일 전송에 대한 메시지를 표시하도록 할 수 있습니다. 실제로 전송을 수행하는 것은 SMTP 서버이고 스크립트는 메시지만 생성합니다.
예를 들어 다음과 같이 작성할 수 있습니다.
모든 대체 값은 따옴표로 묶어야 합니다. 그렇지 않으면 스크립트에서 오류가 발생합니다. 그런 다음 스크립트를 로컬 서버 폴더에 저장할 수 있습니다.
예를 들어: 도메인/send/index.php SMTP opensrever를 통해 메일 전송 설정을 시작합니다.
![](https://i0.wp.com/starting-constructor.ru/wp-content/uploads/2018/01/Screenshot_7.png)
메일은 값 대신 스크립트에 지정된 주소로 도착합니다. '에게'
하지만 이 메일은 openserver 설정에 지정된 SMTP에 의해 정확하게 처리되고 전송됩니다.
- 서버 시작
- "mail" 메뉴의 설정으로 openserver 모듈을 엽니다.
- 그림과 같이 모든 필드를 채우고 실제 Yandex 사서함에서 사용자 이름, 보낸 사람의 이메일 및 비밀번호를 대체합니다.
![](https://i2.wp.com/starting-constructor.ru/wp-content/uploads/2018/01/Screenshot_1.png)
설정을 저장하고 서버가 다시 시작된 후 스크립트 자체에 액세스할 수 있습니다. "내 사이트" 폴더에서 이전에 저장한 index.php 스크립트가 있는 "send" 폴더를 엽니다.
![](https://i2.wp.com/starting-constructor.ru/wp-content/uploads/2018/01/Screenshot_4.png)
이 스크립트에 액세스하자마자 새 브라우저 창에 스크립트가 완료되었음을 나타내는 정보가 나타납니다.
![](https://i0.wp.com/starting-constructor.ru/wp-content/uploads/2018/01/Screenshot_5.png)
그런 다음 스크립트에 주소가 지정된 사서함을 확인하여 편지가 도착했는지 확인해야합니다.
![](https://i1.wp.com/starting-constructor.ru/wp-content/uploads/2018/01/Screenshot_6.png)
거기에 없으면 무언가가 올바르게 구성되지 않았거나 편지가 스팸 폴더에 있다는 의미입니다.
다른 모든 설정은 비슷해 보이지만 혹시라도 추가 정보가 손상되지는 않습니다.
SMTP mail ru를 통해 메일 전송을 설정하려면 Yandex 매개변수를 mail ru 매개변수로 바꾸면 됩니다.
그리고 매번 로컬 서버를 재구축하지 않으려면 서로 다른 openserver 프로필을 구성하는 것이 가장 좋습니다. 이를 수행하는 방법은 비디오 튜토리얼에 나와 있습니다.
이 경우 프로필을 로드하기만 하면 충분하며 서버를 다시 시작한 후에는 이 프로필에 지정된 모든 설정을 사용할 수 있습니다. 그것은 매우 편리하고 매우 간단하게 작동합니다.
각 프로필(이름은 전혀 중요하지 않음)에 대해 고유한 설정을 지정해야 합니다. 단, 스크립트, cms 시스템 및 다른 매개변수를 사용하는 응용 프로그램을 사용하려는 경우는 예외입니다.
그렇지 않은 경우 기본 설정을 사용하면 됩니다.
SMTP 메일 ru의 경우 모든 것이 동일합니다.
Yandex 데이터가 메일 ru 데이터로 변경되었습니다.
![](https://i1.wp.com/starting-constructor.ru/wp-content/uploads/2018/01/Screenshot_2.png)
smtp google을 통해 메일 보내기
Google SMTP를 통해 메일 전송을 설정하려면 약간의 노력이 필요합니다.
첫째, Google에서 프로필을 만드는 것이 다른 Yandex 및 메일 ru 시스템보다 어렵습니다.
둘째, 귀하가 로그인 정보를 제공하더라도 시스템은 단순히 편지를 통과시키지 않습니다. 우선, 그녀는 추가 지침에 대해 필요한 모든 정보가 포함된 편지를 보낼 것입니다.
그렇지 않으면 Google의 경우 정확히 동일한 방식으로 구성됩니다. 모든 데이터만 변경됩니다.
![](https://i1.wp.com/starting-constructor.ru/wp-content/uploads/2018/01/Screenshot_3.png)
다른 SMTP를 통해 메일 전송을 구성하려면 모든 데이터가 거의 동일합니다.
모든 것이 잘 진행되고 편지가 지정된 수취인에게 도달하면 모든 것이 올바르게 완료된 것입니다. 댓글로 경험을 공유해 주시면 좋을 것 같습니다.
특정 웹사이트가 효율적이고 생산적으로 작동할 수 있는 기회를 가지려면 가능한 한 책임감 있고 신중하게 웹사이트 제작에 접근해야 합니다. 온라인 상점을 만드는 데 사용할 시스템 선택에는 특별한 주의가 필요합니다. 사실 상품이나 서비스 판매를 전문으로 하는 상업 플랫폼은 사이트 유지 관리 및 채우기에 관련된 관리자와 온라인 상점 고객 모두에게 필요한 모든 기능을 구현하고 사용하기 쉬워야 합니다. 자신에게 적합한 CMS를 선택해야 하는 문제에 직면한 많은 사람들과 회사는 Magento를 선택할지, OkkaCMS를 선택할지 분석합니다. 이러한 웹사이트 엔진의 특징과 성능을 비교해 보겠습니다.
자신의 웹 사이트를 작업할 때 개인이나 회사는 많은 노력을 기울여야 합니다. 이 경우에만 긍정적인 결과를 기대할 수 있고 진정으로 효과적인 도구를 얻을 수 있습니다. 웹사이트 제작을 시작하기 전에 먼저 해결해야 할 근본적인 질문 중 하나는 가장 적합한 CMS 옵션을 어떻게 결정하느냐 하는 것입니다. 다음으로 두 가지 CMS(Joomla 또는okayCMS)를 비교하고 각각의 기능에 주목하겠습니다.
자신만의 웹사이트를 갖는 것은 효과적이고 성공적으로 운영되는 비즈니스를 위한 기본 요구 사항 중 하나입니다. 통계에 따르면 인터넷을 통한 다양한 상품 구매 및 서비스 주문 수가 증가한 것으로 나타났습니다. 이를 고려하여 대부분의 상업 회사는 이미 자체 웹사이트의 필요성을 인식하고 있습니다. 그러나 인터넷 리소스를 보유하고 있다는 단순한 사실만으로는 그 효율성, 수익성 및 기대되는 비즈니스 이점을 기대하기에 충분하지 않습니다.
자신만의 웹사이트를 만들거나 온라인 상점을 오픈하려고 준비할 때, 많은 문제를 고려하고 분석하고 다양한 문제를 해결해야 합니다. 이 경우에만 귀하의 프로젝트가 긍정적인 결과를 가져오고 귀하의 기대를 완전히 충족시킬 수 있다는 사실을 믿을 수 있습니다. 온라인 상점 개발과 관련된 다양한 문제 중 CMS 선택 문제는 특히 주목할 만합니다. 귀하가 최적의 엔진을 스스로 쉽게 결정할 수 있도록
미래의 온라인 상점을 위한 자체 웹사이트를 만들 계획을 세울 때 상당히 많은 수의 사람들, 심지어 판매 전문 회사조차도 기존 CMS 중 무엇을 선택할 것인지 어렵고 매우 중요한 선택에 직면합니다. 무엇을 선택할지 고민 중이라면 PrestaShop 또는 OKCMS를 읽어 보시기 바랍니다. 이 기사에서는 인터넷 사이트, 특히 온라인 상점을 만들기 위한 이 두 시스템을 비교할 것입니다.
가상 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); 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 , "메일 보낸 사람:<"
.
$mail_from
.
">" ); smtp_msg ($sock , "RCPT 대상:<"
.
$reciever
.
">" ); smtp_msg ($sock , "DATA" ); $headers = "제목: " . $subject . "\r\n" . $headers ; $data = $headers . "\r\n\r\n" . $content . "\r\n." ; smtp_msg ($sock , $data ); smtp_msg ($sock , "QUIT" ); fclose ($sock ); ) 함수 smtp_msg ($sock , $msg ) ( if ( ! $sock ) ( printf ("깨진 소켓!\n" ); exit(1 ); ) if (isset($_SERVER [ "debug" ]) && $_SERVER [ "debug" ]) ( 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), 잘 설명되어 있습니다.
다음은 C# 및 VisualBasic 언어에 대한 사용 예입니다.
C# 언어의 예:
<% @Page Language="c#" %>
<% @Import Namespace="System.Net.Mail" %>
<% @Import Namespace="System.Net" %>
<%
MailMessage message = new MailMessage(); //새 문자 만들기메시지.대상.추가(" [이메일 보호됨]"); //수취인 주소 추가 message.From = 새로운 MailAddress("from@ domain.tld", "보낸 사람 이름"); // 보낸 사람의 이름과 주소를 지정합니다. message.Subject = "메시지 제목"; // 편지의 제목 지정 message.BodyEncoding = System.Text.Encoding.UTF8; // 문자 인코딩 지정 message.IsBodyHtml = 거짓; // 문자 형식 지정(true - HTML, false - HTML 아님) message.Body = "메시지 텍스트"; // 편지의 텍스트(본문) 지정 SmtpClient 클라이언트 = new SmtpClient("smtp.site",25); // "smtp.site" 서버에 대한 새 연결 생성 client.DeliveryMethod = SmtpDeliveryMethod.Network; // 메시지 전송 방법을 정의합니다.클라이언트.EnableSsl = 거짓; // 서버에 대한 보안 연결을 사용할 필요가 없도록 합니다. client.UseDefaultCredentials = false; // 기본 인증 세부정보 사용을 비활성화합니다. client.Credentials = new NetworkCredential("postmaster@ domain.tld", "***비밀번호***"); // SMTP 서버 인증에 필요한 세부 정보(사용자 이름 및 비밀번호) 지정클라이언트.보내기(메시지); // 문자 보내
%>
이 방법의 사용을 보여주는 완성된 양식의 예인 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@domain.tld", "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@ domain.tld", "***비밀번호***") "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 = "발신자_이름 domain.tld>" "발송인의 이름과 주소 표시 smtpMssg.To = "관리자@ domain.tld" "수취인의 주소 표시 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@ domain.tld") "인증을 위한 사용자 이름 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@domain.tld" .Item("http://schemas.microsoft.com/cdo/configuration/sendpassword") = "password" .Update End With Set cdoMessage = CreateObject("CDO.Message") With cdoMessage Set .Configuration = iConfig .From = "테스트 사용자 domain.tld>" .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 서버 작업을 위한 내장 기능이 없습니다. 사이트 스크립트를 사용하여 메일을 보내려면 당사의 솔루션을 사용하도록 제안할 수 있으며 이를 연결하려면 다음 단계를 수행해야 합니다.
domain.tld귀하의 도메인 이름으로 바꿔야 합니다.
제안된 솔루션은 이 CMS의 표준 기능을 사용하여 메일을 보내는 모든 NetCat 모듈에서 작동합니다.