Maison >Applet WeChat >Développement de mini-programmes >Analyse du processus de développement de l'applet WeChat d'entreprise

Analyse du processus de développement de l'applet WeChat d'entreprise

王林
王林avant
2020-12-23 09:22:162803parcourir

Analyse du processus de développement de l'applet WeChat d'entreprise

Introduction :

Développez un petit programme accessible uniquement dans Enterprise WeChat, et seuls les utilisateurs autorisés dans Enterprise WeChat peuvent l'utiliser.

(Partage de vidéos d'apprentissage : Vidéo de programmation)

Analyse du problème :

Tout d'abord, plusieurs problèmes doivent être résolus :

1. Utilisé uniquement dans WeChat d'entreprise et ne peut pas être utilisé dans les mini-programmes ordinaires

Déterminer l'environnement d'exploitation actuel

2 Seuls les utilisateurs autorisés peuvent utiliser ce mini-programme

.

Vérification des autorisations

1 : WeChat ordinaire, utilisez le compte + le mot de passe pour vous connecter, uniquement pour examen, les autorisations du compte peuvent être restreintes

2 : Enterprise WeChat, vérifiez l'identifiant de l'entreprise, vérifiez l'utilisateur id, avoir des autorisations Uniquement autorisé à utiliser

3. Contrôler la recherche

Définir "Non autorisé à être recherché" dans l'arrière-plan de gestion du mini programme

4. >

Dans le mini-programme Fermer le partage

OK, après avoir effectué les points ci-dessus, seuls les utilisateurs autorisés dans Enterprise WeChat peuvent voir le mini-programme sur le Workbench d'Enterprise WeChat.

Processus de traitement

D'accord, maintenant que le problème a été clarifié, commençons.

1. Développez les fonctions de base du mini-programme et soumettez-le pour examen

Oui, vous avez bien lu, soumettez-le d'abord pour examen, car seuls les mini-programmes qui réussissent l'examen peuvent être lié à Enterprise WeChat. Par conséquent, créez d'abord les fonctions de base du mini programme, et vous pouvez restreindre certaines fonctions. Bref, laissez ce mini programme être d'abord mis sur les étagères. Dans le même temps, définissez « interdiction de recherche » dans l'arrière-plan de gestion du mini-programme pour éviter des problèmes inutiles.

2. Associez le mini-programme à Enterprise WeChat

Entrez dans le backend d'Enterprise WeChat-> Gestion des applications-> Associez le mini-programme, puis utilisez le QR WeChat. code de l'administrateur du mini programme pour scanner le code, suivez simplement les instructions.

3. Obtenez le secret du mini programme associé et définissez la plage visible

Le mini programme que vous venez d'associer apparaîtra sur la page du mini programme à l'étape précédente, et cliquez pour entrer. alors vous verrez la plage secrète et visible.

Ce secret est équivalent au jeton utilisé par l'applet pour accéder aux données WeChat de l'entreprise. Veuillez le conserver correctement.

La plage de visibilité est l'autorisation. Quels utilisateurs peuvent voir ce mini programme Ceux qui sont configurés pour être visibles verront le mini programme sur leur établi WeChat d'entreprise.

4. Modifier le mini programme

D'accord, c'est l'heure de l'événement principal.

4.1. Déterminer l'environnement d'exploitation

Le mini-programme doit déterminer l'environnement d'exploitation actuel (WeChat normal ou WeChat d'entreprise) et si l'utilisateur utilisant le mini-programme actuel a l'autorisation de l'utiliser.

var isWxWork = false;
wx.getSystemInfo({
  success(res) {
    console.log(res.environment);

    isWxWork = res.environment == 'wxwork';
    if (!isWxWork) {
        // 当前环境不是企业微信,怎么处理你随便
        return;
    }
    
    // 当前环境是企业微信,执行登陆,获取用户 code,用于后面的权限校验
    wx.qy.login({
      success: function (res) {
        if (res.code) {
            console.log(res.code);
            
            // 这里可以将 res.code 通过请求发送给后台,让后台做权限校验
        } else {
            console.log('登录失败!' + res.errMsg);
        }
      }
    });
  }
})
4.2. Vérification des autorisations

L'arrière-plan doit appeler les interfaces suivantes pour effectuer la vérification des autorisations.

1. Obtenir access_token

https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=xxxx&corpsecret=xxxx

请求方式:GET
Cette interface est similaire à la méthode d'obtention de jeton sur WeChat ordinaire.

Parmi eux, corpid est dans le backend de gestion WeChat de l'entreprise->Mon entreprise->Informations sur l'entreprise->Corporate ID; corpsecret est le secret obtenu après avoir associé le mini-programme à l'étape précédente.

Le contenu renvoyé est le suivant :

{
    "errcode": 0,
    "errmsg": "ok",
    "access_token": "xxxxxx",
    "expires_in": 7200
}
2. Obtenir l'ID utilisateur

https://qyapi.weixin.qq.com/cgi-bin/miniprogram/jscode2session?access_token=xxx&js_code=xxx&grant_type=authorization_code

请求方式:GET
Parmi eux, access_token est obtenu par gettoken à l'étape précédente ; environnement en cours d'exécution. res.code ; grant_type fixed authorisation_code

Le contenu renvoyé est le suivant :

{
    "userid": "bottle",
    "session_key": "xxxxx",
    "corpid": "xxxxxx",
    "deviceid": "xxxxxx",
    "errcode": 0,
    "errmsg": "ok"
}
Le corpid ici peut être utilisé pour vérifier initialement si l'utilisateur actuel dispose d'autorisations, car peu importe lesquelles. La société d'où provient la personne, tant qu'elle utilise Enterprise WeChat, en utilisant cette applet, renverra un tel résultat. Vous devez vérifier si le corps est l'ID de l'entreprise que vous autorisez. Sinon, ne renvoyez aucune autorisation sans procéder. la prochaine étape.

Bien sûr, Corpid peut également être utilisé pour gérer des situations dans lesquelles un petit programme est associé à plusieurs entreprises, mais c'est un autre problème. Permettez-moi de mentionner brièvement ici, parce qu'il s'agit d'un petit programme développé pour d'autres sociétés, que notre petit programme est également associé à deux sociétés, l'une est notre société et l'autre est l'autre société. Cela facilite également nos tests et ne nécessite que nos propres testeurs. L'autorisation leur permet d'utiliser exactement le même environnement pour les tests.

3. Obtenir les informations utilisateur (déterminer les autorisations)

https://qyapi.weixin.qq.com/cgi-bin/user/get?access_token=xxx&userid=xxx

请求方式:GET
Parmi eux, access_token est ce que nous avons obtenu par gettoken à l'étape précédente ;

Le contenu renvoyé est le suivant :

Avec autorisation

{
    "errcode": 0,
    "errmsg": "ok",
    "userid": "xxx",
    "name": "xxx",
    "department": [],
    "position": "",
    "mobile": "xxx",
    "gender": "2",
    "email": "",
    "avatar": "http://p.qlogo.cn/bizmail/xxx/0",
    "status": 1,
    "isleader": 0,
    "extattr": {
        "attrs": []
    },
    "telephone": "",
    "enable": 1,
    "hide_mobile": 0,
    "order": [],
    "qr_code": "https://open.work.weixin.qq.com/wwopen/userQRCode?vcode=xxx",
    "alias": "",
    "is_leader_in_dept": []
}
Sans autorisation :


{
    "errcode": 60011,
    "errmsg": "no privilege to access/modify contact/party/agent , hint: [1564556097_7_8d45297bd21be3702ff430560e1f0652], from ip: 118.113.1.217, more info at https://open.work.weixin.qq.com/devtool/query?e=60011",
    "department": [],
    "order": [],
    "is_leader_in_dept": []
}
OK, l'exécution sera différente selon que vous ayez la permission ou non, l’opération est suffisante, et je n’entrerai pas dans les détails ici.

Documents de référence

API Enterprise WeChat (mini programme) : https://work.weixin.qq.com/api/doc#90000/90136/90289

Enterprise Outil de débogage de l'interface WeChat : https://work.weixin.qq.com/api/devtools/devtool.php

Outil de requête de code d'erreur : https://open.work.weixin.qq.com/devtool /query

Recommandations associées :

Développement de mini-programmes

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer