Tutorial zur Netzwerkanforderungskapselung für die Entwicklung von Miniprogrammen

巴扎黑
Freigeben: 2017-08-17 14:56:46
Original
1447 Leute haben es durchsucht
Hier erklären wir zunächst einen Fehler im Miniprogrammdokument, der dazu führt, dass der Server bei Anfragen keine Parameter empfängt
Beispielcode:
wx.request({
 url: 'test.php', //仅为示例,并非真实的接口地址
 data: {
 x: '' ,
 y: '' },
 header: { 'Content-Type': 'application/json' },
 success: function(res) {
 console.log(res.data) }})
Nach dem Login kopieren

Der Content-Type im Header, den Sie verwenden sollten Kleingeschriebener Inhaltstyp, damit der Server Parameter empfangen kann. Ich habe lange Probleme damit und es funktioniert immer noch nicht, nachdem ich den Server gewechselt habe. Es stellt sich heraus, dass dies das Problem ist. Der Parameter befindet sich in der Anforderungsnutzlast und der Server kann ihn nach Verwendung der folgenden Konvertierung
function json2Form(json) { 
 var str = []; 
 for(var p in json){ 
 str.push(encodeURIComponent(p) + "=" + encodeURIComponent(json[p])); 
 } 
 return str.join("&"); }
Nach dem Login kopieren

Bild: 1.png

<🎜 nicht empfangen >Tutorial zur Netzwerkanforderungskapselung für die Entwicklung von Miniprogrammen

Letztendlich dachte ich, es handele sich um ein Inhaltsproblem. Am Ende war es in Ordnung, es in Kleinbuchstaben zu ändern. Ich habe das Gefühl, dass WeChat, ein so großartiges Team, einen sehr dummen Fehler gemacht hat, der mich als Entwickler gequält hat. Sag es mir nicht, lass uns in den Code einsteigen.

1. HTTP-Anfrageklasse
import util from &#39;util.js&#39;;/**
 * url 请求地址
 * success 成功的回调
 * fail 失败的回调
 */function _get( url, success, fail ) {
  
 console.log( "------start---_get----" );
 wx.request( {
 url: url,
 header: {  // &#39;Content-Type&#39;: &#39;application/json&#39; },
 success: function( res ) {
  success( res ); },
 fail: function( res ) {
  fail( res ); } });
 console.log( "----end-----_get----" );}/**
 * url 请求地址
 * success 成功的回调
 * fail 失败的回调
 */function _post_from(url,data, success, fail ) {
 console.log( "----_post--start-------" );
 wx.request( {
 url: url,
 header: { &#39;content-type&#39;: &#39;application/x-www-form-urlencoded&#39;, },
 method:&#39;POST&#39;,
 data:{data: data},
 success: function( res ) {
  success( res ); },
 fail: function( res ) {
  fail( res ); } });
 console.log( "----end-----_get----" );}  
 /**
 * url 请求地址
 * success 成功的回调
 * fail 失败的回调
 */function _post_json(url,data, success, fail ) {
 console.log( "----_post--start-------" );
 wx.request( {
 url: url,
 header: {  &#39;content-type&#39;: &#39;application/json&#39;, },
 method:&#39;POST&#39;,
 data:data,
 success: function( res ) {
  success( res ); },
 fail: function( res ) {
  fail( res ); } });
 console.log( "----end----_post-----" );}module.exports = {
 _get: _get,
 _post:_post,
 _post_json:_post_json}
Nach dem Login kopieren

2. Testfall
2.1 Get-Anfrage
//GET方式let map = new Map();map.set( &#39;receiveId&#39;, &#39;0010000022464&#39; );let d = json_util.mapToJson( util.tokenAndKo( map ) );console.log( d );var url1 = api.getBaseUrl() + &#39;SearchTaskByReceiveId?data=&#39;+d;network_util._get( url1,d,function( res ) {console.log( res );that.setData({
 taskEntrys:res.data.taskEntrys});}, function( res ) {console.log( res );});
Nach dem Login kopieren

2.2 POST-Anfrage
//Post方式 let map = new Map();
 map.set( &#39;receiveId&#39;, &#39;0010000022464&#39; ); let d = json_util.mapToJson( util.tokenAndKo( map ) );
 console.log( d ); var url1 = api.getBaseUrl() + &#39;SearchTaskByReceiveId&#39;;
 network_util._post( url1,d, function( res ) {
 console.log( res );
 that.setData({
  taskEntrys:res.data.taskEntrys }); }, function( res ) {
 console.log( res ); });
Nach dem Login kopieren

Bild: 2.png

Tutorial zur Netzwerkanforderungskapselung für die Entwicklung von Miniprogrammen

Effekt

Bild: 3.png

Tutorial zur Netzwerkanforderungskapselung für die Entwicklung von Miniprogrammen

Das obige ist der detaillierte Inhalt vonTutorial zur Netzwerkanforderungskapselung für die Entwicklung von Miniprogrammen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage