要是一开机windows下分区显示在linux桌面上,那该多爽,下面就介绍自动装载Windows下的分区 的方法

编辑 /etc/fstab 就可实现启动后自动装载windows下的分区,具体操作如下:

查看分区信息 sudo fdisk -l

查看分区uuid信息:ls -all /dev/disk/by-uuid

编辑fstab:sudo gedit /etc/fstab

我只是在后面加上了一行
/dev/sda6    /media/cdrom_e   ntfs   user,auto,rw,umask=002,gid=1000,utf8   0   0

重启就成功加载D盘了,下面的是解释这些代码的,大家看看就会了(注意必须提前在media下建立文件夹用来装载分区内容,我建立的就是cdrom_e)

 

用vi编辑/ect/fstab文件,然后加入要启动时装载的Windows分区,如:

/dev/hdc1 /mnt/c vfat defaults 0 0
/dev/hdc5 /mnt/d vfat defaults 0 0

fstab栏位说明:

第一栏(fs_spec):实际的device 名称
第二栏(fs_file):对应到的目录结构(mount point)
第三栏(fs_vfstype):该 partition 的档案系统,常见的有:minix、ext、ext2、msdos、iso9660、nfs、swap(vfat指的是fat32格式)
第四栏(fs_mntops):在mount时的参数
第五栏(fs_freq):在使用dump时是否记录,不需要则输入0
第六栏(fs_passno):决定在开机时执行fsck的先后顺序

例子 :
IDE 硬盘分成两个 partition 与一个 swap,还有一台光碟机跟一台软碟机的情形 :

-------------------------------------------

说明:从做到右1~6列
1、 /dev/device,不用说了吧, 如:/dev/hda1为ms-win9x下的c:盘

2、mount-point,如:将/dev/hda1挂到/mnt/c下

3、type: ext3, vfat, ……

4、rules:
      auto: 开机自动挂接
      default, noauto开机不自动挂接
      nouser: 只有root可挂
      ro:只读挂接
      rw:可读可写挂接
      user:任何用户都可以挂接

5、dump:备份,
          0:从不备份,或现实上次至今的备份的天数

6、fsck: 启动时fsck检查顺序,
          0:不检查
          “/”永远为1

例如,在我的系统启动时自动挂接ms-win98se的c:盘,应该加入:
/dev/hda1   /mnt/mywinc/   vfat defaults rw iocharset=cp936

--------------------------------------------

/dev/hda1 / ext2 defaults 1 1
/dev/hda5 /home ext2 defaults 1 2
/dev/cdrom /mnt/cdrom iso9660 noauto,user,ro 0 0
/dev/hda6 swap swap defaults 0 0
/dev/fd0 /mnt/floppy ext2 noauto,owner 0 0
none /proc proc defaults 0 0
none /dev/pts devpts gid=5,mode=620 0 0

如果要在linux起动的时候挂载windows的分区可以加入这样一行:
/dev/hda1        /mnt/winC        auto iocharset=utf8,umask=0,noatime 0 0
/dev/hda5        /mnt/winD        auto iocharset=utf8,umask=0,noatime 0 0
/dev/hda6        /mnt/winE        auto iocharset=utf8,umask=0,noatime 0 0

utf8是对中文的支持,使用这个参数可以保证在访问中文文件夹的时候不出错误.

1.C#连接连接Access
程序代码:
——————————————————————————-
using System.Data;
using System.Data.OleDb;

……

string strConnection="Provider=Microsoft.Jet.OleDb.4.0;";
strConnection+=@"Data Source=C:\BegASPNET\Northwind.mdb";

OleDbConnection objConnection=new OleDbConnection(strConnection);

……

objConnection.Open();
objConnection.Close();

……

——————————————————————————–

解释:

连接Access数据库需要导入额外的命名空间,所以有了最前面的两条using命令,这是必不可少的!

strConnection这个变量里存放的是连接数据库所需要的连接字符串,他指定了要使用的数据提供者和要使用的数据源.

