블로그 이미지
내게 능력 주시는 자 안에서 내가 모든것을 할수 있느니라 - 빌립보서 4 : 13 - happydong

카테고리

Happydong (1363)
프로그래밍 (156)
MUSIC (16)
인물 (3)
Utility (10)
세미나 소식&내용 (22)
IT뉴스 (18)
운동 (830)
CAFE (10)
Life (282)
Total
Today
Yesterday




 보통 서버에 SMTP 설치/설정해서 .NET에서 지원하는 SmtpClient객체를 이용해서 메일을 보냈을 것 이다. 이렇게 해도 메일을 발송하는데는 별 문제가 없다. 하지만, 간혹 메일을 보내면 포탈사이트 메일을 사용하는 사용자들에게는 스펨으로 빠지는 경우가 있다. 그 이유는 메일보내는 도메인이 화이트리스트에 등록이 안되있어서 그런데 이를 해결하기 위해서는 KISA RBL에 등록을 해야한다. (자세한 내용은 사이트를 확인 바람.) 아무튼 귀찮은 작업이다. 

 이를 간단하게 해결하는 방법으로 Gmail과 Live(둘중 선택) SMTP를 이용하면 될 것이다. Gmail과 Live는 외부에서 접근이 가능하게 SMTP주소와 포트를 오픈해 놨다. 그래서 간단하게 예제 소스를 만들어 봤다. 

 Visual Studio를 이용해서 웹프로젝트를 하나 생성해서 Default.aspx에 아래 코드를 작성해 보자.

Default.aspx

<body>

    <form id="form1" runat="server">

    <div>

        ㅁ 메일 작성!!<br />

        <br />

        SMTP 선택 :

        <asp:DropDownList runat="server" ID="ddlSmtpList">

            <asp:ListItem Text="Gmail" Value="1" />

            <asp:ListItem Text="Live" Value="0" />

        </asp:DropDownList>

        <br />

        받는 사람 :

        <asp:TextBox runat="server" ID="txtToMailAddress" /><br />

        제목 :

        <asp:TextBox runat="server" ID="txtTitle" Style="width: 560px" /><br />

        <asp:TextBox runat="server" ID="txtBody" Style="width: 600px; height: 400px;" TextMode="MultiLine" /><br />

        <asp:Button runat="server" ID="btnSend" OnClick="btnSend_Click" Text="전송" />

    </div>

    </form>

</body>


간단한 코드다. Gmail 또는 Live SMTP를 사용지에 대한 DropDownList와 수신자 메일을 지정할 텍스트박스, 제목을 적을 텍스트박스, 내용을 적을 텍스트박스 그리고 전송위한 버튼...간단하게 5개 컨트롤들을 지정해 봤다. 그럼 .cs 코드를 보자.

