2008年3月21日 星期五
檔案下載或開啟時出現亂碼檔名
下面介紹一個屬性設定,可以試試。
Response.HeaderEncoding = System.Text.Encoding.GetEncoding("big5");
透過設定 HeaderEncoding之後,可以將這問題解決掉。
完整的程式如後:
string strpath = "檔案路徑";
Response.HeaderEncoding = System.Text.Encoding.GetEncoding("big5");
Response.AddHeader("content-disposition", "attachment;filename=" + "中文檔名");
Response.WriteFile(strpath);
Response.End();
Ref:http://blog.darkthread.net/blogs/darkthreadtw/archive/2007/09/05/kb-open-and-download-file-in-chinese-filename.aspx
Ref:http://blog.miniasp.com/post/2008/04/ASPNET-Force-Download-File-and-deal-with-Chinese-Filename-correctly.aspx
[補充 20110920]
參閱保哥[ASP.NET 如何設定強制下載檔案並正確處理中文檔名的問題]這一篇文章,可以正確處理簡繁問題,也提供了不同瀏覽器的處理,非常值得參考。
[補充 20120704]
另一種選擇。
UrlPathEncode 用於檔案下載出現亂碼的問題
http://paladinprogram.blogspot.tw/2012/07/urlpathencode.html
GridView 在Firefox
解決之道,在於 GridLines = none ,到 GridView 控制項,找到 GridLines 屬性,並將他設成 none 就可以。
2008年3月18日 星期二
在ASP.NET 取得目前瀏覽器的URL
string strAbsoluteUri = Request.Url.AbsoluteUri;
strAbsoluteUri 的內容則為 http://localhost/ProjMngWeb/close/close_Main.aspx?seqsn=543
string [] arraySegments = Request.Url.Segments;
arraySegments 的內容則為 ["/" , "ProjMngWeb/" , "close/" , "close_Main.aspx"] 共4個維度
Bind DropDownList - SortedList
SortedList hEnd = new SortedList();
hEnd.Add("A","1");
hEnd.Add("B","2");
hEnd.Add("C","3");
ddlTimeStart.DataSource = hEnd;
ddlTimeStart.DataTextField = "key";
ddlTimeStart.DataValueField = "value";
ddlTimeStart.DataBind();
C#在客戶端和服務端操作Excel文件
一、在客戶端把數據導入到Excel文件步驟
1、創建Excel
application對象,打開或生成Excel文件
//服務端創建StringBuilder對象
System.Text.StringBuilder sb=new System .Text .StringBuilder ();
//指定客戶端執行語言
sb.Append
("<Script Language=VBScript>");
sb.Append
("<!--\r\n");
sb.Append
("dim xls\r\n");
//創建Excel
application對象
sb.Append
("Set xls=CreateObject(\"Excel.Application\")\r\n");
//打開Excel文件
sb.Append ("xls.WorkBooks.Open(C:\\MyExcel.xls)\r\n");
2、選定工作表,把數據導入到Excel
//選定欲操作的Excel表
sb.Append
("xls.Sheets(1).Select\r\n");
//获得要操作数据表的行、列数
int rows=dt.Rows.Count,cols=dt.Columns.Count
;
//按行列将数据写入Excel表
for (int
j=brow+1;j<brow+cols ;j++)
for (int i=bcol;i<bcol+rows
;i++)
sb.Append ("xls.Sheets(1).Cells(" +(j-1) + "," + (i)
+ ")=\"" + dt.Rows[i-bcol][j-brow].ToString ().Replace ("\"","'") + "\"\r\n");
3、显示Excel文件
sb.Append ("xls.visible=true\r\n");
4、釋放創建的Excel
application對象
sb.Append
("set xls=nothing\r\n");
sb.Append
("-->");
sb.Append
("</script>");
5、將代碼寫到客戶端
this.Page.RegisterClientScriptBlock("",sb.ToString ());
二、在服務端操作Excel文件
服務端操作Excel文件,是把Excel文件看作數據庫,把Excel工作表當作數據表
1、創建連接並打開連接
protected
System.Data .OleDb.OleDbConnection dbcnn;
cnnstr="Provider=Microsoft.Jet.OLEDB.4.0;Extended
Properties=\"Excel 8.0;HDR=Yes;\";Data Source=C:\\MyExcel.xls”;
dbcnn=new
OleDbConnection (cnnstr);
dbcnn.Open
();
2、創建OleDbCommand對象用來操作Excel文件
protected
System.Data .OleDb .OleDbCommand dbcmd;
dbcmd=new
OleDbCommand();
dbcmd.Connection =dbcnn;
3、操作Excel文件
//获得要操作数据表的行、列数
rows=dt.Rows.Count
;
cols=dt.Columns.Count-1 ;
//按行列将数据写入Excel文件Sheet1工作表
for(int i=0;i<rows;i++)
{
olestr="
insert into [Sheet1$] values(";
for(int
j=0;j<cols;j++)
olestr=olestr+"'"+dt.Rows[i][j].ToString
()+"',";
olestr+="'"+Convert.ToDecimal
(dt.Rows[i][cols].ToString ())+"')";
dbcmd.CommandText =olestr;
dbcmd.ExecuteNonQuery ();
}
4、釋放OleDbCommand對象、關閉連接
dbcmd.Dispose
();
dbcnn.Close
();
5、可操作的SQL語句
//建立名為punchdate的工作表,並指明子段類型。
//創建工作表好處是可指定子段類型,否則都以字符串導出
CREATE TABLE
punchdate(mno char(5), punchNum float)
//插入新數據
Insert into
punchdate(mno,punchNum) values(‘09’,9000)
//更新數據
Update
punchdate set punchNum=8000 where mno=’09’
6、不可操作的SQL語句
Delete from
punchdate
7、注意連接子串
//HDR=Yes
説明工作表第一行為子段名
"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel
8.0;HDR=Yes;\";Data Source=C:\\MyExcel.xls”
//HDR=No
説明工作表沒有含子段名的行
"Provider=Microsoft.Jet.OLEDB.4.0;Extended
Properties=\"Excel 8.0;HDR=No;\";Data Source=C:\\MyExcel.xls”
8、注意對Web.config的設置
刪除以下項目
<identity
impersonate="true" />
或者這樣設置
<identity
impersonate="false" />
三、兩種方法的優缺點
操作Excel文件方法
優點
缺點
客戶端
數據導入到Excel文件時,很靈活,可將數據填入任意指定的存儲格,定位到任意位置
1、在客戶端生成ActiveX控件,要將站點設置成可信站點或對IE進行安全設置(降低了IE的安全性)
2、對調用的Excel模板文件,用戶要有權讀寫
3、在客戶端寫Excel文件速度比較慢
服務端
1、對調用的Excel模板文件,只要ASP.NET有權讀寫即可
2、在服務端寫Excel文件速度比較快
3、不要對IE進行特別設置
對操作的文件只能當作數據庫操作,不夠靈活
四、流输出
原理:把數據填充到
DataGrid,然後把DataGrid内容放到一個輸出流裏面,並指定輸出流類型為
Excel
System.IO .StringWriter
sw =new System.IO.StringWriter();//字符串流
System.Web
.UI .HtmlTextWriter hw =new System.Web.UI.HtmlTextWriter(sw);//html
流,用字符串流作參數
dg.RenderControl(hw);//把DataGrid
流變成字符串流。
Response.ContentType
="application/vnd.ms-excel";//定義輸出流類型為
excel 流。關鍵語句。
Response.ContentEncoding=System.Text.Encoding.GetEncoding("Big5");//指定編碼類型為大五碼
Response.Write(sw.ToString());//輸出流
Response.End();//結束
2008年3月17日 星期一
使用智慧段落選取-不夠智慧[=白癡]
這時,就要拿出摳男的看家本領,在死不要錢的Google上找到解法:
到 工具-選項-編輯-使用智慧段落選取,將打勾拿掉就可以了。
Ref: http://office.microsoft.com/zh-tw/word/HA102362181028.aspx
2008年3月11日 星期二
IE 與 FireFox 開窗 討論
經測試,FireFox目前是沒辦法用獨占視窗開啟的。
參考:
http://blog.blueshop.com.tw/ajun/archive/2006/08/29/36797.aspx
使用這種開窗方式,要在 aspx 頁面 或是 Master 頁面加上
<% Response.Expires = 0; %>
不讓IE儲存網頁,不然會讀不到最新版異動