"Provider=Microsoft.Jet.OleDb.4.0;"是指数据提供者,这里使用的是Microsoft Jet引擎,也就是Access中的数据引擎,asp.net就是靠这个和Access的数据库连接的.

"Data Source=C:\BegASPNET\Northwind.mdb"是指明数据源的位置,他的标准形式是"Data Source=MyDrive:MyPath\MyFile.MDB".

PS:
1."+="后面的"@"符号是防止将后面字符串中的"\"解析为转义字符.
2.如果要连接的数据库文件和当前文件在同一个目录下,还可以使用如下的方法连接:
strConnection+="Data Source=";
strConnection+=MapPath("Northwind.mdb");
这样就可以省得你写一大堆东西了!
3.要注意连接字符串中的参数之间要用分号来分隔.

"OleDbConnection objConnection=new OleDbConnection(strConnection);"这一句是利用定义好的连接字符串来建立了一个链接对象,以后对数据库的操作我们都要和这个对象打交道.

"objConnection.Open();"这用来打开连接.至此,与Access数据库的连接完成.
——————————————————————————–

2.C#连接SQL Server
程序代码:
——————————————————————————–

using System.Data;
using System.Data.SqlClient;

string strConnection="user id=sa;password=;";
strConnection+="initial catalog=Northwind;Server=YourSQLServer;";
strConnection+="Connect Timeout=30";

SqlConnection objConnection=new SqlConnection(strConnection);

objConnection.Open();
objConnection.Close();

——————————————————————————–

解释:

连接SQL Server数据库的机制与连接Access的机制没有什么太大的区别,只是改变了Connection对象和连接字符串中的不同参数.

首先,连接SQL Server使用的命名空间不是"System.Data.OleDb",而是"System.Data.SqlClient".

其次就是他的连接字符串了,我们一个一个参数来介绍(注意:参数间用分号分隔):
"user id=sa":连接数据库的验证用户名为sa.他还有一个别名"uid",所以这句我们还可以写成"uid=sa".
"password=":连接数据库的验证密码为空.他的别名为"pwd",所以我们可以写为"pwd=".
这里注意,你的SQL Server必须已经设置了需要用户名和密码来登录,否则不能用这样的方式来登录.如果你的SQL Server设置为Windows登录,那么在这里就不需要使用"user id"和"password"这样的方式来登录,而需要使用"Trusted_Connection=SSPI"来进行登录.
"initial catalog=Northwind":使用的数据源为"Northwind"这个数据库.他的别名为"Database",本句可以写成"Database=Northwind".
"Server=YourSQLServer":使用名为"YourSQLServer"的服务器.他的别名为"Data Source","Address","Addr".如果使用的是本地数据库且定义了实例名,则可以写为"Server=(local)\实例名";如果是远程服务器,则将"(local)"替换为远程服务器的名称或IP地址.
"Connect Timeout=30":连接超时时间为30秒.

在这里,建立连接对象用的构造函数为:SqlConnection.
——————————————————————————–

3.C#连接Oracle
程序代码:
——————————————————————————–

using System.Data.OracleClient;
using System.Data;

//在窗体上添加一个按钮,叫Button1,双击Button1,输入以下代码
private void Button1_Click(object sender, System.EventArgs e)
{
string ConnectionString="Data Source=sky;user=system;password=manager;";//写连接串
OracleConnection conn=new OracleConnection(ConnectionString);//创建一个新连接
try
{
conn.Open();
OracleCommand cmd=conn.CreateCommand();

cmd.CommandText="select * from MyTable";//在这儿写sql语句
OracleDataReader odr=cmd.ExecuteReader();//创建一个OracleDateReader对象
while(odr.Read())//读取数据,如果odr.Read()返回为false的话,就说明到记录集的尾部了
{
Response.Write(odr.GetOracleString(1).ToString());//输出字段1,这个数是字段索引,具体怎么使用字段名还有待研究
}
odr.Close();
}
catch(Exception ee)
{
Response.Write(ee.Message); //如果有错误,输出错误信息
}
finally
{
conn.Close(); //关闭连接
}
}

——————————————————————————–