Default.aspx.cs

        /// <summary>

        /// Live smtp서버 주소

        /// </summary>

        private const string LIVESMTP_SERVER = "smtp.live.com";

 

        /// <summary>

        /// Gmail smtp서버 주소

        /// </summary>

        private const string GMAILSMTP_SERVER = "smtp.gmail.com";

 

        /// <summary>

        /// SMTP포트

        /// </summary>

        private const int SMTPPORT = 587;

 

        protected void Page_Load(object sender, EventArgs e)

        {

        }

 

        /// <summary>

        /// 전송버튼 이벤트

        /// </summary>

        /// <param name="sender"></param>

        /// <param name="e"></param>

        protected void btnSend_Click(object sender, EventArgs e)

        {

            MailAddress from = new MailAddress()

            {

                Email = "kdw8751@gmail.com",

                DisplayName = "Dongwook"

            };

 

            MailAddress to = new MailAddress()

            {

                Email = txtToMailAddress.Text

            };

 

            bool isGmail = ddlSmtpList.SelectedValue == "1" ? true:false;

 

            SendMail(txtTitle.Text, txtBody.Text, to, from, isGmail);

        }

 

        /// <summary>

        /// 메일을 발송합니다.

        /// </summary>

        /// <param name="title">제목</param>

        /// <param name="body">내용</param>

        /// <param name="to">수신자</param>

        /// <param name="from">발신자</param>

        /// <param name="isGmail">Gmail Smtp 여부</param>

        private void SendMail(string title, string body, MailAddress to, MailAddress from, bool isGmail)

        {

            // SmtpClient 변수 선언

            SmtpClient smtp;

 

            if (isGmail)

            {

                smtp = new SmtpClient(GMAILSMTP_SERVER, SMTPPORT);

                // Gmail메일 ID/ Password 지정

                smtp.Credentials = new NetworkCredential("Gmail아이디@gmail.com", "Gmail Password");

            }

            else

            {

                smtp = new SmtpClient(LIVESMTP_SERVER, SMTPPORT);

                // Live메일 ID/ Password 지정

                smtp.Credentials = new NetworkCredential("Live아이디@live.com", "Live Password");

            }

 

            smtp.DeliveryMethod = SmtpDeliveryMethod.Network;

            smtp.EnableSsl = true;

 

            MailMessage message = CreateDefaulMailMessage(from, to, title, body);

            object userState = message;

 

            // 비동기 이벤트

            smtp.SendCompleted += new SendCompletedEventHandler(smtp_SendCompleted);

            // 비동기 호출

            smtp.SendAsync(message, userState);

            // 동기호출

            //smtp.Send(message);

        }

 

        /// <summary>

        /// 비동기 호출 이벤트

        /// </summary>

        /// <param name="sender"></param>

        /// <param name="e"></param>

        void smtp_SendCompleted(object sender, System.ComponentModel.AsyncCompletedEventArgs e)

        {

            if (e.Error != null)

                return;

        }

 

        /// <summary>

        /// 기본적인 메일 메세지를 생성하여 반환합니다.

        /// </summary>

        /// <param name="from">발신자 이메일</param>

        /// <param name="to">수신자 이메일</param>

        /// <param name="subject">메일 제목</param>

        /// <param name="body">메일 본문</param>

        /// <returns>메일 메세지 객체</returns>

        private MailMessage CreateDefaulMailMessage(MailAddress from, MailAddress to, string subject, string body)

        {

            // 메일 메세지 객체 생성

            MailMessage message = new MailMessage();

 

            //// 보내는 사람

            message.From = from.ConvertToBuiltInMailAddress();

 

            // 수신자 지정합니다.

            message.To.Add(to.ConvertToBuiltInMailAddress());

 

            // 제목 인코딩

            message.SubjectEncoding = System.Text.Encoding.UTF8;

            // 제목

            message.Subject = subject;

 

            // 본문 인코딩

            message.BodyEncoding = System.Text.Encoding.UTF8;

            // 본문

            message.Body = body;

 

            // HTML 허용

            message.IsBodyHtml = true;

 

            // 우선순위

            message.Priority = MailPriority.Normal;

            return message;

        }

    }

 

    /// <summary>

    /// 메일 정보

    /// </summary>

    public class MailAddress

    {

        /// <summary>

        /// 메일주소를 지정/반환합니다.

        /// </summary>

        public string Email { get; set; }

 

        /// <summary>

        /// 이름을 지정/반환합니다.

        /// </summary>

        public string DisplayName { get; set; }

 

        /// <summary>

        /// 빌트인 MailAddress 객체를 만들어 반환합니다.

        /// </summary>

        /// <returns></returns>

        public System.Net.Mail.MailAddress ConvertToBuiltInMailAddress()

        {

            return new System.Net.Mail.MailAddress(this.Email, this.DisplayName);

        }

    }


위 코드에서 주석을 보면서 보면 이해하기 쉬울것 이다. 내용을 다 입력한후 전송버튼을 클릭하면 btnSend_Click로 이벤트로 들어 올것이다. 여기서 드롭다운리스트에서 선택되어 있는 SMTP주소를 지정한다. 그리고 제목, 내용, 수진자지정, 보낸 사람지정후 메일을 보내진다. 코드는 아주 간단하다. 실행해 보면 잘 될 것이다. (소스는 버리기 아까우니 첨부파일로 올려놓겠다.)

주요 내용은 Live SMTP주소가 smtp.live.com 이고, Gmail SMTP주소는 smtp.gmail.com 이다. 포트는 둘다 587로 되어 있다. 그리고 메일을 보내기 위해서는 Live, Gmail 계정이 반드시 있어야 한다. 

