欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用java實現(xiàn)“釘釘微應用免登進入某H5系統(tǒng)首頁“功能”

 更新時間:2019年10月01日 09:01:59   作者:沐兮sc  
這篇文章主要介紹了用java實現(xiàn)“釘釘微應用,免登進入某H5系統(tǒng)首頁“功能”,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

一、前言

哈哈,這是我的第一篇博客。

先說一下這個小功能的具體場景:

用戶登錄釘釘app,點擊微應用,獲取當前用戶的信息,與H5系統(tǒng)的數(shù)據(jù)庫的用戶信息對比,如果存在該用戶,則點擊后直接進入H5系統(tǒng)的首頁,否則顯示“您無權(quán)限”。

補充:又加了一個小需求,就是免登成功,會給該用戶發(fā)條消息

我是參考釘釘開發(fā)文檔實現(xiàn)的這個小功能,文檔地址:https://ding-doc.dingtalk.com/doc#/serverapi2/clotub

二、準備工作

 需要創(chuàng)建一個微應用:https://open-dev.dingtalk.com

 

1.是在企業(yè)內(nèi)部開發(fā)中創(chuàng)建H5微應用,不是第三方企業(yè)應用中

企業(yè)內(nèi)部開發(fā):企業(yè)內(nèi)部開發(fā)是指“開發(fā)企業(yè)內(nèi)部應用”供企業(yè)內(nèi)部的人員使用。企業(yè)可以選擇由企業(yè)內(nèi)部的開發(fā)者進行開發(fā),或者由企業(yè)授權(quán)定制服務商進行開發(fā)。

第三方企業(yè)應用:第三方企業(yè)應用開發(fā),是指開發(fā)者以釘釘、企業(yè)之外的第三方身份,基于釘釘?shù)拈_放能力開發(fā)應用,并提供給釘釘上的其他組織使用。(哈哈,這個區(qū)別我是直接copy文檔中的)

2.H5工程中,創(chuàng)建的一個前端頁面ddNoLogin.html(哈哈,這個起名有點中文式英語,因為我沒有找到合適的英文單詞):

該頁面是用來獲取免登授權(quán)碼,然后把該code傳遞給后臺接口的。

3.填寫公司服務器的公網(wǎng)IP

可以敲命令查看該ip:curl ifconfig.me

 4.微應用創(chuàng)建好,會生成三個參數(shù),

agentId、appKey、appSecret

外加一個corpId(釘釘開發(fā)者平臺的首頁中有顯示),這四個參數(shù)值是固定的,后續(xù)開發(fā)需用

5.接口權(quán)限

高級權(quán)限-企業(yè)通訊錄中的接口都需要給開通

6.最后發(fā)布應用

三、功能開發(fā)

哈哈,要開始敲代碼了

1.獲取免登授權(quán)碼code

這里調(diào)用的是釘釘JS-API中的方法,本功能調(diào)用的方法是不需要鑒權(quán)的,如果需要鑒權(quán),則還需先dd.config。

關(guān)于功能方法是否需要鑒權(quán),可以去查看JSAPI總覽

ddNoLogin.html:

<!DOCTYPE html>
<html>
<head>
 <title>微應用登陸</title>
 <meta charset="utf-8">
 <meta name="viewport" content="width=device-width,initial-scale=1 user-scalable=0" />
 <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
 <script type="text/javascript" src="http://g.alicdn.com/dingding/open-develop/1.9.0/dingtalk.js"></script>
</head>
<body>
<div id="ddNoLogin"></div>
<script type="text/javascript">
  dd.ready(function() {
  //1.獲取免登授權(quán)碼code
  dd.runtime.permission.requestAuthCode({
   corpId : corpId , //企業(yè)id
   onSuccess : function(result) {
    var code = result.code;
    getUserInfo(code); //通過該code可以獲取用戶身份
   },
   onFail : function(err) {
    alert('出錯了, ' + err);
   }
  });
 });
  function getUserInfo(code) {
  $.ajax({
   type : "GET",
   url : "/xxx/noLogin?code=" + code,
   async : false,
   dataType : 'json',
   contentType : "application/json;charset=utf-8",
   success : (function(res) {
    if(res.code == "0000"){         
      window.location.href = '/#/xxxxx';
        }else{
         $('#ddNoLogin').html(res.msg);
        }
   }),
  });
 }
</script>
</body>
</html>

獲取code的實現(xiàn)是需要用前端JS去寫的

2.獲取access_token

釘釘提供了開放的api后臺接口,這里通過appkey和appsecret獲取token,請求路徑:https://oapi.dingtalk.com/gettoken?appkey=key&appsecret=secret

該token有效期是2個小時,有效期內(nèi)重復獲取,會返回相同結(jié)果,并自動續(xù)期,

故這里我的實現(xiàn)是:定時刷新token,每隔1小時50分鐘去獲取釘釘?shù)膖oken,并緩存到redis中(我把釘釘?shù)南嚓P(guān)配置都放入到application.yml中了)

DdTokenTask.java:

/**
 * 定時獲取釘釘?shù)膖oken
 */
@Component
@EnableScheduling
public class DdTokenTask {
 
 @Autowired
 private JedisClient jedisClient;
 
 public static final long cacheTime = 1000 * 60 * 55 * 2;//1小時50分鐘
 @Value("${dtalk.tokenUrl}")
 private String tokenUrl;
 @Value("${dtalk.app.key}")
 private String appKey;
 @Value("${dtalk.app.secret}")
 private String appSecret;
 @Value("${dtalk.redisTokenKey}")
 private String tokenKey;
 @Value("${dtalk.taskRun}")
 private String taskRun;
 
 
 /**
  * 每隔1小時50分鐘獲取釘釘?shù)腶ccess_token
  */
 @Scheduled(fixedRate = cacheTime)
 @Async
 public void getDdTokenTask(){
  if("true".equals(taskRun)){
   //刷新
   System.out.println("--->>>>>-------------獲取釘釘token的定時任務開始了:"+ DateUtil.formatDateToString(new Date(), "HH:mm:ss"));
 
   String accessTokenUrl = tokenUrl + "?appkey=" + appKey + "&appsecret=" + appSecret;
   //訪問獲取access_token 有效期是2小時
   String accessToken = JsonUtil.getJsonNode(HttpUtil.doGet(accessTokenUrl)).get("access_token").asText();
   //放入到redis中
   jedisClient.set(tokenKey, accessToken);
 
   System.out.println("--->>>>>-------------獲取釘釘token的定時任務結(jié)束了,token:"+accessToken);
  }
 }
 
 /*private String getAccessToken(){
  //需引入SDK,公司私服沒有
  DefaultDingTalkClient client = new
  DefaultDingTalkClient("https://oapi.dingtalk.com/gettoken");
  OapiGettokenRequest request = new OapiGettokenRequest();
  request.setAppkey("appkey");
  request.setAppsecret("appsecret");
  request.setHttpMethod("GET");
  OapiGettokenResponse response = client.execute(request);
  return "";
 }*/
 
}
(哈哈,其實文檔中提供了釘釘SDK的java寫法,不過公司私服沒有該SDK,所以我就直接用htttp請求了)

 3.獲取用戶userid

 通過免登授權(quán)碼和access_token獲取用戶的userid,請求路徑:https://oapi.dingtalk.com/user/getuserinfo?access_token=access_token&code=code

 4.獲取用戶詳情

請求路徑:https://oapi.dingtalk.com/user/get?access_token=ACCESS_TOKEN&userid=shaocui

會返回用戶的姓名、手機號等所有信息

DdLoginController.java:

@RestController
@RequestMapping("/ddUser")
@Api(value = "/ddUser", description = "釘釘H5微應用登錄", tags = {"DdLoginController"})
public class DdLoginController {
 
 @Autowired
 private JedisClient jedisClient;
 
 @Value("${dtalk.userUrl}")
 private String userUrl;
 @Value("${dtalk.userDetailUrl}")
 private String userDetailUrl;
 @Value("${dtalk.redisTokenKey}")
 private String tokenKey;
 @Value("${dtalk.agentId}")
 private Integer agentId;
 
 
 @GetMapping("/noLogin")
 @ApiOperation( "釘釘免登")
 @ApiImplicitParam(paramType = "query", name = "code", value = "免登授權(quán)碼", dataType = "String")
 public WebResponse noLogin(@RequestParam("code") String code, HttpServletResponse response){
  //2.獲取access_token
  String accessToken = jedisClient.get(tokenKey);
 
  //3.獲取用戶userid
  String userIdUrl =userUrl + "?access_token=" + accessToken + "&code=" + code;
  //訪問獲取userid
  JsonNode user = JsonUtil.getJsonNode(HttpUtil.doGet(userIdUrl));
  if(user.get("errcode").asInt() != 0){
   //有些公司的公網(wǎng)ip不固定,導致微應用中設置的不對,這里就會報錯
   return WebResponse.resFail(user.get("errmsg").asText());
  }
  String userId = user.get("userid").asText();
 
  //4.獲取用戶詳情 手機號
  String userInfoUrl = userDetailUrl + "?access_token=" + accessToken + "&userid=" + userId;
  //訪問獲取mobile
  JsonNode userInfo = JsonUtil.getJsonNode(HttpUtil.doGet(userInfoUrl));
  String mobile = userInfo.get("mobile").asText();
 
  System.out.println("釘釘用戶的手機號:"+mobile);
 
  //通過手機號獲取該用戶
  SysUser sysUser = 。。。。。;
  if(sysUser == null){
   //不存在該用戶
   return WebResponse.resFail("您無權(quán)限訪問", null);
  }
 
  。。。。。。
 
  //釘釘發(fā)送免登成功消息給用戶
  sendMessage(accessToken, userId, userInfo.get("name").asText());
 
  return WebResponse.resSuccess("免登成功", loginUserInfo);
 }
 
 //釘釘發(fā)送消息給用戶
 private void sendMessage(String token, String userId, String userName){
  String messageUrl = "https://oapi.dingtalk.com/topapi/message/corpconversation/asyncsend_v2?access_token="+token;
  Map<String, Object> map = new HashMap<>();
  map.put("agent_id", agentId.longValue());
  map.put("userid_list", userId);
  map.put("to_all_user", false);
  String content = "用戶"+userName+"在"+ DateUtil.formatDateToString(new Date(), "yyyy-MM-dd HH:mm:ss")+"時成功登錄xxH5端,并進入到xxx頁面";
  String msg = "{\"msgtype\":\"text\",\"text\":{\"content\":"+"\""+content+"\""+"}}";
  JSONObject jsonObj = JSONObject.parseObject(msg);
  map.put("msg",jsonObj);
 
  HttpUtil.doPost(messageUrl, map, "UTF-8", 20000, null);
 }
}
(哈哈,那個。。。。。處的代碼是實現(xiàn)系統(tǒng)認證成功后的具體操作,故這里省略)

到此釘釘免登就實現(xiàn)了,然后免登成功后給用戶發(fā)送消息

5.工作通知消息

POST請求,請求路徑:https://oapi.dingtalk.com/topapi/message/corpconversation/asyncsend_v2?access_token=ACCESS_TOKEN

請求體{agent_id、userid_list、dept_id_list、to_all_user、msg}

注意:

給同一個用戶發(fā)送相同的內(nèi)容,一天只能發(fā)一次;發(fā)送不同的內(nèi)容,一天可以500次,

故這里我在發(fā)送的消息中添加了當前時間。

(哈哈,一些細節(jié)的東西我都寫在代碼的注釋里了,最后發(fā)現(xiàn)這個小功能好像就一點點代碼量)

總結(jié)

以上所述是小編給大家介紹的使用java實現(xiàn)“釘釘微應用免登進入某H5系統(tǒng)首頁“功能”,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

相關(guān)文章

最新評論