标题:c#由浅入深代码
取消只看楼主
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
检测服务器开放的端口信息

经过无数次的反复验证与修改终于诞生了这篇帖子(鼓掌)
王杰友情提示:
首先导入system.io与system.net.sockets命名空间

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Net.Sockets;
using System.IO;

namespace 再次检测服务器开放端口的信息
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Panel Panel1;

private void Page_Load(object sender, System.EventArgs e)
{
int[] arrPort=new int[5]{21,23,25,110,1433};
string strServer="localhost";
string strService,strResponse,strShow;
int intPort;
for(int i=0;i<arrPort.Length;i++)
{
intPort=arrPort[i];
switch(intPort)
{
case 21:
strService="FTP服务"; break;
case 23:
strService="Telnet服务"; break;
case 25:
strService="SMTP服务"; break;
case 110:
strService="POP3服务"; break;
default:
strService="无法知道"; break;
}
if ((strResponse=TcpConnect(strServer,intPort))!="没有开放")
{
strShow="<b>"+intPort.ToString()+"</b>端口:"+"</font>";
}
else
{
strShow="<b>"+intPort.ToString()+"</b>端口没有开放"+"(<font color=red>)"+strService+"</font>";
}
Panel1.Controls.Add(new LiteralControl(strShow+"<p>"));
}


}
public string TcpConnect(string strServer,int intPort)
{
string strResult;
TcpClient tcpc=new TcpClient();
try
{
tcpc.Connect(strServer,intPort);
Stream s=tcpc.GetStream();
StreamReader sr=new StreamReader(s);
strResult=sr.ReadLine();
}
catch(Exception ee)
{
strResult="没有开放";
}
finally
{
tcpc.Close();
}
return strResult;
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}


http://zdrjwlb.bulo. QQ群:1659819
2005-11-23 15:05
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
浏览器中的文件列表

版主手迹:
经过反复的修改测试,终于诞生了此帖子,于是心里无限感慨,中国的程序员怎么了???
错误无处不在!汗!
由于需要用到system.io所以需要提前导入,以后这点要时刻注意,程序到底都用到那些命名空间,我已经整理好相关的资料,将在有时间后一并发出来共享。呵呵
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.IO;

namespace 浏览器中的文件列表2
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label Label1;
protected System.Web.UI.WebControls.Table Table1;

private void Page_Load(object sender, System.EventArgs e)
{
string strCurrentDir=Server.MapPath(".");
Label1.Text=strCurrentDir;
FileInfo fi;
DirectoryInfo di;
TableCell tc;
TableRow tr;

string FileName; //文件名称
string FileExt; //文件扩展名
long FileSise; //文件大小
DateTime FileModify; //文件更新时间
DirectoryInfo dir=new DirectoryInfo(strCurrentDir);
foreach(FileSystemInfo fsi in dir.GetFileSystemInfos())
{
FileName ="";
FileExt="";
FileSise=0;
if (fsi is FileInfo)
//表示当前fsi是文件
{
fi=(FileInfo)fsi;
FileName=fi.Name; //文件名称
FileExt=fi.Extension; //文件扩展名称
FileSise=fi.Length; //获取当前文件的大小
FileModify=fi.LastWriteTime; //或许上次写入当前目录的时间
//通过扩展名来选择文件显示图标
}
else
{
//当前为目录
di=(DirectoryInfo)fsi;
FileName=di.Name;
FileModify=di.LastWriteTime;
}
//组建新的行
tr=new TableRow();
tc=new TableCell();
tc.Controls.Add(new LiteralControl(FileName.ToString()));
tr.Cells.Add(tc);
tc=new TableCell();
tc.Controls.Add(new LiteralControl(FileSise.ToString()));
tr.Cells.Add(tc);
tc=new TableCell();
tc.Controls.Add(new LiteralControl(FileModify.ToString()));
tr.Cells.Add(tc);
Table1.Rows.Add(tr);

}
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}