참고 )
Live SMTP를 이용하면 메일을 발송할수 있는 건수가 제한이 되어 있다. 총 몇건인지 자세히 알아 보진 않았지만... 테스트로 20건 정도 반복해서 보내봤는데... 계정이 막혀버렸다. 그래서 Live에 다시 직접 로그인해서 풀어줘야하는 번거로운이 있엇다.  그에 비해 Gmail은 계정이 막히거나 그러지 않았다. Gmail의 메일 발송 한도는 아래 링크를 확인 하기 바란다.
(http://mail.google.com/support/bin/answer.py?hl=ko&answer=22839)


Posted by happydong
, |




개발자를 위한 Windows 7 세미나 시리즈
5탄- 멀티터치를 활용한 응용 프로그램
개발 가이드(10월 8일)


Windows 7의 가장 매력적인 기능인 멀티터치 기능을
알고 계신가요?
웹 애플리케이션과 WPF 프로그래밍에서도 쉽고 빠르게 활용할 수 있는 멀티터치를 MSDN 세미나에서
만나보시기 바랍니다.
일시 : 10월 8일(목) 18:30 ∼ 21:30
장소 : 한국마이크로소프트 5층 세미나실 (포스코센터 서관 5층) [약도보기]
AGENDA
18:30- 19:00 등록
19:00- 20:10 윈도우 7 멀티터치 개발의 세계로..
윈도우 7의 새로운 기능 중에 가장 개발해보고 싶은
기능 1위 멀티터치. 윈도우 7의 멀티터치 개발을 소개해 드립니다.
(샘플 코드는 주로 닷넷 프로그래밍 환경에서 작성되었습니다.)
오일석 MVP
20:10-20:20 휴식
20:20-20:50 실버라이트3, 웹을 멀티터치 하다.
실버라이트3와 윈도우 7을 통하여 웹에서도 멀티터치가
가능해졌습니다. 간단한 사용법은 물론, 멀티터치가
웹애플리케이션에 어떤 영향을 줄지 생각해 볼 수 있는 시간이
될 것입니다.
공인석 MVP
20:50-21:30 멀티터치 WPF 4를 주목하라.
출시예정인 비주얼 스튜디오 2010과 .NET 프레임워크 4.0에서는
멀티터치 가능한 WPF 컨트롤을 제공합니다.
쉽고 빠르게 멀티터치 가능한 WPF 응용프로그램을 만드는 방법을
소개해 드립니다.
오일석 MVP
강사소개
  오일석 MVP
UX에 대한 열망으로 편한 길을 뒤로하고 d’strict way를 걷고 있다.
디스트릭트(http://dstrict.com) UX Technology 2 그룹에서 UX 솔루션 연구 개발에 몰두하고 있으며 주로 Microsoft의 UX 기술을 활용하고 있다. Microsoft MVP(Client App Dev.)로 훈스닷넷(http://hoons.kr)에서 시삽으로 활동하고 있다.
  공인석 MVP
훈스닷넷 실버라이트 분야 시삽을 맡고 있고, 실버라이트가 소개된 이래로 실버라이트에 매진해 왔다. 유령회사 공도소프트라는 블로그를 통하여 기술 자료, 컬럼, 강좌 등을 진행하고 있으며 훈스닷넷을 비롯한 실버라이트 관련 커뮤니티 활성화에 기여하고 있다.

행사안내
> 행사 참석을 원하시는 고객께서는 반드시 사전등록
   해주시기 바랍니다.

> 주차권이 제공되지 않으니 가급적 대중교통
   이용해 주시기 바랍니다.

> 행사 종료 후, 추첨을 통해 소정의 경품
   드립니다.
행사문의처
전화: 02-531-9607 (담당:변재섭)   E-Mail: msevent@wunderman.com
후원:  
Posted by happydong
, |



 웹개발을 하다보면 간혹 에디터를 붙어야 하는 경우가 생긴다. 그럼 개발자는 어떤 에디터를 사용할까 많이들 고민할 것 이다. 나 또한 그랬으니깐

 그래서 내가 예전에 사용해서 봤던 Xquared를 이용해서 웹사이트에 전용시키는 방법을 공유하려한다. 이는 초보개발자들이 웹에디터를 적용할 때 도움이 되는 문서가 되지 않을까 싶다.

 

Xquared자바스크립트로만 작성되어 있어서 별도의 소프트웨어를 설치 필요가 없고, XHTML표준을 따르는 문서를 만들어 주며, 다양한 확장점을 통해 원하는 기능을 쉽게 추가할 수 있도록 구현되어 있다.

 

Xquared 소개에 보면 위와 같이 설명되어 있다. 자세한 소개는 Xquared에서 확인해 보길 바란다.

 

이제 사이트에 어떻게 적용할지 하나하나 확인 해보자!

! 적용하기전에 먼저 에디터를 다운로드 받도록 한다. 다 받았다면 Visual Studio에서 웹프로젝트를 하나 만들도록 한다.

사용자 삽입 이미지

[그림 1]

Xquared_Editor라는 이름의 웹프로젝트를 하나 생성했다. 새로 생성하면 아마도 위 그림과 같은 모습일 것이다. 그렇다면 이제 아까 다운받았던 Xquared 에디터에서 images, javascripts, stylesheets 폴더를 프로젝트에 추가하자!!

사용자 삽입 이미지

[그림 2]

자 그럼 위 그림과 같이 구성이 되었을 것이다. 그럼 이제 에디터 설정을 하면 된다. 그럼 간단하게 Default.aspx파일에 스크립트 설정을 해보자. (물론 테스트 파일을 열어서 확인해도 편할것이다.)

Default.aspx

<html xmlns="http://www.w3.org/1999/xhtml">

<head runat="server">

    <title></title>

    <!-- style  -->

    <link rel="stylesheet" type="text/css" href="/stylesheets/xq_ui.css" />

    <!-- script  -->

 

    <script type="text/javascript" src="/javascripts/XQuared.js?load_others=1"></script>

 

    <script type="text/javascript" src="/javascripts/plugin/FileUploadPlugin.js"></script>

   

    <!-- xed 에디터 생성 스크립트 -->

    <script type="text/javascript">        //<![CDATA[

        var xed;

 

        window.onload = function() {

            xed = new xq.Editor("xqEditor");

 

            xed.setEditMode('wysiwyg');

            xed.setWidth("100%");

        };

        //]]>

</script>

 

</head>

<body>

    <form id="form1" runat="server">

    <div style="width:700px;">

        <!-- 내용이 전달될 textarea  -->

        <textarea id="xqEditor" name="xqEditor"></textarea>

    </div>

    </form>

</body>

</html>

 

스크립트 이벤트인 onload 이벤트 Xquared 에디터를 생성하는 것이 보일 것이다. 위와 같이 간단한 코드로 Xquared 에디터를 붙일수 있다. 지금은 테스트로 Default.aspx 페이지에 붙였지만, 실제 개발한때는 UserControl이나, Control로 잘만들어 놓으면 쓰기 편한 것 이다.


사용자 삽입 이미지

[그림 3 실행모습]

그럼 이제 Validation 체크관련 해서 알아보도록 하겠다. 테스트를 위해 버튼을 하나 만들어 보자. 

 

Default.aspx

function Validation() {

            alert(xed.getCurrentContent(true));

        }

<!-- 중복 코드 생략  -->

<input type="button" value="체크" onclick="Validation();" />

위 코드와 같이 간단하게 만들어 봤다. 버튼을 클릭하면 Validation라는 스크립트 함수를 호출하도록하고, Validation함수에서는 getCurrentContent함수를 통해 에디터의 내용을 반환해서 메세지를 뿌려주는 것이다. (getCurrentContent true를 주면 full-validation 수행된다.)


사용자 삽입 이미지

[그림 4]

위 그림은 실행 모습이다. 이를 이용해서 Validation 체크를 하면 될 것이다.

 

자 그럼 이제 이미지 업로드 설정에 대해서 알아 보도록 하자. 지금 툴바에는 이미지 업로드 버튼이 안보일 것이다. 이는 에디터 생성할 때 설정을 해주어야 한다.

 

Default.aspx

window.onload = function() {

            xed = new xq.Editor("xqEditor");

 

            xed.isSingleFileUpload = true;

            xed.addPlugin('FileUpload');

            xed.setFileUploadTarget('/ImageUpload.aspx', null);

            xed.setEditMode('wysiwyg');

            xed.setWidth("100%");

 

위 코드를 보면 isSingleFileUpload, addPlugin, setFileUploadTarget 이 세가지 함수가 추가로 설정되어 있다. isSingleFileUpload는 한 개 파일 업로드를 하겠다고 설정한 것이다. (다중 파일업로드는 Xquared 사이트에서 확인 해보기 바란다. 지금은 SingleFileUpload에 관련해서만 설명하도록 하겠다.) addPlugin() 메소드를 사용해서 플러그인을 xed에 추가한다. setFileUploadTarget()메소드는 파일 업로드할 페이지를 지정한다. 그래서 난 ImageUpload.aspx라는 페이지를 하나 생성해서 추가해 두었다. 그럼 이제 ImageUpload 페이지에 파일 업로드 코드를 작성하도록 하자.

 

먼저 스크립트를 추가 한다.

 

ImageUpload.aspx

<script type="text/javascript">        //<![CDATA[

        window.onload = function() {

 

            if (window.parent.xed) {

                window.parent.xed.fileUploadListener.onSuccess('<%= FileName %>','');

            }

        }

//]]></script>

 

스크립트는 간단하다 부모의 xed객체의 onSuccess메소드를 호출해 주는 것이다. 여기서 파일이름을 같이 전달해준다.

 

ImageUpload.aspx.cs

/// <summary>

        /// 파일 이름을 지정/반환합니다.

/// </summary>

protected string FileName { get; set; }

 

        protected void Page_Load(object sender, EventArgs e)

        {

            Save();

        }

 

        /// <summary>

        /// 파일을 저장합니다.

        /// </summary>

        private void Save()

        {

            // 에디터에서 표시될 이미지 경로

            string _imagehost = string.Format("http://{0}/FileUpload", Request.ServerVariables["HTTP_HOST"]);

            // 이미지 파일 저장 경로

            string UPLOADPATH = Server.MapPath("FileUpload");

 

            // 정상적으로 처리가 되었는지 여부

            bool isSuccess = false;

            // 이미지 지정 경로

            string imgPath = "";

 

            // 업로드 파일이 존재 여부 확인

            if (Request.Files.Count <= 0)

            {

                // Error 출력

                Message(isSuccess, imgPath, "Error");

                return;

            }

 

            // HttpPostedFile 인스턴스 생성

            HttpPostedFile file = Request.Files[0];

            // 파일 이름을 반환합니다. [고유한 파일명 반환]

            FileName = GetName(file.FileName);

 

            // 파일 이름이 null이면 error

            if (string.IsNullOrEmpty(FileName) == true)

            {

                Message(isSuccess, imgPath, "Error");

                return;

            }

 

            // 파일 저장합니다.

            file.SaveAs(Path.Combine(UPLOADPATH, FileName));

            // 정상처리

            isSuccess = true;

            // 에디터에서 보여질 경로 지정.

            imgPath = String.Format("{0}/{1}", _imagehost, FileName);

 

            // 메세지 출력

            Message(isSuccess, imgPath, "");

        }

 

        /// <summary>

        /// 메세지를 반환합니다.

        /// </summary>

        /// <param name="isSuccess"></param>

        /// <param name="fileUrl"></param>

        /// <param name="errorMessage"></param>

        public void Message(bool isSuccess, string fileUrl, string errorMessage)

        {

            string result = string.Format(" success:{0}, file_url:'{1}', message:'{2}' ", isSuccess.ToString().ToLower(), fileUrl, errorMessage);

            this.body1.InnerHtml = "{" + result + "}";

        }

 

        /// <summary>

        /// 파일 이름을 반환합니다.

        /// </summary>

        /// <param name="fileName"></param>

        /// <returns></returns>

        public string GetName(string fileName)

        {

            // 불필요한 파일 이름 삭제

            int lastCount = fileName.LastIndexOf(".");

            string fileType = fileName.Substring(lastCount, (fileName.Length - lastCount)).ToLower();

            string saveFileName = string.Empty;

 

            // 해당 type이 아니면 null 반환

            if (fileType == ".jpg" || fileType == ".gif" || fileType == ".png")

            {

                // 고유할수 있도록 간단하게 DateTime.Now.Ticks 사용함.

                saveFileName = DateTime.Now.Ticks.ToString() + fileType;

            }

 

            return saveFileName;

        }

 

.cs 코드는 따로 설명이 필요 없도록 코드에 주석을 달아 놨다. 이렇게까지 해서 Xquared 에디터 붙이기 성공을 했다. 간단하게 예제를 실행해 보고 파일이 정상적으로 폴더에 들어 갔는지 확인해 보자!!

 

[그림 5 Image 버튼 클릭후 파일 선택 모습]

 

[그림 6 Insert버튼 클릭후 모습]

 

[그림 7 저장파일]

 

정상적으로 잘 작동하는 것 같다~^^

이 프로젝트 소스는 첨부파일로 같이 올려 놓아요!

Posted by happydong
, |