当前位置: 首页 > 滚动

天天热讯:钉钉PC端使用 Blazor WebAssembly 读取用户信息

来源:博客园 发布时间:2023-05-08 19:14:26

功能: 在钉钉内打开 Blazor WebAssembly 网站时, 读取钉钉当前的用户信息, 并显示启用的功能列表

版本: .NET6


(资料图片仅供参考)

界面库: Ant Design Blazor

基础要求:

1. 让公司管理员设置自己为钉钉开发者

2. 下载 钉钉RC版 作为调试工具, 下载地址: https://open.dingtalk.com/document/resourcedownload/h5-debug

3. 钉钉开发者后台 -> 企业内部开发 -> 新建H5微应用. 在开发管理中设置服务器出口IP、应用首页地址、PC端首页地址. 在权限管理中开通 调用OpenApp专有API时需要具备的权限 权限

4. 有固定公网IP, 建议使用域名绑定

5. 已经使用钉钉的服务端SDK搭建了服务端

在项目的 index.html 文件的 body 里添加

1 <script src="https://g.alicdn.com/dingding/dingtalk-jsapi/3.0.12/dingtalk.open.js"></script> 2  3     <script> 4         // 获取钉钉免登码 5         window.GetUserAuthCode = (corpId) => { 6             dd.ready(function () { 7                 dd.runtime.permission.requestAuthCode({ 8                     corpId: corpId, 9                     onSuccess: function (result) {10                         //alert(result.code);11                         DotNet.invokeMethodAsync("ERPQueryTool", "StaticDingTalkLogined", result.code);12                         /*{13                             code: "hYLK98jkf0m" //string authCode14                         }*/15                     },16                     onFail: function (err) { }17 18                 });19             });20         };21 22         // 在钉钉内下载文件23         window.DingTalkDownloadFile = (url, name) => {24             dd.ready(function () {25 26                 dd.biz.util.downloadFile({27                     url: url, //要下载的文件的url28                     name: name, //定义下载文件名字29                     onProgress: function (msg) {30                         // 文件下载进度回调31                     },32                     onSuccess: function (result) {33                         /*34                           true35                         */36                     },37                     onFail: function () { }38                 })39 40             });41         };42 43         // 在钉钉内下载后打开保存目录44         window.DingTalkOpenFolderAfterDownloadFile = (url, name) => {45             dd.ready(function () {46 47                 dd.biz.util.downloadFile({48                     url: url, //要下载的文件的url49                     name: name, //定义下载文件名字50                     onProgress: function (msg) {51                         // 文件下载进度回调52                     },53                     onSuccess: function (result) {54                         /*55                           true56                         */57                         dd.biz.util.openLocalFile({58                             url: url, //本地文件的url,指的是调用DingTalkPC.biz.util.downloadFile接口下载时填入的url,配合DingTalkPC.biz.util.downloadFile使用59                             onSuccess: function (result) {60                                 /*61                                   true62                                 */63                             },64                             onFail: function () { }65                         });66                     },67                     onFail: function () { }68                 });69 70             });71 72         };73     </script>

在项目的 MainLayout.razor 里添加

private static Action? LoginedAction;    protected override async void OnAfterRender(bool firstRender)    {        base.OnAfterRender(firstRender);        if (!firstRender)        {            return;        }        LoginedAction = DingTalkLogined;        StartDingTalkLogin();    }    // 调用JS方法, 获取 authCode    private async void StartDingTalkLogin()    {        await JS.InvokeAsync("GetUserAuthCode", Tool.LoginHelper.DingTalkCorpId);    }    // JS方法回调    [JSInvokable]    public static void StaticDingTalkLogined(string authCode)    {        LoginedAction?.Invoke(authCode);    }    // 根据 authCode 获取用户信息    private async void DingTalkLogined(string authCode)    {        // 调用服务端获取 authCode 对应的用户信息        // 获取启用的功能列表    }

最终效果:

参考资料:

https://open.dingtalk.com/document/orgapp/read-before-development

https://antblazor.com/zh-CN/docs/introduce

TopBottomTopBottom
上一篇 下一篇
最新推荐 更多>>