[此贴子已经被作者于2005-11-23 15:58:26编辑过]


http://zdrjwlb.bulo. QQ群:1659819
2005-11-23 15:57
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
connection对象介绍

王杰友情提示:
首先导入system.data跟system.data.oledb
如果是sqlserver的话应该导入using System.Data.SqlClient
具体问题具体分析吧以后不再提示!
首先我们从access的开始介绍,以后会陆续为大家介绍sqlserver的强大的功能,耐心等待吧!
下面是范例使用了2个label分别显示数据库的2中不同状态!
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;

namespace WebApplication8
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label Label2;
protected System.Web.UI.WebControls.Label Label1;

private void Page_Load(object sender, System.EventArgs e)
{
OleDbConnection conn=new OleDbConnection();
conn.ConnectionString="provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("db1.mdb");
conn.Open();
Label1.Text=conn.State.ToString();
conn.Close();
Label2.Text=conn.State.ToString();
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}


http://zdrjwlb.bulo. QQ群:1659819
2005-11-23 17:23
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
ExecuteScalar方法

ExecuteScalar方法返回单个值,用来执行聚合函数。
下面是利用ExecuteScalar方法执行avg聚合函数的SQL语句

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;
namespace ExecuteScalar方法
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label Label1;

private void Page_Load(object sender, System.EventArgs e)
{
OleDbConnection conn=new OleDbConnection();
conn.ConnectionString="provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("db1.mdb");
conn.Open();
String strSql="select avg(数学) from table1";
OleDbCommand comm=new OleDbCommand(strSql,conn);
Double d=(Double)comm.ExecuteScalar();
Label1.Text="所有人数学的平均成绩为"+d.ToString()+"分";
conn.Close();
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}


http://zdrjwlb.bulo. QQ群:1659819
2005-11-25 16:42
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
ExecuteScalar方法

ExecuteScalar方法返回单个值,用来执行聚合函数。
下面是利用ExecuteScalar方法执行avg聚合函数的SQL语句

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;
namespace ExecuteScalar方法
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label Label1;

private void Page_Load(object sender, System.EventArgs e)
{
OleDbConnection conn=new OleDbConnection();
conn.ConnectionString="provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("db1.mdb");
conn.Open();
String strSql="select avg(数学) from table1";
OleDbCommand comm=new OleDbCommand(strSql,conn);
Double d=(Double)comm.ExecuteScalar();
Label1.Text="所有人数学的平均成绩为"+d.ToString()+"分";
conn.Close();
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}


http://zdrjwlb.bulo. QQ群:1659819
2005-11-25 16:43
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
ExecuteNonQuery方法

ExecuteNonQuery方法用于执行不需要返回结果的命令,比如DDL、DML和DCL等。
下面是ExecuteNonQuery方法的使用范例:

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;

namespace ExecuteNonQuery方法
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
private void Page_Load(object sender, System.EventArgs e)
{
OleDbConnection conn=new OleDbConnection();
conn.ConnectionString="provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("db1.mdb");
conn.Open();
string strSql="insert into table1(姓名,语文,数学,英语) values('王杰',99,99,99)";
OleDbCommand comm=new OleDbCommand(strSql,conn);
comm.ExecuteNonQuery();
conn.Close();
Response.Write("操作成功!");
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}


http://zdrjwlb.bulo. QQ群:1659819
2005-11-25 16:45
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
command对象之ExecuteREader方法

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;


namespace command对象
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.DataGrid DataGrid1;

private void Page_Load(object sender, System.EventArgs e)
{
OleDbConnection conn=new OleDbConnection();
conn.ConnectionString="provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("db1.mdb");
conn.Open();
OleDbCommand comm=new OleDbCommand("select * from table1",conn);
OleDbDataReader dr=comm.ExecuteReader();
DataGrid1.DataSource=dr;
DataGrid1.DataBind();
conn.Close();
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}


http://zdrjwlb.bulo. QQ群:1659819
2005-11-25 16:45
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
使用like子句实现模糊查询

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;


