2013年7月22日 星期一

[ASP.NET]用TryParseExact將特殊日期格式轉回DateTime

一般日期轉換,我都會用DateTime.TryParse來轉換,但如果不注意的話,會發生日期完全不對或失敗的問題…
日期不對舉凡像有些系統會使用05/07/2013這種格式,心裡想的是七月五號,但轉換後會變成五月七號,另外一種情況就是自訂格式轉換的問題,今天收到客戶送過來的日期格式如下"2013/07/22 @ 20:00:15:4324",如果用DateTime.TryParse就會回傳false,這時就要用DateTime.TryParseExact():
//特殊格式
string DateStr = "2013/07/22 @ 20:00:15:4324";
DateTime _date;

//錯誤的轉換方式,回傳False
if (DateTime.TryParse(DateStr, out _date))
{
    //TryParse轉換成功
}

//正確轉換方式
if(DateTime.TryParseExact(DateStr, "yyyy/MM/dd @ HH:mm:ss:ffff", null, System.Globalization.DateTimeStyles.None, out _date))
{
    //TryParseExact轉換成功
}

Reference

--

MSDN

2013年7月21日 星期日

[CSS]網頁鑲入FLASH卻出現邊框或白線之解決辦法

雖然HTML5越來越火紅,但要所有網頁設計師都去學HTML5捨棄掉FLASH簡直是天方夜譚,所以在實務上,常常會從網頁設計師的版發現又是FLASH,又是Table排版,搞半天還是要程式設計師花時間去調整版面(以上純屬個人經歷小小抱怨…)
之前常發現一個問題,就是FLASH邊邊會出現白線,網頁結構大概如下:
<body>
<form id="form1" runat="server">
    <div>
        <object id="FlashID" width="900" height="675" style="visibility: inherit;">
            <param name="movie" value="flash.swf">
            <param name="quality" value="high">
            <param name="wmode" value="transparent">
            <param name="swfversion" value="11.0.0.0">
            <!-- 此 param 標籤會提示使用 Flash Player 6.0 r65 和更新版本的使用者下載最新版本的 Flash Player。如果您不想讓使用者看到這項提示,請將其刪除。 -->
            <param name="expressinstall" value="../../Content/images/expressInstall.swf">
            <param name="BGCOLOR" value="#2b0001">
            <!-- 下一個物件標籤僅供非 IE 瀏覽器使用。因此,請使用 IECC 將其自 IE 隱藏。 -->
            <!--[if !IE]>-->
            <object type="application/x-shockwave-flash" data="flash.swf" width="900" height="675" style="font-size: 0; line-height: 0;">
                <!--<![endif]-->
                <param name="quality" value="high">
                <param name="wmode" value="transparent">
                <param name="swfversion" value="11.0.0.0">
                <param name="expressinstall" value="../../Content/images/expressInstall.swf">
                <param name="BGCOLOR" value="#2b0001">
                <!-- 瀏覽器會為使用 Flash Player 6.0 和更早版本的使用者顯示下列替代內容。 -->
                <div>
                    <h4>這個頁面上的內容需要較新版本的 Adobe Flash Player。</h4>
                    <p>
                        <a href="http://www.adobe.com/go/getflashplayer">
                            <img src="http://www.adobe.com/images/shared/download_buttons/get_flash_player.gif" alt="取得 Adobe Flash Player" width="112" height="33"></a>
                    </p>
                </div>
                <!--[if !IE]>-->
            </object>
            <!--<![endif]-->
        </object>
    </div>
    <div style="background-color: yellow;">test</div>
</form>
</body>

第二個div我用背景黃色來區隔,會發現有以下白線(紅色區塊為FLASH區塊,因版權問題故就不呈現了):

image

調了好久,解決方法其實很簡單,只要朝CSS下手即可Q__Q:

object {
     float:none;
     margin:0em 0em 0em 0em;
     display:block;
}

image

Referenece

--

CSS Display屬性介紹

[IDE]在Visual Studtio 2012使用Visual SourceSafe(VSS)進行版本控管

版本控管有很多種,一般.NET開發人員會先想到的是TFS,最近也有很方便的線上版控GitHub,再來可能使用SVN等等,但本公司目前使用的仍是推出很久的Visaul SourceSafe來進行版本控管,不管用什麼都不重要,重要的是不要有人上程式導致系統掛掉,或者是大家版本不同搞成一團亂,能確保程式版本好維護即可,但現在開發工具都已經用到Visual Studtio 2012了,還能用古老的VSS嗎,答案是可以的!在這裡做個小筆記

要使用前,請先確保有安裝VSS Client工具,這樣VS才能偵測的到

首先打開VS 2012 -> 工具 -> 選項

QQ截圖20130721171844

也可以去環境裡面設定一些規則

QQ截圖20130721173338

設定預設的登入ID

QQ截圖20130721173355

接著就可以去開你的專案了,開啟後應該會跳出VSS輸入帳號密碼的畫面:

QQ截圖20130721171938

如果您的專案是網站,請使用

Referenece

--

什麼是VSS

