2015年11月16日

瑜珈課的體悟

同一個口令/指示 有多少人就有多少不同的動作

需要老師輔助

超越極限

個體能力不同

2015年10月28日

javascript 一個元件用兩個 class註冊同一種事件的觸發順序

<input class="A B" />
$('.A').keyup(function () {
...
});
$(document).delegate('.B', 'keyup', function () {
...
});

B會比 A先執行

2015年10月23日

開發時各項工具的選擇 要考慮後續維護使用

做台新專案的經驗
PM堅持 UML用 Astah做
但是接手的台新 IT團隊都用 Enterprise Architech

2015年8月7日

OpenXML將內容控制項替換文字

Template的內容控制項後面如果是接換行符號,不可以用 ↓(Shift+Enter),要用←┘(Enter)
不然替代文字後產生出的文件會有格式問題

2015年7月31日

Log4Net 學習紀錄

1.NuGet install log4net
2.Cerate file log4net.config
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections>
</configuration>
<configuration>
<!--logger: 記錄器,可自訂設定屬性(可多個)-->
<!--appender-ref: 指定參考的Appender設定-->
<logger name="Rolling">
<appender-ref ref="RollingFile" />
</logger>
<logger name="DB">
<appender-ref ref="LogDatabase" />
</logger>
</configuration>
<configuration>
<!--root logger: 根記錄器,當其他記錄器執行完後最後會執行根記錄器(唯一)-->
<!--level: 記錄級別設定-->
<root>
<level value="DEBUG" />
<appender-ref ref="RollingFile" />
</root>
</configuration>
For File
<configuration>
<!--appender: 內容為輸出格式的設定-->
<!--type: 輸出類型,例如 ConsoleAppender 為主控台輸出、RollingFileAppender 為文字檔輸出-->
<!--file: 輸出檔案的路徑位置-->
<!--layout: 記錄的格式設定-->
<appender name="RollingFile" type="log4net.Appender.RollingFileAppender">
<file value="C:\Log\PlayLog.txt" />
<appendToFile value="true" />
<maximumFileSize value="1000KB" />
<maxSizeRollBackups value="2" />
<rollingStyle value="Date" />
<datePattern value="yyyyMMdd" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="[Activity]%newlineActivityId: %property{GUID}%newlineTime: %date{yyyy-MM-dd HH:mm:ss}%newlineLevel: %level%newline%newline[System]%newlineSystem: %property{System}%newline%newline[IP]%newlineServerIP: %property{ServerIP}%newlineClientIP: %property{ClientIP}%newline%newline[Message]%newlineDescription: %property{Description}%newlineException: %property{Exception}%newline%newline[Properties]%newline%message%newline%newline" />
</layout>
</appender>
</configuration>
For DB
<configuration>
<appender name="LogDatabase" type="log4net.Appender.AdoNetAppender">
<bufferSize value="100" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=4.0.0.0, Culture=Neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="Data Source={Server};Initial Catalog={DBName};User ID={UserID};Password={Password}" />
<commandText value="INSERT INTO [dbo].[Message] (MessageId, Message) VALUES (@MessageId, @Message)" />
<parameter>
<parameterName value="@MessageId" />
<dbType value="Int32" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{MessageId}" />
</layout>
</parameter>
<parameter>
<parameterName value="@Message" />
<dbType value="String" />
<size value="100" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{Message}" />
</layout>
</parameter>
</appender>
</configuration>
3.Add Watch in Global.asax Application_Start()
log4net.Config.XmlConfigurator.ConfigureAndWatch(new System.IO.FileInfo(Server.MapPath("~/log4net.config")));


儲存GUID
log4net.ThreadContext.Properties["GUID"] = guidValue;
<parameter>
<parameterName value="@LogId" />
<dbType value="Guid" />
<layout type="log4net.Layout.RawPropertyLayout">
<key value="GUID" />
</layout>
</parameter>

Trace log4net debug message by modify web.config
<configuration>
<appSettings>
<add key="log4net.Internal.Debug" value="true"/>
</appSettings>
</configuration>
<configuration>
<system.diagnostics>
<trace autoflush="true">
<listeners>
<add name="textWriterTraceListener"
type="System.Diagnostics.TextWriterTraceListener"
initializeData="C:\Log\log4net.txt"
/>
</listeners>
</trace>
</system.diagnostics>
</configuration>

2015年5月14日

繳費疑雲

一個帳號前後有兩個擁有者A,B

A把帳號讓渡給B了

B去查帳單的時候,A、B的兩個時期的帳單都有
B把所有帳單都繳掉了

這時查繳費紀錄只會出現B的資料
A去查繳費紀錄時就查不到了

user卻想在繳費紀錄看到“誰產生帳單的”

2015年4月20日

Single Page

用 ajas post只更新畫面中的部分區塊&javascript

debug javascript時很麻煩 ...

2015年4月17日

foreach 物件屬性

foreach (PropertyInfo property in obj.GetType().GetProperties())
{
if (property.GetValue(obj, null) != null)
{
property.SetValue(obj, "");
}
}

2015年4月1日

前端頁面使用者操作紀錄

在遠通的專案,發生了 end-user在 CSS系統繳費,說是只繳兩筆,但是系統銷帳卻有三筆的狀況

但是因為沒有頁面元件操作紀錄,所以死無對証

解決的方法可以考慮在 checkbox綁 onclick,每按一下就紀錄下來,submit的時候一併送出,再寫入 log

2015年3月31日

.NET SqlParameter(string paraName, object value) 字串 NVarchar

最近程式再被調教中
收到一封 mail說我們的 SQL script都是用 nvarchar,效能較差
要我們改成 varchar
查了一下是因為底層的 function寫得太便利,大家都是丟 object[] 進去直接賦值 大概是像這樣子
SqlParameter sqlPara = new SqlParameter("@" + temp[0], paraValues[i]);


如果 value是 int、dobule、datetime等都沒問題,產生出來的 SqlParameter內的屬性 SqlDbType會自動轉成對應的類別
但如果是字串,不管是 string、String還是 char,一律會被轉成 nvarchar
問題就來了


因為 table schema是放 varchar,query script的 where條件被轉成 nvarchar,就會導致效能變差~

2015年3月20日

Java的 milliseconds 轉成 c#的 DateTime

long javaMilliSec = 1386862447000;
new DateTime(1970,1,1,0,0,0,DateTimeKind.Utc).Add(new TimeSpan(javaMilliSec *TimeSpan.TicksPerMillisecond)).ToString("yyyy/MM/dd HH:mm:ss")

ref: Get c# DateTime from Java System.currentTimeMillis