4.C#连接MySQL
程序代码:
——————————————————————————–

using MySQLDriverCS;

// 建立数据库连接
MySQLConnection DBConn;
DBConn = new MySQLConnection(new MySQLConnectionString("localhost","mysql","root","",3306).AsString);
DBConn.Open();

// 执行查询语句
MySQLCommand DBComm;
DBComm = new MySQLCommand("select Host,User from user",DBConn);

// 读取数据
MySQLDataReader DBReader = DBComm.ExecuteReaderEx();

// 显示数据
try
{
while (DBReader.Read())
{
Console.WriteLine("Host = {0} and User = {1}", DBReader.GetString(0),DBReader.GetString(1));
}
}
finally
{
DBReader.Close();
DBConn.Close();
}

//关闭数据库连接
DBConn.Close();

——————————————————————————–

5.C#连接IBM DB2
程序代码:
——————————————————————————–

OleDbConnection1.Open();
//打开数据库连接
OleDbDataAdapter1.Fill(dataSet1,"Address");
//将得来的数据填入dataSet
DataGrid1.DataBind();
//绑定数据
OleDbConnection1.Close();
//关闭连接

//增加数据库数据
在Web Form上新增对应字段数量个数的TextBox,及一个button,为该按键增加Click响应事件代码如下:

this.OleDbInsertCommand1.CommandText = "INSERTsintosADDRESS(NAME,
EMAIL, AGE, ADDRESS) valueS
(”"+TextBox1.Text+"”,”"+TextBox2.Text+"”,”"+TextBox3.Text+"”,”"+TextBox4.Text+"”)";
OleDbInsertCommand1.Connection.Open();
//打开连接
OleDbInsertCommand1.ExecuteNonQuery();
//执行该SQL语句
OleDbInsertCommand1.Connection.Close();
//关闭连接

——————————————————————————–

6.C#连接SyBase
程序代码: (OleDb)
——————————————————————————–

Provider=Sybase.ASEOLEDBProvider.2;Initial Catalog=数据库名;User ID=用户名;Data Source=数据源;
Extended Properties="";Server Name=ip地址;Network Protocol=Winsock;Server Port Address=5000;

用C#连接SQL 2000数据库,怎样用Windows身份验证模式连接数据库
adoconnection1.string:=’Provider=SQLOLEDB.1;Integrated Security=SSPI;Initial Catalog=ls;Data Source=BLUEBOY;’//这样就可以了
其中:’Provider=SQLOLEDB.1;为驱动程序
Integrated Security=SSPI;为集中登录模式
Initial Catalog=ls;/要访问的数据名
Data Source

一般,当我们在本机调试ASP动态网页时,可输入
http://localhost
http://本地计算机名
http://127.0.0.1

在当输入http://127.0.0.1 时,一般机器都需要输入用户名和密码进入,这里将分两种情况:

一种是刚新建IIS的,为了测试IIS,所以此时访问即是“系统盘\Inetpub\wwwroot”下的iisstart.asp,随之iisstart.asp又跳转到localstart.asp,并同时打开iishelp的。“localhost”、“计算机名”都没问题,但输入127.0.0.1时,弹出对话框,需要输入帐户和密码。

第二种情况是,建立了虚拟目录,通过“localhost+虚拟目录”和“计算机名+虚拟目录”都能访问,同样是“127.0.0.1+虚拟目录”不能访问.

 

虽然同是相同的症状,但却是不同的情况。

首先,先抛出第一条总的要诀:要使得输入http://127.0.0.1   能访问,无论直接访问,还是虚拟目录,必须确保“匿名访问”的打开。

那么现在就能快速解决第二种情况的问题,如下图的操作:打开IIS,在“默认站点”上右键,弹出菜单选择“属性”,打开面板,选择“目录安全”进行“编辑”,此时,如果“匿名访问”前没有勾选,选择勾选,“确定”就能解决这个问题。

此时访问 “127.0.0.1+虚拟目录的” 第二种已经解决

 

不过这个问题,遇到的人比较少,并且就这样简简单单的勾选了还不算回事,再往下看。