http://www.dwdmbi.com/2012/09/using-vss-2005-with-visual-studio-2012.html

[ASP.NET]產生XML時多出BOM之解決辦法

最近工作上遇到一個需求,大概是產生XML資料,再利用這個資料丟到別的系統,來做資料匯入,但按照spec做出來,對方卻一直說parse有問題,花了好久的時間核對才發現是BOM的問題Q__Q
BOM
位元組順序記號(英語:byte-order mark,BOM)是位於碼點U+FEFF的統一碼字元的名稱。當以UTF-16或UTF-32來將UCS/統一碼字元所組成的字串編碼時,這個字元被用來標示其位元組序。它常被用來當做標示檔案是以UTF-8、UTF-16或UTF-32編碼的記號。資料擷取自維基百科
產生XML的程式如下
XmlDocument doc = new XmlDocument();

XmlDeclaration xmldecl;

//指定為UTF-8
xmldecl = doc.CreateXmlDeclaration("1.0", null, null);
xmldecl.Encoding = "UTF-8";
XmlElement root = doc.DocumentElement;
doc.InsertBefore(xmldecl, root);

//產生XML結構
XmlElement Dept = doc.CreateElement("Dept");
doc.AppendChild(Dept);

XmlElement RD = doc.CreateElement("RD");
Dept.AppendChild(RD);

doc.Save(@"D:\temp.xml");

因輸出的檔案看起來沒什麼問題,格式也都正確,但用二進位編輯器(如何使用二進位編輯器請看此篇)查看後,卻多出了一行亂碼

image

因Save預設會是UTF-8編碼,故我們宣告了兩次BOM的UTF-8,解決方式有以下幾種

將XML使用WriteAllText逐行寫入

File.WriteAllText(@"D:\temp.xml", doc.OuterXml);

或者將XML Save不指定為UTF-8
using (var writer = new XmlTextWriter(@"D:\temp.xml", new UTF8Encoding(false)))
{
    doc.Save(writer);
}

Referenece

--

http://stackoverflow.com/questions/4942825/xdocument-saving-xml-to-file-without-bom

2013年7月20日 星期六

[IDE]NotePad++新增二進位編輯器模組(Hex Editor)

通常除了開發上使用Visuall Studio外,通常我會一些檔案我會搭配用NotePad++來開啟編輯,最近工作需要有二進位編輯器來看一些檔案,突然發現Notepad++有個模組可以安裝,趕快來分享一下!

版本 6.3.3 v

開啟NotePad++,點選問號

image

點選H分類

image

找到Hex Editor工具

image

下載會來後會是一個ZIP壓縮檔,將裡面的HexEditor放入NotePad++資料夾,預設是C:\Program Files (x86)\Notepad++\plugins

image

接著重啟後,至外掛模組就可以將功能開啟了!!

image

2013年7月14日 星期日

[ASP.NET]筆記文-透過C#及Gmail帳號來發送Email

寫程式最大的成就感,就是能幫你解決日常生活的那些瑣事,最近寫了一個小程式,大概就是定時去一個網頁抓一些資料回來分析,然後定時寄到我的Mail信箱,但其實沒有架Mail Server,也可利用Gmail、outlook、yahoo來幫我們發送通知信,以前用過但忘記了,趕快再把它記錄到部落格,順便再附上其他常用的Email smtp,下次可以直接找來Copy XD
private void SendMailByGmail(List<string> MailList,string Subject,string Body)
{
    MailMessage msg = new MailMessage();
    //收件者,以逗號分隔不同收件者 ex "test@gmail.com,test2@gmail.com"
    msg.To.Add(string.Join(",", MailList.ToArray()));
    msg.From = new MailAddress("test2@gmail.com", "測試郵件", System.Text.Encoding.UTF8);
    //郵件標題 
    msg.Subject = Subject;
    //郵件標題編碼  
    msg.SubjectEncoding = System.Text.Encoding.UTF8;
    //郵件內容
    msg.Body = Body;
    msg.IsBodyHtml = true;
    msg.BodyEncoding = System.Text.Encoding.UTF8;//郵件內容編碼 
    msg.Priority = MailPriority.Normal;//郵件優先級 
    //建立 SmtpClient 物件 並設定 Gmail的smtp主機及Port 
    #region 其它 Host
    /*
     *  outlook.com smtp.live.com port:25
     *  yahoo smtp.mail.yahoo.com.tw port:465
    */
    #endregion
    SmtpClient MySmtp = new SmtpClient("smtp.gmail.com", 587);
    //設定你的帳號密碼
    MySmtp.Credentials = new System.Net.NetworkCredential("Gmail帳號", "Gmail密碼");
    //Gmial 的 smtp 使用 SSL
    MySmtp.EnableSsl = true;
    MySmtp.Send(msg);
}

Referenece

--

http://blog.longwin.com.tw/2010/09/google-gmail-set-value-2010/

http://windows.microsoft.com/zh-tw/windows/outlook/send-receive-from-app

http://help.yahoo.com/kb/index?page=content&y=PROD_MAIL_ML&locale=zh_TW&id=SLN4724