随笔 - 13, 文章 - 0, 评论 - 10, 引用 - 0
数据加载中……

2009年3月8日

[Biztalk]Hello world

Biztalk的描述这里就不粘贴了,我们都知道他可以进行数据交换,在这里做一个简单的文件监听、传送例子,也是我学习Biztalk的第一个Demo。

感谢我的同事地球人(http://www.cnblogs.com/cbcye/),我是在他的帮助下,看着他写的文章开始Biztalk学习的。

1.首先打开Biztalk管理控制台,Biztalk2006管理->Biztalk Group->应用程序。

2. 右键->新建应用程序,这里我起名为Hello World。

3.接收端口->新建->单向接收端口  在这里设置端口名称以及接收位置。

4.发送端口->新建->静态单向发送端口  在这里设置发送端口名称以及位置,另外,在筛选器中,设置BTS.ReceivePortName == 刚刚设置的发送端口名称。

 

在这里,我们就可以启动刚刚创建的应用程序了,讲一个xml文件放置在刚设置的接收位置,刷新,这个文件不见了,它已经被传送到我们刚刚设置的发送位置了。:)


在发送端口的文件类型->配置中,可以看到,当前的默认文件名是%MessageID.xml%,这个表达式是Biztalk的宏,代表了消息在Biztalk中的ID。

目前,我们只能够传送.xml后缀名的文件,如果需要传送任意文件,可以把接收端口的文件掩码设置为*,同时,需要修改发送端口中文件类型的默认文件名,可以修改为%SourceFileName%,以文件原来的名字进行保存。

 

经常遇到的问题

   文件接收位置的文件不见了,但却没有在文件发送位置出现

   检查一下在发送端口的筛选器中,BTS.ReceivePortName的值是不是和你的发送端口名称吻合。

posted @ 2009-03-08 19:50 edist 阅读(22) | 评论 (0)编辑

2008年3月20日

[Active Directory]该服务器不愿意处理该请求

进行AD操作时,执行到directoryEntry.Invoke("SetPassword", new object[] { "password" })时,出现了这个超级人性化的提示.
Google一下,发现遇到这个问题的人还不少.
错误原因是由于重置的密码不符合计算机组策略的密码策略造成的.可以增加密码强度.
修改密码策略方法如下:
开始-运行-gpedit.msc打开组策略,  安全设置-帐户策略-密码策略  相应修改
修改后运行gpupdate,刷新组策略即可

posted @ 2008-03-20 14:03 edist 阅读(126) | 评论 (0)编辑

2007年11月19日

页面提示"已终止操作"的解决办法

造成这个错误的原因是因为页面未加载完毕时改变了Body中的内容

在执行类似document.body.innerHTML=***的操作之前。先进行判断是否加载完毕.
方法如下.
function dosomething()
{
     if (window.document.readyState)
     {//IE
        if (window.document.readyState=='complete')
        {
            //do(); 
        }
        else
        {
           setTimeout("dosomething()",10);
        }
     }
     else 
     {
         window.addEventListener("load",function(){do();},false);
      }

posted @ 2007-11-19 10:12 edist 阅读(57) | 评论 (0)编辑

2007年11月14日

获取页面Html代码,自动识别编码。

 
public string GetHtml(string url)
    {
        string code = DecodeData(url);
        HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
        request.Timeout = 30000;
        request.Headers.Set("Pragma", "no-cache");
        HttpWebResponse response = (HttpWebResponse)request.GetResponse();
        Stream streamReceive = response.GetResponseStream();
        Encoding encoding = code != string.Empty ? Encoding.GetEncoding(code.ToUpper()) : Encoding.Default;
        StreamReader streamReader = new StreamReader(streamReceive, encoding);
        string strResult = streamReader.ReadToEnd();
        streamReader.Close();
        streamReader.Dispose();

        return strResult;
    }
//http://blog.sunmast.com/natas/archive/2004/10/30/989.aspx,略有改动.   

    private string DecodeData(string Url)
    {
        WebRequest r = WebRequest.Create(Url);
        WebResponse w = r.GetResponse();
        //    
        //   first   see   if   content   length   header   has   charset   =   calue    
        //    
        String charset = string.Empty;
        String ctype = w.Headers["content-type"];
        if (ctype != null)
        {
            int ind = ctype.IndexOf("charset=");
            if (ind != -1)
            {
                charset = ctype.Substring(ind + 8);
            }
        }

        //   save   data   to   a   memorystream    
        MemoryStream rawdata = new MemoryStream();
        byte[] buffer = new byte[1024];
        Stream rs = w.GetResponseStream();
        int read = rs.Read(buffer, 0, buffer.Length);
        while (read > 0)
        {
            rawdata.Write(buffer, 0, read);
            read = rs.Read(buffer, 0, buffer.Length);
        }

        rs.Close();

        //    
        //   if   ContentType   is   null,   or   did   not   contain   charset,   we   search   in   body    
        //    
        if (charset == null)
        {
            MemoryStream ms = rawdata;
            ms.Seek(0, SeekOrigin.Begin);

            StreamReader srr = new StreamReader(ms, Encoding.ASCII);
            String meta = srr.ReadToEnd();

            if (meta != null)
            {
                int start_ind = meta.IndexOf("charset=");
                int end_ind = -1;
                if (start_ind != -1)
                {
                    end_ind = meta.IndexOf("\"", start_ind);
                    if (end_ind != -1)
                    {
                        int start = start_ind + 8;
                        charset = meta.Substring(start, end_ind - start + 1);
                        charset = charset.TrimEnd(new Char[] { '>', '"' });
                    }
                }
            }
        }
        return charset.ToString();
    } 

posted @ 2007-11-14 09:40 edist 阅读(449) | 评论 (2)编辑

2007年11月12日

Berkeley DB 基本使用.

最近在写蜘蛛。需要一张庞大的url表来记录各种url被线程的读取状况,因此需要连续的请求,以及多线程的并发操作等。
很显然,sqlserver并不能完全的满足需求。
推荐一下Berkeley DB
Berkeley DB相当于存储于本地硬盘的一个大的Hash表,由Key,Value构成.

需要下载的相关内容
Berkeley DB 4.5.20
Berkeley DB for .NET 0.95


基本操作
 // 添加数据到DBD数据库
        public  bool Add(string key,string obj)
        {
            string DbPath = @"e:\search\data\data.db";
            Db db = new Db(DbCreateFlags.None);
            DbEntry wKey = DbEntry.InOut(Encoding.UTF8.GetBytes(key));
            DbEntry wData = DbEntry.InOut(Encoding.UTF8.GetBytes(obj));
            DbFile dbf = db.Open(null, DbPath, null, BerkeleyDb.DbType.BTree, Db.OpenFlags.Create, 0);
            WriteStatus wStatus = dbf.Put(null, ref wKey, ref wData);
            dbf.Sync();
            db.Close();
            if (wStatus == WriteStatus.Success)
            {
                return true;
            }
            else
            {
                return false;
            }

        }

        // 根据key返回值
        public string GetVal(string key)
        {
            string result = string.Empty;
            DbEntry rData = DbEntry.Out(new byte[2048]);
            DbEntry rKey = DbEntry.InOut(Encoding.UTF8.GetBytes(key));
            Db db = new Db(DbCreateFlags.None);
            DbFile dbf = db.Open(null, DbPath, null, BerkeleyDb.DbType.BTree, Db.OpenFlags.Create, 0);
            ReadStatus rStatus = dbf.Get(null, ref rKey, ref rData, DbFile.ReadFlags.None);
            db.Close();
            if (rStatus == ReadStatus.Success)
            {
                result = Encoding.UTF8.GetString(rData.Buffer, 0, rData.Size);
            }
            return result;
        }

posted @ 2007-11-12 16:53 edist 阅读(299) | 评论 (2)编辑

2007年11月11日

更新Lucene索引中的数据.

Lucene本身并不支持更新。所以只能选择先删除再新增记录。
lucene本身支持两种删除模式
1,DeleteDocument(int docNum)
2,DeleteDocuments(Term term)
一般使用的是第二种
 IndexReader reader = IndexReader.Open(path));
 int count=reader.DeleteDocuments(new Term("FieldName","Txt"));

