提取aspnet_Profile中自定义的用户属性(C#实现)

特殊需求

一个非常特别需求,需要提取aspnet_Profile中自定义的用户属性。这个特殊的需求是这样的:

提取用户的属性列表,我的机器只能访问开发库,没法访问生产库。DBA也比较忙,于是乎就把原始数据拿了过来,用程序进行分解。

Profile对象存储表(aspnet_Profile)

字段名

类型

属性

说明

UserId

uniqueidentifier

FK: aspnet_Users.UserId

用户ID

PropertyNames

ntext


属性名称

PropertyValuesString

ntext


字符串值

PropertyValuesBinary

image


二进制值

数据是这个样子的:
propertynames
NID:S:0:3:Company:S:3:3:PID:S:6:3:TrueName:S:9:2:
propertyvaluesstring
338com549李某
C#实现
  ///   <summary>
        
///  获取 aspnet_Profile中的属性值
        
///   </summary>
        
///   <returns></returns>
         private  DataTable GetProfileProperty()
        {
            
string  sql  =   @" SELECT 
                            [username]
                          , [rolename]
                          , [propertynames]
                          , [propertyvaluesstring]
                      FROM [VUserProfile]
" ;
            DataSet ds 
=  DBUtility.getDataSet(sql);
 
            
// NID,Company,PID,TrueName是自定义的用户属性
            DataTable dt  =   new  DataTable();
            DataColumn UserName 
=   new  DataColumn( " UserName " typeof ( string ));
            DataColumn RoleName 
=   new  DataColumn( " RoleName " typeof ( string ));
            DataColumn NID 
=   new  DataColumn( " NID " typeof ( string ));
            DataColumn Company 
=   new  DataColumn( " Company " typeof ( string ));
            DataColumn PID 
=   new  DataColumn( " PID " typeof ( string ));
            DataColumn TrueName 
=   new  DataColumn( " TrueName " typeof ( string ));
            dt.Columns.Add(UserName);
            dt.Columns.Add(RoleName);
            dt.Columns.Add(NID);
            dt.Columns.Add(Company);
            dt.Columns.Add(PID);
            dt.Columns.Add(TrueName);
            
for  ( int  i  =   0 ; i  <  ds.Tables[ 0 ].Rows.Count; i ++ )
            {
                DataRow row 
=  ds.Tables[ 0 ].Rows[i];
                
string  username  =  row[ " username " ].ToString();
                
string  rolename  =  row[ " rolename " ].ToString();
                
string  propertynames  =  row[ " propertynames " ].ToString().Replace( " :S: " " * " );
                
string  propertyvaluesstring  =  row[ " propertyvaluesstring " ].ToString();

                DataRow dtrow 
=  dt.NewRow();
                dtrow[
" UserName " =  username;
                dtrow[
" RoleName " =  rolename;
                
string [] p1  =  propertynames.Split( ' * ' );
                
for  ( int  j  =   0 ; j  <  p1.Length  -   1 ; j ++ )
                {

                    
string [] tmp  =  p1[j].Split( ' : ' );
                    
string [] tmp2  =  p1[j  +   1 ].Split( ' : ' );
                    string propertyname 
=  tmp[tmp.Length  -   1 ];
                    string propertyvalue 
=  propertyvaluesstring.Substring( int .Parse(tmp2[ 0 ]),  int .Parse(tmp2[ 1 ]));
                    dtrow[propertyname] 
=  propertyvalue;
                }
                dt.Rows.Add(dtrow);
            }
            
return  dt;
        }

效果

UserNameRoleNameNIDCompanyIDPIDTrueName
leex
客服800
c1
201李 X
leey
财务
801c2
202李 Y
leez
代理商
801c3
203李 Z

 

 

转载于:https://www.cnblogs.com/tenghoo/archive/2010/05/21/aspnet_Profile.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值