此时单独测试 127.0.0.1 虽然也没有了要求密码输入对话框,但新的问题出现了,同样,此刻输入http://localhost 同样的是如此的错误,这也就是很多人反馈的

错误类型:
Microsoft VBScript 运行时错误 (0x800A0046)
没有权限: ‘GetObject’
/localstart.asp, 第 40 行

 

那么现在就先停在这,分析下原因

开始没有“匿名访问”,需要提供帐户密码;现在有了“匿名访问”,则出现了错误。注意!这是针对直接 127.0.0.1 访问而言的。

那么“匿名访问”就是提供的帐户和密码,才使得“127.0.0.1+虚拟目录”的问题得到解决,当然也解决了直接“127.0.0.1”访问的部分问题(不需要帐号密码了)

说明这个“匿名帐户”是有用的。

但现在要解决这个新出来的问题:Microsoft VBScript 运行时错误 (0x800A0046) 没有权限: ‘GetObject’

通常被提供的方法是:单独对“iisstart.asp”和“localstart.asp”取消“匿名访问”

等等,再好好看,我没有打错字

要解决“(0x800A0046) 没有权限: ‘GetObject’”的方案是“单独”对这两个文件进行取消“匿名访问”

具体操作流程:在IIS中选择“localstart.asp”文件,右键,弹出菜单选择“属性”,打开面板,选择“文件安全性”进行“编辑”,取消“匿名访问”访问前的选择.

 

同样的操作流程对“iisstart.asp”再进行一般。

那么现在“http://localhost ”已经能访问,解决了Microsoft VBScript 运行时错误 (0x800A0046) 没有权限: ‘GetObject’的问题。

到此,再来分析下:

1,要使得127.0.0.1能访问必须要设置“匿名访问”
2,要使得“iisstart.asp”和“localstart.asp”能正常访问,必要要单独设置取消“匿名访问”

经过了如上设置后,localhost,localhost+虚拟目录,127.0.0.1+虚拟目录都能正常访问,就剩下单独的 127.0.0.1 访问的情况,以上的分析似乎又是相矛盾的

那么,再来看看这“匿名访问”到底是个什么?

用户名是“BLUECOM\IUSR_BLUECOM”,密码是IIS控制的。其中“BLUECOM”是我这台机器的“计算机名”,各人是不同的。那么“IUSR_BLUECOM”就是“IUSR_计算机名”了。

这个“IUSR_计算机名”又是什么?它是一个“Internet来宾帐户”,是“匿名访问IIS的内置的帐户”,他是属于“Guests”组的

这就又回到当使用该帐户时,localhost会显示“(0x800A0046) 没有权限”,这似乎有点关系。

 

那么,我最终的比较完美的方案则是,全部采用“匿名访问”,确保所有的页面都能访问而没有密码输入框,同时,将“匿名访问”的帐户替换掉,不使用“IUSR_计算机名”帐户,而是使用我的XP管理员登录帐号。

于是重头继续调整,打开IIS,在“默认站点”上右键,弹出菜单选择“属性”,打开面板,选择“目录安全”进行:

1,“编辑”
2,“浏览”用户
3,“高级”
4,“查询”用户
5,“选择”本机XP登录用户名
6,“确定”,一直“确定”到最后

 

另外,在更新的时候有一点很重要,就是要选择“继承覆盖”两个文件“iisstart.asp”和“localstart.asp”,否则就需要单独把这两个文件的“匿名访问”重新加上,加上的帐号为刚才设置的XP登录帐号
 
 

Asp.Net防止刷新重复提交数据小记2008-09-22 16:16最近在用Asp.Net编写点东西时遇到个问题:即用户在提交表单后按刷新就会重复提交数据,即所谓的“刷新重复提交”的问题。在网上搜 一下,可以找到很多关于这方面的资料,其中有一篇是来自MSDN上的一种解决方法: http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnvs05/html/BedrockASPNET.asp 它是通过重新定义 System.Web.UI.Page 类来实现加载页面时,是“刷新”、“后退”请求,还是正常请求,其他的页面则继承了自定义的这 个Page类。感觉他这个方法比较独特,有例子可以下载,有兴趣的可以研究研究。

