Получить имя пользователя из поля пользователя SharePoint в списке - PullRequest
3 голосов
/ 02 декабря 2009

У меня есть собственный рабочий процесс sharepoint, который я разрабатываю в Visual Studio. Рабочий процесс работает с библиотекой документов, к которой подключен пользовательский тип контента. Тип содержимого включает поле поиска пользователя («владелец»).

Я пытаюсь, чтобы мой рабочий процесс назначил задачу полю поиска «владелец». Однако я смог получить только отображаемое имя пользователя, но не имя пользователя учетной записи.

Может кто-нибудь помочь?

Ответы [ 2 ]

10 голосов
/ 03 декабря 2009

См. Эту статью о том, как получить данные пользователя с поля.

public static SPUser GetSPUser(SPListItem item, string key) {
     SPFieldUser field = item.Fields[key] as SPFieldUser;

     if( field != null) {   
         SPFieldUserValue fieldValue = field.GetFieldValue(item[key].ToString()) as SPFieldUserValue; 

         if(fieldValue != null)     
            return fieldValue.User; 
      }
      return null; 
 }

Ваш код должен быть таким

SPUser spUser=GetSPUser(splistItem,"Owner");
String sUserName=(spUser!=null)?spUser.UserName:null;
4 голосов
/ 24 февраля 2012

Мое решение:

public static SPUser GetSPUser(SPListItem item, string key)   
{
    SPUser user=null;   
    SPFieldUserValue userValue = new SPFieldUserValue(item.Web, item[key].ToString());
    if (userValue != null)
    {
        SPUser user = userValue.User;
    }
return user;
}

Как звонить:

SPUser spUser=GetSPUser(splistItem,"Owner"); 

Это проверенный код и работает нормально.

...