前言

有个时候SP的二次开发,需要用代码获取头像显示,如SP基于AD验证,AD有头像属性,做为头像数据来源(因为Exchange和lync的头像也来自AD),说道这里大家都知道有2种办法,一种从AD属性读取。一个从SP的user profile中去读取(也从AD来)。

方法1:从AD读取

AD有个属性叫thumbnailPhoto,而此属性存取的是二进制文件,因此读取的时候需要转换文件显示。首先需要在AD上传头像,可以用powershell或vbscript等很多方式上传照片(上传省略)。下面将采用C#代码如何获取AD的头像,做过验证码的人都知道,可以用Response.BinaryWrite 打印出来,然后图片控件访问这个打印出来的页面

1. 打印页面代码如下:

建议一个空白页面,后台代码如下:

using System;

using System.Collections.Generic;

using System.DirectoryServices;

using System.Linq;

using System.Web;

using System.Web.UI;

using System.Web.UI.WebControls;

namespace WebApplication1

{

public partial class photo : System.Web.UI.Page

{

protected void Page_Load(object sender, EventArgs e)

{

String myUser = Request.QueryString["u"];

if (myUser == null)

Response.Redirect("app_graphics/user.jpg");

Response.ContentType = "image/jpeg";

Response.Clear();

Response.BufferOutput = true;

DirectoryEntry de = new DirectoryEntry("LDAP://127.0.0.1/DC=contoso,DC=com", "mossadmin", "Passw0rd!");

DirectorySearcher search = new DirectorySearcher();

search.SearchRoot = de;

search.Filter = "(&(objectClass=user)(objectCategory=person)(sAMAccountName=" + myUser + "))";

search.PropertiesToLoad.Add("samaccountname");

search.PropertiesToLoad.Add("thumbnailPhoto");

SearchResult user;

user = search.FindOne();

String userName;

if (user == null)

Response.Redirect("app_graphics/user.jpg");

else

userName = (String)user.Properties["sAMAccountName"][0];

try

{

byte[] bb = (byte[])user.Properties["thumbnailPhoto"][0];

Response.BinaryWrite(bb);

Response.Flush();

}

catch

{

Response.Redirect("app_graphics/user.jpg");

}

}

}

}


2. 访问页面代码如下:

建议一个显示页面

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApplication1.WebForm1" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">

<head runat="server">

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

<title></title>

</head>

<body>

<form id="form1" runat="server">

<div>

<img src="photo.aspx?u=mossadmin" id="myPhoto" onclick="getPhoto()"

style="float: left; cursor: pointer;" />

<script type="text/javascript">

function getPhoto() {

document.getElementById("myPhoto").src = "photo.aspx?u=mossadmin";

}

</script>

</div>

</form>

</body>

</html>


注意:还可以点击刷新页面,用onclick事件,如果不需要可以干掉。最终查看显示结果即可

方法二:从user profile读取头像

1. 首先需要启动user profile的2个服务,如下图:

SA需要创建,如下图:

2. 然后配置同步连接,如下图:

3. 配置同步属性,如下图:

大家知道PictureUrl为SP2013的头像字段,如下图:

点编辑配置如下:如果没有,选择导入添加属性,对照AD属性thumbnailPhoto

确定即可

4. 启动同步服务。如下图:

5. 查看同步后的结果

6. 此时用代码读取,不一定读取到,因为还没有存储到个人信息的“用户照片”库里头,

新的照片会放在“我的网站宿主”的“用户照片”库中,并更新配置文件数据库中的属性值

具体原理大家可以我博客:

http://www.cnblogs.com/love007/archive/2012/08/23/2652798.html

7、运行powershell脚本

Update-SPProfilePhotoStore -CreateThumbnailsForImportedPhotos 1

-MySiteHostLocation %MySiteURL%