网上最多的解决此类问题的方法就是不保存缓存,即提交后表单上的数据不会被浏览器的缓存保存,如果此时再遇到刷新或者后退请求时, 就会显示“网页已过期”,数据也就不会重复提交了,这就起到了阻止刷新重复提交的效果。

下面以简单的提交一篇帖子为例,介绍禁用缓存防止刷新重复提交的方法,表单数据包括“标题”和“正文”两个部分。

以下是该方法的代码(post.aspx):

//页面加载

protected void Page_Load(object sender, EventArgs e)

{

   //可以在页面加载时设置页面的缓存为“SetNoStore()”,即无缓存

   Response.Cache.SetNoStore();

   //Session中存储的变量“IsSubmit”是标记是否提交成功的

   if ((bool)Session["IsSubmit"])

   {

     //如果表单数据提交成功,就设“Session["IsSubmit"]”为false

     Session["IsSubmit"] = false;

     //显示提交成功信息

     ShowMsg.Text = " * 提交成功!";

   }

   else

     //否则的话(没有提交,或者是页面刷新),不显示任何信息

     ShowMsg.Text = "";

}

//提交按钮(btnOK)单击事件

protected void btnOK_Click(object sender, EventArgs e)

{

   if (txtTitle.Text.ToString().Trim() == "")

     //ShowMsg是用来显示提示信息的

     ShowMsg.Text = " * 标题不能为空!";

   else if (txtText.Text.ToString().Trim() == "")

     ShowMsg.Text = " * 内容不能为空!";

   else

   {

     //这里是将数据提交到数据库中,省略

     /*

     string sql = "insert into tab…values(…)";

     MyConn.ExecQuery(sql);

     */

     //提交成功后,设“Session["IsSubmit"]”为true

     Session["IsSubmit"] = true;

     //强制转换页面(不可少,否则刷新仍会重复提交,仍转到本页),

     通过页面的转换将缓存中的提交的数据都释放了,即提交的标单数据不会被保存到缓存里,

     如果后退的话,将会出现该页无法显示

     Response.Redirect("post.aspx");

   }

}

上面这个方法非常简单也很实用,推荐大家使用。

下面是我自己研究出来的另一种方法,该方法不同于“不保存缓存的方法”,它是让浏览器保存所有页面缓存的。该方法通过随机码的方式 来判断是正常提交还是“刷新”或“后退”的。

首先(提交页面是post.aspx)在 Session 中 增加变量 Rnd 用来存放随机码,同时在提交表单数据时不做处理,而是让页面转到 post.aspx?r=x,这里“x”等于Session["Rnd"],这个时候在页面加载时,通过判断r的值和Session["Rnd"]的值是否相同,如果相同就处理提 交的数据,否则即可认为是“刷新”或者是“后退”操作了,最后再次付给Session["Rnd"]一个随机码。

以下是该方法代码(post.aspx):

//获取随机码

public class MyRnd

{

   public static string Rnd()

   {

     //随机码是由 0-9 a-z A-Z 之间的数字或字母组成的

     //下面是生成的20位随机码

     //0..9 A..Z a..z

     //48-57 65-90 97-122

     string rst = "";

     Random rr = new Random();

     for (int i = 0; i < 20; i++)

     {

       int ir = 0;

       do

       {

         ir = rr.Next(123);

         if((ir >= 48) && (ir <= 57)) break;

         else if((ir >= 65) && (ir <= 90)) break;

         else if ((ir >= 97) && (ir <= 122)) break;

       }

       while (true);

       rst += ((char)ir).ToString();

       }

     return rst;

   }

}

//页面加载

protected void Page_Load(object sender, EventArgs e)