namespace command对象
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.TextBox TextBox1;
protected System.Web.UI.WebControls.Label Label1;
protected System.Web.UI.WebControls.Button Button1;
protected System.Web.UI.WebControls.Label Label2;
protected System.Web.UI.WebControls.DataGrid DataGrid1;

private void Page_Load(object sender, System.EventArgs e)
{
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Button1.Click += new System.EventHandler(this.Button1_Click);
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion

private void Button1_Click(object sender, System.EventArgs e)
{
OleDbConnection conn=new OleDbConnection();
conn.ConnectionString="provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("db1.mdb");
conn.Open();
string sql="select * from table1";
if (TextBox1.Text!="")
sql="select * from table1 where 姓名 like '%+TextBox1.Text+%'";
Label2.Text=sql;
OleDbCommand comm=new OleDbCommand(sql,conn);
OleDbDataReader dr=comm.ExecuteReader();
DataGrid1.DataSource=dr;
DataGrid1.DataBind();
conn.Close();

}
}
}


http://zdrjwlb.bulo. QQ群:1659819
2005-11-25 16:46
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
DataReader对象

DataReader对象用于从数据库中获得仅向前的只读数据流,由于在内存一次只存放一行数据,因此使用DataReader对象可提高应用程序的性能,大幅度减轻对内存的需求。
下面是DataReader对象的使用范例:

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;

namespace DataReader对象
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
private void Page_Load(object sender, System.EventArgs e)
{
OleDbConnection conn=new OleDbConnection();
conn.ConnectionString="provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("db1.mdb");
conn.Open();
string strSql="select * from table1";
OleDbCommand comm=new OleDbCommand(strSql,conn);
OleDbDataReader dr=comm.ExecuteReader();
string html="<Table border=1>";
html+="<Tr>";
html+="<td><b></b>姓名</td>";
html+="<td><b></b>语文</td>";
html+="<td><b></b>数学</td>";
html+="<td><b></b>英语</td>";
html+="</tr>";
try
{
while(dr.Read())
{
html+="<tr>";
html+="<td>"+dr["姓名"].ToString()+"</td>";
html+="<td>"+dr["语文"].ToString()+"</td>";
html+="<td>"+dr["数学"].ToString()+"</td>";
html+="<td>"+dr["英语"].ToString()+"</td>";
html+="</tr>";
}
html+="</table>";
}
finally
{
dr.Close();
conn.Close();
}
Response.Write(html);
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}


http://zdrjwlb.bulo. QQ群:1659819
2005-11-25 16:47
王杰
Rank: 2
等 级:新手上路
威 望:4
帖 子:307
专家分:0
注 册:2005-5-13
得分:0 
DataAdapter对象

DataAdapter对象用于从数据源中获取数据、填充dataset中的表并将对dataset的更改提交回数据源。dataadapter对象有4个重要属性:selectcommand、insertcommand、updatecommand、deletecommnd,这4个属性都是command对象。其中selectcommand用来执行查询,其他的3个用于执行数据操作。
下面是DataAdapter对象的使用范例:


using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.OleDb;

namespace DataAdapter对象
{
/// <summary>
/// WebForm1 的摘要说明。
/// </summary>
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.DataGrid DataGrid1;

private void Page_Load(object sender, System.EventArgs e)
{
OleDbConnection conn=new OleDbConnection();
conn.ConnectionString="provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("db1.mdb");
string sql="select * from table1";
conn.Open();
OleDbDataAdapter da=new OleDbDataAdapter(sql,conn);
DataSet ds=new DataSet();
da.Fill(ds,"table1");//table1是相对应的数据库中的表名
DataGrid1.DataSource=ds.Tables["table1"].DefaultView;
DataGrid1.DataBind();
conn.Close();
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion
}
}



http://zdrjwlb.bulo. QQ群:1659819
2005-11-25 16:47



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-34505-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.128783 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved