设为首页 收藏本站
查看: 1416|回复: 0

[经验分享] 在SharePoint中几种访问域用户profile的方法[转]

[复制链接]

尚未签到

发表于 2017-5-24 11:37:19 | 显示全部楼层 |阅读模式
 在SharePoint2010中,我们可以选择几种不同的方式来访问域用户的profile,下面简单介绍3种方法:
  1.通过客户端直接调用user profile service来访问
  例如项目中有silverlight模块想显示当前用户的profile信息,可以这么作:
  首先添加Service Reference,输入service url http://rootsite/sites/subsite/_vti_bin/UserProfileService.asmx?WSDL
  rootsite & subsite请根据实际情况替换。然后我们为我们的Service reference取名为UserProfileServiceProxy。
  其次在maipage方法中加入调用service 代码以及回调方法代码:
 
以下是代码片段:
    public MainPage() 
  { 
  InitializeComponent(); 
  client = new UserProfileServiceProxy.UserProfileServiceSoapClient(); 
  client.Endpoint.Behaviors.Add(new AsmxBehavior()); 
  client.GetUserProfileByNameCompleted +=new EventHandler(client_GetUserProfileByNameCompleted); 
  client.GetUserProfileByNameAsync(null); 
  } 
  private void client_GetUserProfileByNameCompleted(object sender, UserProfileServiceProxy.GetUserProfileByNameCompletedEventArgs e) 
  { 
  if (e.Error == null) 
  { 
  string s = ""; 
  for (int i = 0; i < e.Result.Count; i++) 
  { 
  if (e.Result.Values.Count > 0) 
  { 
  s +="{" + i.ToString() + "}" +"-->" + e.Result.Values[0].Value.ToString() + "\n"; 
  } 
  } 
  MessageBox.Show(s); 
  } 
  }
 
  其中加入AsmxBehavior类的原因是silverlight对guid的deseriable无法识别,网上找了个别人写的类,不添加这个bahavior,service调用会报异常,AsmxBehavior类和AsmxMessageInspector类就解决了这个问题,用的时候,把这两个类加进你的项目中就可以了。AsmxBehavior类和AsmxMessageInspector类的详细代码会在附件中加上。
  这样就可以得到一个当前user的profile信息了,可以看见我们主要是调用了GetUserProfileByNameAsync(null)这个方法,传入null参数返回当前用户profile,当然你可以给别的name来得到相应的profile。
  2. 在server直接通过SharePoint 的 Object Model取得service,方法如下:
 
以下是代码片段:
    using (SPSite site = new SPSite("siteurl")) 
  { 
  SPServiceContext context = SPServiceContext.GetContext(site); 
  UserProfileManager pmManager = new UserProfileManager(context); 
  System.Collections.IEnumerator item = pmManager.GetEnumerator(); 
  while (item.MoveNext()) 
  { 
  UserProfile userProfile = item.Current as UserProfile; 
  object o = userProfile[PropertyConstants.Url].Value; 
  } 
  }
 注意此方法需要先添加引用下面2个dll文件:
 
以下是代码片段:
    using Microsoft.Office.Server; 
  using Microsoft.Office.Server.UserProfiles;
 
  3.当然当你有一个可以直接从公司域环境中读取信息的帐号时,也可以直接去AD中读取用户profile,方法如下:
 
以下是代码片段:
    using System.DirectoryServices; 
  static void Main(string[] args) 
  { 
  DirectoryEntry directoryEntry = new DirectoryEntry("LDAP://ads.autodesk.com", @"youraccount", "password",AuthenticationTypes.Secure); 
  DirectorySearcher ds = new DirectorySearcher(directoryEntry); 
  ds.Filter = "(&(objectCategory=Person)(objectClass=User))"; 
  SearchResultCollection collection = ds.FindAll(); 
  int count = 0; 
  foreach (SearchResult sr in collection) 
  { 
  System.DirectoryServices.DirectoryEntry det = sr.GetDirectoryEntry(); 
  PropertyCollection pc = det.Properties; 
  if (det.Properties["mail"].Value != null && det.Properties["sAMAccountName"].Value != null) 
  { 
  Console.WriteLine(det.Properties["mail"].Value.ToString() + "--------" + det.Properties["sAMAccountName"].Value.ToString()); 
  count++; 
  } 
  if (det.Properties["sAMAccountName"].Value.ToString() == "your account") 
  { 
  foreach (string propName in pc.PropertyNames) 
  { 
  foreach (object value in det.Properties[propName]) 
  Console.WriteLine(" property = {0} value = {1}", 
  propName, value); 
  } 
  } 
  } 
  Console.WriteLine(count); 
  Console.Read(); 
  }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-380475-1-1.html 上篇帖子: SharePoint 2010 自定义状态机工作流(StateMachine Workflow) + InfoPath 实例part2 (InfoPath设计部 下篇帖子: sharepoint通过excel导入list时报错:导入数据时(方法'Post'作用于对象'IOWSPostData'时失败)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表