Heim WeChat-Applet Mini-Programmentwicklung Anweisungen zum Erstellen eines Anmeldevorgangs für die WeChat-Miniprogrammentwicklung

Anweisungen zum Erstellen eines Anmeldevorgangs für die WeChat-Miniprogrammentwicklung

Apr 02, 2017 pm 03:49 PM

Jeder, der sich bei WeChat angemeldet hat, weiß, dass wir eine Kennung benötigen, um die Einzigartigkeit der Identität des Benutzers aufzuzeichnen. In WeChat ist die UnionId die eindeutige ID, die wir aufzeichnen müssen. Daher wird die Art und Weise, wie wir die UnionId erhalten, zum Schlüssel Projekt in Es ist in zwei Teile unterteilt: Miniprogramm und Hintergrund-PHP-Code.

Beginnen wir mit unserem Mini-Programmcode

Sprechen Sie kurz über den jsCode-Anmeldeprozess unseres Mini-Programms

Anmeldung -> >getUserInfo ruft iv und verschlüsselte Daten ab –> übergibt sie an Ihren eigenen Server zur Verarbeitung –> gibt das Ergebnis an den Applet-

var API_URL = "自己的服务器地址";
Page({
 onLoad: function () {
 console.log("iv");
 wx.login({//login流程
 success: function (res) {//登录成功
 if (res.code) {
 var code = res.code;
 wx.getUserInfo({//getUserInfo流程
 success: function (res2) {//获取userinfo成功
 console.log(res2);
 var encryptedData = encodeURIComponent(res2.encryptedData);//一定要把加密串转成URI编码
  var iv = res2.iv;
  //请求自己的服务器
  Login(code,encryptedData,iv);
 }
 })
 
 } else {
 console.log('获取用户登录态失败!' + res.errMsg)
 }
 }
});
}
})
Nach dem Login kopieren

Code zurück: Wird vom Server zum Abrufen der Sitzung<🎜 verwendet >Erforderliche Parameter für Schlüssel.

IV: Anfangsvektor des Verschlüsselungsalgorithmus, verschlüsseltDaten: verschlüsselte

Zeichenfolge.

Geben Sie Code iv verschlüsselte Daten an unseren Server weiter

function Login(code,encryptedData,iv){ console.log(&#39;code=&#39;+code+&#39;&encryptedData=&#39;+encryptedData+&#39;&iv=&#39;+iv);
 //创建一个dialog
  wx.showToast({
  title: &#39;正在登录...&#39;,
  icon: &#39;loading&#39;,
  duration: 10000
  });
  //请求服务器
  wx.request({
  url: API_URL,
  data: {
  code:code,
  encryptedData:encryptedData,
  iv:iv
  },
  method: &#39;GET&#39;, // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
  header: {
  &#39;content-type&#39;: &#39;application/json&#39;
  }, // 设置请求的 header
  success: function (res) {
  // success
  wx.hideToast();
  console.log(&#39;服务器返回&#39;+res.data);
 
  },
  fail: function () {
  // fail
  // wx.hideToast();
  },
  complete: function () {
  // complete
  }
  })
 }
Nach dem Login kopieren
Wenn Sie sich das Dokument ansehen, sollten Sie wissen, dass die von uns benötigte UnionId in verschlüsselten Daten enthalten ist, sodass der Server diese Informationen benötigt um die UnionId zu analysieren.

Serververarbeitungslogik

Laden Sie zuerst die WeChat-Entschlüsselungsdemo herunter

Der hier ausgewählte PHP-Code besteht aus den drei

Klassen-Dateien mit Ausnahme der Demo unser eigenes Projekt und rufen Sie es später auf.

Hier ist eine Erklärung des Verarbeitungsablaufs des Servers:


Rufen Sie den sesionKey über die

Schnittstelle von WeChat ab und verwenden Sie dann den sessionKey und iv, um die verschlüsselten Daten zu entschlüsseln um die UnionID zu erhalten.

/**
 * 登录
 *
 * @return Response
 */
 public function weixinlogin( $user_id=null )
 {
  global $App_Error_Conf,$Gift_Ids,$Server_Http_Path,$Is_Local,$Test_User,$Good_Vcode,$WeiXin_Xd_Conf;
  $validator_result = input_validator(array(&#39;code&#39;,&#39;iv&#39;,&#39;encryptedData&#39;));
  if(!empty($validator_result)){
   return response($validator_result);
  }
  $js_code = $_REQUEST[&#39;code&#39;];
  $encryptedData = $_REQUEST[&#39;encryptedData&#39;];
  $iv = $_REQUEST[&#39;iv&#39;];
  $appid = $WeiXin_Xd_Conf[&#39;appid&#39;];
  $secret = $WeiXin_Xd_Conf[&#39;secret&#39;];
  $grant_type = $WeiXin_Xd_Conf[&#39;grant_type&#39;];
  //从微信获取session_key
  $user_info_url = $WeiXin_Xd_Conf[&#39;code2session_url&#39;];
  $user_info_url = sprintf("%s?appid=%s&secret=%s&js_code=%s&grant_type=%",$user_info_url,$appid,$secret,$js_code,$grant_type);
  $weixin_user_data = json_decode(get_url($user_info_url));
  $session_key = $weixin_user_data->session_key;
//解密数据
$data = &#39;&#39;;
$wxBizDataCrypt = new WXBizDataCrypt($appid, $session_key);
$errCode=$wxBizDataCrypt>decryptData($appid,$session_key,$encryptedData, $iv, $data );
Nach dem Login kopieren
Die Daten, die wir schließlich erhalten haben, sind die von uns entschlüsselten verschlüsselten Daten, die die UnionId enthalten.

Das obige ist der detaillierte Inhalt vonAnweisungen zum Erstellen eines Anmeldevorgangs für die WeChat-Miniprogrammentwicklung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)