在SharePoint Server 2013,运行 Update-SPProfilePhotoStore cmdlet 以确保 SharePoint 配置文件照片存储与 SharePoint Server 2013兼容。只能在从 Office SharePoint Server 2007 的升级完成后使用 Update-SPProfilePhotoStore cmdlet。使用 Update-SPProfilePhotoStore cmdlet 时,会从原始照片创建三个具有可预测大小和名称的缩略图版本,新的照片会放在“我的网站宿主”的“用户照片”库中,并更新配置文件数据库中的属性值。

在操作期间,原始图像会保持原样。如果特定用户因任何原因而导致操作失败,则会直接移到下一用户。将配置文件图片从一台服务器 URL 迁移到另一台服务器 URL 期间,用户可以使用 OldBaseUriNewBaseUri 参数。您只需指定已从旧 URL 更改为新 URL 的 URL 的起始部分,系统就会尝试为配置文件图片 URL 重新设定基址。

例如,OldBaseUri: http://server1/my/ProfilePhotos; NewBaseUri: http://server1/my/NewLocation/ProfilePhotos

然后编写代码读取PictureUrl如下图:

#region//读取userprofile

///<summary>

///根据用户名获取UserProfile

///</summary>

///<param name="loginName">登录名</param>

///<param name="site">当前站点</param>

///<param name="web">当前web</param>

///<returns></returns>

public static UserProfile GetUserProfileByLoginName(string loginName, SPSite site, SPWeb web)

{

UserProfile userProfile = null;

SPSecurity.RunWithElevatedPrivileges(delegate()

{

SPUser user = web.EnsureUser(loginName); //当用户不存在时,自动将改用户添加到sharepoint中

SPServiceContext serviceContext = SPServiceContext.GetContext(site);

UserProfileManager profileManager = new UserProfileManager(serviceContext);

if (profileManager.UserExists(loginName))

{

userProfile = profileManager.GetUserProfile(loginName); //读取用户配置文件

}

});

return userProfile;

}

#endregion

读取代码如下:

static void Main(string[] args)

{

using(SPSite site = new SPSite("http://sp2013:8001"))

{

using(SPWeb web = site.OpenWeb(""))

{

UserProfile upf = userBLL.GetUserProfileByLoginName("contoso\\mossadmin", site, web);

//

if (upf != null)

{

//byte[] buffer = (byte[])upf[PropertyConstants.PictureUrl][0];

string temp = upf[PropertyConstants.PictureUrl].Value.ToString();

}

}

}

}


SharePoint2013的头像显示和读取的更多相关文章

  1. android高仿微信UI点击头像显示大图片效果

    用过微信的朋友朋友都见过微信中点击对方头像显示会加载大图,先贴两张图片说明下: 这种UI效果对用户的体验不错,今天突然有了灵感,试着去实现,结果就出来了.. 下面说说我的思路: 1.点击图片时跳转到另 ...

  2. 使用QT显示OpenCV读取的图片

    目录 1. 概述 2. 实现 2.1. 代码 2.2. 解析 3. 结果 1. 概述 OpenCV自带了一部分常用的GUI功能,但是更多的图像处理功能需要其他GUI框架来辅助实现,这里通过QT来显示O ...

  3. 【Android】读取sdcard卡上的全部图片而且显示,读取的过程有进度条显示

    尽管以下的app还没有做到快图浏览.ES文件浏览器的水平,遇到大sdcard还是会存在读取过久.内存溢出等问题,可是基本思想是这种. 例如以下图.在sdcard卡上有4张图片, 打开app,则会吧sd ...

  4. JS实现鼠标经过用户头像显示资料卡的效果,可点击

    基于项目的须要.须要制作出例如以下的一种页面效果:当用户鼠标经过好友列表中好友头像时,显示该好友的基本资料.事实上也就是类似QQclient的那种功能. 网上找了非常多代码,基本都实现了鼠标悬浮之后弹 ...

  5. JS 头像显示

    HTML <div class="form-group"> <label class="col-sm-3 control-label"> ...

  6. Android自定义控件实例,圆形头像(图库 + 裁剪+设置),上传头像显示为圆形,附源码

    Android项目开发中经常会遇见需要实现圆角或者圆形的图片功能,如果仅仅使用系统自带的ImageView控件显然无法实现此功能,所以通过系列文章的形式由简到繁全方位的介绍一下此功能的实现,巩固一下自 ...

  7. 通过CSS3实现圆形头像显示

    很久没更新博客了,因为比较菜,也没什么能在上面分享的.作为新手,马上要毕业找工作了,最近又在重新学习web的一些知识,刚刚学到CSS3,跟大家分享一些比较有趣的知识.今天分享的是利用CSS实现圆形头像 ...

  8. TreeView 节点的显示,读取,操作

    using System;using System.Collections;using System.Configuration;using System.Data;using System.Linq ...

  9. form表单普通提交预览显示,读取显示tmp文件

    <html> <head> <meta http-equiv="content-type" content="text/html; char ...

随机推荐

  1. AngularJS的学习--$on、$emit和$broadcast的使用

    AngularJS中的作用域有一个非常有层次和嵌套分明的结构.其中它们都有一个主要的$rootScope(也就说对应的Angular应用或者ng-app),然后其他所有的作用域部分都是继承自这个$ro ...

  2. 联想Y50耳机插入耳机孔后没有声音解决办法

    症状:博主本子Y50,前阵子关机时,提示win10要下载更新并安装,开机后发现将耳机插入耳机孔后死活听不到声音(笔记本自带的音响有声音).期间怀疑过耳机坏了的问题,检查过耳机在手机上能正常播放声音.最 ...

  3. 漫谈可视化Prefuse(二)---一分钟学会Prefuse

    前篇<漫谈可视化Prefuse(一)---从SQL Server数据库读取数据>主要介绍了prefuse如何连接数据库sql server并读取数据进行可视化展现. 回头想想还是应该好好捋 ...

  4. Java性能优化

    作者:禅楼望月(http://www.cnblogs.com/yaoyinglong) 注:里面的测试结果会因电脑配置的不同而有所差异!!! 1. 为一些集合定义初始化大小 List.Set.Map都 ...

  5. MAPPING SEGMENTS TO PAGES

    The segmentation and paging mechanisms provide in the support a wide variety of approaches to memory ...

  6. Windows Azure HandBook (5) Azure混合云解决方案

    <Windows Azure Platform 系列文章目录> 在很多情况下,我们都会遇到本地私有云和公有云做互通互联的混合云场景.对于这种混合云的场景,微软的Windows Azure会 ...

  7. Windows Azure Virtual Machine (31) 迁移Azure虚拟机

    <Windows Azure Platform 系列文章目录> 为什么要写这篇Blog? 之前遇到过很多客户提问: (1)我之前创建的虚拟机,没有加入虚拟网络.现在需要重新加入虚拟机网络, ...

  8. SQL Server安全(8/11):数据加密(Data Encryption)

    在保密你的服务器和数据,防备当前复杂的攻击,SQL Server有你需要的一切.但在你能有效使用这些安全功能前,你需要理解你面对的威胁和一些基本的安全概念.这篇文章提供了基础,因此你可以对SQL Se ...

  9. 玩爽了!直接在Chrome里抓取数据

    一个小测试发现可以自动做题,于是想通过脚本的方式看能不能获取相应的题库,刚好可以学习一下JS异步操作.花了一天时间,总算跑顺利了,遇到了不少坑.记录下来分享. 1.JS如何顺序执行 JS有强大的异步操 ...

  10. 【转载】HttpWebRequest开启gzip压缩简介

    在用HttpWebRequest对象时,一般我们都没有开启gzip压缩,如果服务端返回的数据比较大,这是我们需要开启gzip压缩,怎么开启呢? 1.给HttpWebRequest对象,添加如下Head ...