{

   //获取URL中请求的“r”值,如果“r”不存在则 r=""

   string r = "";

   if(Request.QueryString["r"] != null)

     r = Request.QueryString["r"].ToString().Trim();

   string t;

   //获取 “Session” 中的 “Rnd” 值,用于和“r”比较

   t = Session["Rnd"].ToString().Trim();

   //如果“r=t”则为提交操作,即可对表单的数据进行处理

   if(r == t)

   {

     if (txtTitle.Text.ToString().Trim() == "")

       ShowMsg.Text = " * 标题不能为空!";

     else if (txtText.Text.ToString().Trim() == "")

       ShowMsg.Text = " * 内容不能为空!";

     else      {

       //这里是将数据提交到数据库中,省略

       /*

       string sql = "insert into tab…values(…)";

       MyConn.ExecQuery(sql);

       */

       //提交成功后清空表单数据

       txtTitle.Text = "";

       txtText.Text = "";

       //显示提交成功信息

       ShowMsg.Text = " * 提交成功!";

     }

   }

   //否则可以认为是“刷新”或者“后退”操作

   else

   {

       txtTitle.Text = "";

       txtText.Text = "";

   }

   //最后要重新获得“Session["Rnd"]”的值,并将“btnOK.PostBackUrl”设为“Session["Rnd"]”的值

   Session["Rnd"] = MyRnd.Rnd();

   btnOK.PostBackUrl ="post.aspx?r=" + Session["Rnd"].ToString().Trim();

}

//这里提交按钮(btnOK)单击事件就不需要写任何代码了

通过这种方法,每次加载页面时“Session["Rnd"]”都将得到一个新的值,而在刷新或后退时就不会得到相同的“r”和“t”值,数据也就 不会被重复提交,只有通过“btnOK”来提交的操作才会得到“r==t”,数据才会被提交处理的,通过判断随机码的方式来阻止刷新重复提交就 可以实现了。

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Drawing;

public partial class validate : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if(!this.IsPostBack)
{
this.GenImg(this.GetCode(4));
}
}
//产生随机字符串
private string GetCode(int num)
{
string[] source={"1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","P","Q","R","S","T","U","V","W","X","Y","Z"};
string code="";
Random rd=new Random();
for(int i=0;i < num;i++)
{
code += source[rd.Next(0,source.Length)];
}
return code;
}

//生成图片
private void GenImg(string code)
{
Random rd = new Random();
Bitmap myPalette = new Bitmap(120, 60); //定义一个画板
Graphics gh = Graphics.FromImage(myPalette); //在画板上定义绘图的实例
Rectangle rc = new Rectangle(0, 0, 120, 60); //定义一个矩形
String picPath = Server.MapPath("pic/bg" + rd.Next(1,4).ToString().Trim() + ".jpg" );
Bitmap imagefile = (Bitmap)System.Drawing.Image.FromFile(picPath, true); //得到一张位图
TextureBrush texture = new TextureBrush(imagefile); //以图片建立绘图刷
Color[] fontcolor = { Color.Black, Color.Red, Color.DarkBlue, Color.Green, Color.Red, Color.Brown, Color.DarkCyan, Color.Purple }; //定义 8 种颜色
String[] fontname = { "Verdana", "System", "Comic Sans MS", "Arial", "宋体" }; //定义 5 种字体
Font myfont; //字体定义
SolidBrush mybrush; //画笔定义

gh.FillRectangle(texture, rc);//使用绘图刷填充矩形,到此得到图片背景

for (short i = 0; i <= code.Length – 1; i++)
{
myfont = new Font(fontname[rd.Next(0, 5)],30,FontStyle.Italic); //随机字体,42号,斜体
mybrush = new SolidBrush(fontcolor[rd.Next(0, 8)]); //随机颜色
gh.DrawString(code.Substring(i,1) , myfont, mybrush, 3 + (i * 23),rd.Next(1,8));//在矩形内画出字符串
}

 

myPalette.Save(Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg);//将图片显示出来

Session["ValidateCode"] = code;//将字符串保存到Session中,以便需要时进行验证

gh.Dispose();
myPalette.Dispose();
}
}

zblog自从升级到1.8版本后出现啦这个东西:"发布文章同时通知Ping中心"。
开能之前先搞明白几个问题:
一:什么是Ping服务?

