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

카테고리

Happydong (1363)
프로그래밍 (156)
01.C#기초 (4)
02.C#고급 (13)
03.ASP.NET (28)
04.HTML&Script (17)
05.Silverlight (38)
06.C 언어 기초 (2)
07.iOS (14)
08.Java (5)
09.SQL (8)
10.컴퓨터보안 (10)
11.패턴이야기 (3)
12.유니티3D (1)
13.Ubuntu (7)
14.Node.js (6)
MUSIC (16)
인물 (3)
Utility (10)
세미나 소식&내용 (22)
IT뉴스 (18)
운동 (830)
CAFE (10)
Life (282)
Total
Today
Yesterday

'프로그래밍/03.ASP.NET'에 해당되는 글 28건

  1. 2009.10.07 [메일발송] Gmail, Live SMTP를 이용한 메일 발송 4
  2. 2009.10.06 [웹 에디터] Xquared 에디터 붙이기!! 7
  3. 2009.02.01 OpenID를 이용한 로그인




 보통 서버에 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
, |



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

 그래서 내가 예전에 사용해서 봤던 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
, |



몇일전 회사에서 Silverlight를 이용해서 로그인 처리를 하고, 로그인에 대한 정보를 Silverlight에서 받을수 있도록 하는 간단한 샘플프로젝트를 해보라는 미션을 받게 되었습니다. 단, OpenID를 입력받아서 사용자 정보를 받아야 하는 것 이었습니다. 그래서 이래저래 Google링하는 도중 좋은 정보들을 찾을 수 있어서 공유하기 위한 목적으로 이렇게 포스팅 해봅니다.^^

OpenID란?

  OpenID란 간단하게 얘기하자면, 하나의 아이디로 여러 웹사이트에 로그인하기 위한 서비스라고 생각하시면 되겠습니다. 즉, 웹사이트에 따로 복잡한 회원가입 절차가 없이도, OpenID를 지원하다면 로그인을 할수 있도록 하는 것이지요.
 OpenID를 보시면 URL 주소로 되어 있는데요, 그것이 나만의 아이디로 쓰이게 되고요, 이미 가지고 계신 블로그나 홈피주소를 아이디로 쓸 수도 있어요.
 OpenID를 지원하는 웹사이트에 로긴하기 위해서는, 단지 사용자의 OpenID URL만 입력하면 되고요, 그럼 그 웹사이트에서는 인증을 위해 사용자의 OpenID를 제공하는 서버로 요청을 보냅니다. 그리고 인증이 끝나면 사용자 정보를 요청한 사이트에 인증된 사용자정보를 보내주므로서 로그인처리가 되는 것이지요.
OpenID더 궁금하신 내용이 있다면 아래 링크를 참고 하세요.

OpenID한국판사이트
OpenID적용된사이트목록


OepnID 적용해 보기

 먼저 OpenID가 없으신 분이라면, myID.net에서 만드시면 되겠습니다. (myID.net서비스에 대해 궁금하신 분들은 를 참고해서 보세요.)

 OpenID를 만드셨다면 이제 Visual Studio를 이용해 웹프로젝트를 하나 생성하도록 하겠습니다. 프로젝트를 만드셨다면 이제 .NET 기반의 OpenID공개 소스인 ExtremeSwank Library(ExtremeSwank OpenID)와 컨트롤 예제(ExtremeSwank OpenIDControl User Control)를 다운받도록 합니다.

로드

(ExtremeSwank Library .NET2.0기반으로 개발되어 있지만,3.0에서도 사용 가능하며, OpenID1.1 2.0을 모두 지원하고 있다는 장점도 가지고 있습니다.)

 

이렇게 두개의 파일을 다 받으셨다면 ExtremeSwank.OpenId.dll를 프로젝트에 추가 하시고, 컨트롤 파일을 추가해주시면 간단한 예제 프로젝트가 완성이 됩니다. 저 같은 경우 아래 그림과 같이 구성해 보았습니다.

 

사용자 삽입 이미지

 

간단하게 MasterPage, UserControls 폴더를 따로 만들어서 해당 파일들을 넣어주고 URL만 변경해 주었지요. 이제 한번 실행해 보도록 하지요.

그림1.

사용자 삽입 이미지

그림2.
사용자 삽입 이미지
(위 그림에서 drum83.myid.net는 제 OpenID입니다.^^;;;)

그림3.
사용자 삽입 이미지
(요청한 사이트가 등록이 되어 있지 않다면 비밀번호를 입력해야 합니다.)

그림4.
사용자 삽입 이미지
(비밀번호를 입력하게 되면, 자신의 정보를 보여지게되고, 승인할것인지, 이번만 승인할것인지를 사용자가 직접 결정을 하게됩니다.)

그림5.
사용자 삽입 이미지
(이렇게 사용자가 인증을 하게되면 위와같이 해당 정보를 요청한사이트에 콜백해주게 됩니다.)

 ExtremeSwank Library를 이용하면 간단하게 OpenID를 적용할수가 있으며, 지금 사용한 컨트롤만 웹사이트에 맞게 커스터마이징하시면 쉽게 OpenID를 적용한 웹사이트를 만들수 있을 거예요. 그리고 아래 주소를 가고시면  ExtremeSwank Library 문서도 MSDN같이 잘나와 있어서 적용하는데 큰 무리는 없을 듯 해요.
ExtremeSwank Library 문서

위에 만든 예제파일도 첨부했으니 받아보실분은 다운로드 받으세요~^^




Posted by happydong
, |