无责任Windows Azure SDK .NET开发入门篇三[使用Azure AD 管理用户信息--3.3 Details用户详细信息]...

3.3 Details用户详细信息

用户详细信息是通过objectId获取。代码如下

public async Task<ActionResult> Details(string objectId)
{
    try
    {
        ActiveDirectoryClient client = AuthenticationHelper.GetActiveDirectoryClient();
        var user = (User)await client.Users.GetByObjectId(objectId).ExecuteAsync();
        return View(user);
    }
    catch (Exception e)
    {
        if (e.Message == "Authorization Required.")
        {
            HttpContext.GetOwinContext().Authentication.Challenge(OpenIdConnectAuthenticationDefaults.AuthenticationType);
        }
        return View();
    }
}

对应的View代码如下

@model Microsoft.Azure.ActiveDirectory.GraphClient.User

@{
    ViewBag.Title = "UserDetails";
}

<h2>User Details</h2>

<div class="form-horizontal">
    <div class="form-group">
        @Html.LabelFor(model => model.UserPrincipalName, "用户名(全名)", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.UserPrincipalName)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.MailNickname, "别名", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.MailNickname)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.City, "城市", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.City)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.Country, "国家或地区", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.Country)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.Department, "部门", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.Department)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.DisplayName, "显示名称", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.DisplayName)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.PhysicalDeliveryOfficeName, "办公室号码", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.PhysicalDeliveryOfficeName)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.TelephoneNumber, "办公电话", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.TelephoneNumber)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.GivenName, "名字", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.GivenName)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.JobTitle, "职务", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.JobTitle)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.PostalCode, "邮政编码", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.PostalCode)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.State, "省/自治区/直辖市", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.State)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.StreetAddress, "街道地址", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.StreetAddress)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.Surname, "姓氏", new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.Surname)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(model => model.UserType, new { @class = "col-sm-2 control-label" })
        <div class="col-sm-10">
            @Html.DisplayFor(model => model.UserType)
        </div>
    </div>
</div>

<table>
    <tbody>
        <tr>
            <td>
                @Html.ActionLink("Edit", "Edit", new { objectId = Model.ObjectId }, new { @class = "btn btn-primary" })
            </td>
            <td>
                @Html.ActionLink("Delete", "Delete", new { objectId = Model.ObjectId }, new { @class = "btn btn-warning" })
            </td>
            <td>
                @Html.ActionLink("List", "Index", null, new { @class = "btn btn-info" })
            </td>
        </tr>
    </tbody>
</table>

转载于:https://www.cnblogs.com/shyleoking/p/4719045.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值