首先,当你新发表了日志之后。最希望的baidu、google,Feed之类的爬虫在第一时间来更新对你的日志的收录。但是由于爬虫更新机制所限。baidu、google、Feed之类的爬虫不会在第一时间更新的,因此当开通了Ping服务后,爬虫会立即进行抓取并更新,这样就节约了等待爬虫的这段时间。

zblog里面的可以再插件管理里面加入一些ping服务的URL

如何在Windows Live Writer中开通Ping服务?

1。打开你的Windows Live Writer,选择工具–>选项–>Ping服务器
2。选中在向以下URL发送Ping命令
3。在下面的框中加入要发送Ping服务的URL,每行一个。

二:常用的Ping服务URL

http://www.feedsky.com/api/RPC2
http://ping.feedburner.com
http://rpc.technorati.com/rpc/ping
http://blogsearch.google.com/ping/RPC2
http://www.xianguo.com/xmlrpc/ping.php
http://www.bloglines.com/ping
http://blog.iask.com/ping.php
http://ping.blog.qikoo.com/rpc2.php
http://rpc.pingomatic.com/
http://api.my.yahoo.com/RPC2
http://api.my.yahoo.com/rss/ping

依次为:Feedsky,Feedburner,Technorati,Google博客搜索,鲜果,Bloglines阅读器,新浪博客搜索,奇虎博客搜索,Pingomatic的Ping服务,雅虎阅读器.抓虾貌似还没有Ping服务.更加完整的Ping服务地址载于Feedsky客服Src的博客:完美的ping通知.不推荐加入太多,因为会减慢文章发布速度。

1、C#是.net平台下支持较为完整的语言,天生就是为.NET平台服务的,C++在.NET平台下的支持相对就差一点,再加上如果进行托管代码的编写,托管 + C++ == 怪胎,C++天生的底层特性好像才.NET下水土不服,虽然现在有C++/CLI,但是到底有多大的价值,还不确定2、.NET的内存分配有专用的垃圾回收机制,不需要担心内存的泄漏问题,不知道是不是仅仅指在托管堆中分配的。编译时.NET平台将所有东西编译成IL的东西,然后通过一个编译器再去编译那个中间代码执行,感觉象解释语言,据说也更好破解了,中间代码基本上跟源代码差不多,总之肯定比汇编容易。3、C#中不再使用指针,也就是->不会在C#中出现,不过又搞出来一个delegate的东西,不明白4、C#中不存在全局变量,任何东西都要属于一个类,连main都在类里,还是这样子Main,看着怪怪的5、搞出来一个System.Console的东西来输出控制台的东西,而且格式化字符串好像只能格式化三个变量,还是习惯printf(StringCchPrint)来输出6、多了个decimal数据类型,来表示货币,暂时还没看出来方便到哪儿了。还多了byte类型表示一个字节,bool类型也只能用true和false来赋值拉,更规范一点。字符类型char来表示UNICODE的字符,代表两个字节了,感觉更怪,还是WChar习惯点7、发现一个转义字符’a’ (感叹号),不知道用来干嘛8、还有一个object的类,说所有的类型都是基类,感觉比较象variable类型。然后后边又说了一个装箱和拆箱,实际就是在进行拷贝构造,然后在进行值拷贝,暂时没看到有什么不一样。9、array的声明怪怪的,a[10][10]这样的不能用了??只能用int a[][]= new int[10][10]的样子??那种可动态生成数组长度的东西,好像只是定义了一个类似的数组指针嘛,还得new一下赋值10、is操作符和as操作符,is操作符进行类型判断;as用来进行类型转换,类似强制类型转换,区别是转换失败返回NULL,不产生异常11、它说new操作符进行实例的创建,并不一定暗示动态内存分配,跟C++的不同,没搞明白12、typeof返回系统原型对象的类型,看它的例子是返回个字符串13、checked 、unchecked,溢出检查,unchecked包含的表达式忽略溢出检查14、if语句的判断必须是布尔型,不能写if(int)的形式15、switch语句的每个case后边必须有break或者goto,带goto看着很奇怪。switch可以用字符串做为判断条件。16、一个怪怪的foreach语句,那个集合的意义还没有搞清楚17、域和属性,域跟c++的成员变量概念一样,属性定义get和set方法,使用的时候感觉很象这个变量就是public的,看着还是怪18、事件和索引器没看明白,事件有点象MFC的事件,但是事件是谁触发??如果是其它类显式的发消息出发事件,为什么不直接调用??感觉对方法也封装了一次,难道以后为了方便更改事件的处理方法???19、抽象类的声明方法,C#必须用abstract关键字,C++只要包含纯虚函数即可20、密封类防止类被继承,多此一举?保护知识产权? 密封方法防止方法被重载
C#跟C++差别还是挺大的,特别是接口的部分,至于语法也仅仅是轻微的调整

从学习难易的角度来看:C++较难。C#较容易些。但是,C#是典型的易学难精通,C++是难学易用的。(这句话可能有争议,但是楼主可以自己体会下)
从学习的用途来看:C#在RAD领域,可以说是无敌的。
C++在高性能的服务应用,无人可比。
C++中OO是最好的。掌握了它,C#和JAVA马上可以上手。

下表包含 C++ 和 C# 功能之间的重要比较。如果您是一位 C++ 程序员,此表将为您提供这两种语言的最重要差异。
注意 C++ 和 C# 项目派生于不同的项目模型。有关 C++ 和 C# 项目之间差异的信息,请参见项目中的项管理和使用解决方案资源管理器。
功能 参考主题
继承:类只能继承一个基类中的实现。另外,类或接口可以实现多个接口。

数组:声明 C# 数组和声明 C++ 数组的语法不同。在 C# 中,“[]”标记出现在数组类型的后面。
bool 类型:bool 类型和其他类型(特别是 int)之间没有转换。
long 类型:在 C# 中,long 数据类型为 64 位,而在 C++ 中为 32 位。
struct 类型:在 C# 中,类和结构在语义上不同。struct 是值类型,而 class 是引用类型。

switch 语句:与 C++ 中的 switch 语句不同,C# 不支持从一个 case 标签贯穿到另一个 case 标签。
delegate 类型:委托与 C++ 中的函数指针基本相似,但前者具有类型安全,是安全的。
从派生类调用重写基类成员。

使用 new 修饰符显式隐藏继承成员。
声明重写方法需要有 override 关键字。
预处理器指令用于条件编译。C# 中不使用头文件。
异常处理:使用 finally 语句。

C# 运算符:C# 支持其他运算符,如 is 和 typeof。它还引入了某些逻辑运算符的不同功能。

关键字 extern 的使用。
关键字 static 的使用。
在构造基类上替代 C++ 初始化列表的方法。
C# 程序的常规结构:命名空间、类、结构、委托和枚举。
Main 方法和 C++ 中的 main 函数的声明方式不同。
方法参数:C# 支持 ref 和 out 参数,这两个参数取代指针通过引用传递参数。

在 C# 中只在不安全模式下才使用指针。 unsafe
在 C# 中以不同的方式执行重载运算符。
字符串:C# 字符串不同于 C++ 字符串。 string
foreach 关键字使您得以循环访问数组和集合。 foreach, in
C# 中没有全局方法和全局变量:方法和变量必须包含在类型声明(如 class 或 struct)中。
C# 中没有头文件和 #include 指令:using 指令用于引用其他未完全限定类型名的命名空间中的类型。
C# 中的局部变量在初始化前不能使用。
析构函数:在 C# 中,不能控制析构函数的调用时间,原因是析构函数由垃圾回收器自动调用。
构造函数:与 C++ 类似,如果在 C# 中没有提供类构造函数,则为您自动生成默认构造函数。该默认构造函数将所有字段初始化为它们的默认值。

C# 不支持位域。 C++ 位域
C# 的输入/输出服务和格式设置依赖于 .NET Framework 的运行时库。

在 C# 中,方法参数不能有默认值。如果要获得同样的效果,请使用方法重载。