Lucene的删除也就是一次搜索的过程.
需要匹配删除的字段存储时不要进切词.



1年多没写文章啦。。。。。


posted @ 2007-11-11 14:30 edist 阅读(991) | 评论 (5)编辑

2006年7月7日

MVC 添加用户.

在codeproject看到一个mvc实例.
大致结构如下.
AbstractLayer-baseMember.cs   定义了基类成员
DataLayer-SqlDataAccess.cs  继承IdataAccess,实现接口方法
                 -IdataAccess.cs     接口
BusinessLayer-Member.cs  继承baseMember.cs  返回方法实现
View
添加用户页面.
将页面数据添加到BusinessLayer 下的Member实例(因为BusinessLayer下的Member继承了baseMember)调用AddNewMember();

 

protected void btnSave_Click(object sender, System.EventArgs e)
        
{
AddMember();
            
int retVal = objMember.AddnewMember(objMember);
            
if(retVal>0)
            
{
                lblMessage.Text 
= "New record added successfully";
            }

            
else
            
{
                lblMessage.Text 
= "An error has occured while processing your request";
            }

        }

        
public void AddMember()
        
{
            objMember.firstName 
= txtFirstName.Text.Trim();
            objMember.lastName 
= txtLastName.Text.Trim();
            objMember.contactNo 
= txtContactNo.Text.Trim();
            objMember.emailAddress 
= txtEmailAddress.Text.Trim();
        }

BusinessLayer下Member.cs
AddNewMember再返回接口方法的实现

public int AddnewMember(AbstractLayer.baseMember objMember)
        
{
            IdataAccess MemberSqlDataAccess 
= new SqlDataAccess(System.Configuration.ConfigurationSettings.AppSettings["ConnectionString"].ToString());
            
return MemberSqlDataAccess.AddnewMember(objMember);
        }

DataLayer
IdataAccess定义了AddNewMember接口.
SqlDataAccess实现
SqlDataAccess代码:

public int AddnewMember(AbstractLayer.baseMember  objMember)
  {
   SqlTransaction objTrans=null;      
   SqlConnection myConnection =  new SqlConnection(m_Connection_String);
   try
   {
    // Insert Member Personal details only
    myConnection.Open();
    objTrans= myConnection.BeginTransaction();
    SqlParameter [] arrParam=new SqlParameter[4];

    arrParam[0]=new SqlParameter("@fName", objMember.firstName);
    arrParam[1]=new SqlParameter("@lName",objMember.lastName);
    arrParam[2]=new SqlParameter("@coNo",objMember.contactNo);
    arrParam[3]=new SqlParameter("@emailAddr",objMember.emailAddress);
    //pass connection string, storedprocedure name and parameter array
    SqlHelper.ExecuteNonQuery(m_Connection_String,CommandType.StoredProcedure,"usps_proInsMember",arrParam);
    
   }
   catch(Exception Ex)
   { 
    objTrans.Rollback();
    string sError=Ex.Message.ToString(); 
    return -1;
   }
   finally
   {
    myConnection.Close();
   }
   return 1;
  }


 

posted @ 2006-07-07 23:19 edist 阅读(61) | 评论 (1)编辑