微信小程序开发(request请求后台获取不到data)

1微信的request的post请求后台获取不到data(当初这个问题纠结了好久好久),原因是post传递的data是json格式而不是key,value的格式,所以获取不到相应的data就是post请求应为表单模式的data,微信小程序提供的datajson格式完全获取不到。

解决方法:

1.改变header

header: {
‘Content-Type‘: ‘application/json;charset=UTF-8;‘
},

2.query的格式传递post请求就可以了,不过这个有点。。你懂的,我用了这种方放对request进行了二次封装,代码如下:

/**
***对微信小程序的request进行二次封装
***注:兼容java接口的form请求
 **/
/**
***create by jianchep 2016/11/26
 **/
var config = require(‘../config.js‘)
module.exports = function (obj) {
    if (!obj.url) {
        console.warn(‘请输入url接口‘)
        return
    }
    let url = config.javaHost + obj.url + ‘?format=json‘
    let data = obj.data || {}
    let formData = obj.formData || {}
    let formDataString = ‘‘
    for(var key in formData){
        formDataString += ‘&‘ + key + ‘=‘ + formData[key]
    }
    // console.log(‘formDataString--->>‘, formDataString)
    if (formDataString) {
        url += formDataString
    }
    console.log(url, 1231231231)
    let requestList = {
        url: url,
        data: data,
        header: {
            ‘Content-Type‘: ‘application/json‘
        },
        success: function(res){
            if (obj.success) {
                obj.success(res)
            } else {
                let str = ‘\"‘ + obj.url + ‘\"接口请求成功,请用success回调函数来得到返回值‘
                console.warn(str)
            }
        },
        fail: function(res) {
            if (obj.fail) {
                obj.fail(res)
            } else {
                let str = ‘\"‘ + obj.url + ‘\"接口请失败功,请用fail回调函数来得到返回值‘
                console.warn(str)
            }
        },
        complete: function (res) {
            if (obj.complete) {
                obj.complete(res)
            }
        }
    }
    if (obj.method) {
        requestList.method = obj.method.toUpperCase()
    }
    // console.log(‘api----->>‘, requestList)
    wx.request(requestList)
}

有点鬼畜还是第一版目前还是能用的- -

时间: 2024-10-12 21:49:15

微信小程序开发(request请求后台获取不到data)的相关文章

监控微信小程序wx.request请求失败

在微信小程序里,与后台服务器交互的主要接口函数是wx.request(),用于发起 HTTPS 网络请求.其重要性不言而喻.然而,却经常遇到请求失败的问题,笔者特意谷歌"wx.request 请求失败",可以搜索到很多相关的文章,下面列出一些: wx.request 失败| 微信开放社区 微信小程序 wx.request 请求失败- SegmentFault 思否 小程序部分机型小程序用户无法发起 wx.request 请求,网络错误问题 ... wx.request()失败,requ

微信小程序开发:http请求

在微信小程序进行网络通信,只能和指定的域名进行通信,微信小程序包括四种类型的网络请求. 普通HTTPS请求(wx.request) 上传文件(wx.uploadFile) 下载文件(wx.downloadFile) WebSocket通信(wx.connectSocket) 这里以介绍wx.request,wx.uploadFile,wx.dowloadFile三种网络请求为主 设置域名 要微信小程序进行网络通信,必须先设置域名,不然会出现错误: URL 域名不合法,请在 mp 后台配置后重试

微信小程序开发——点击按钮获取用户授权没反应或反应很慢的解决方法

异常描述: 点击按钮获取用户手机号码,有的时候会出现点击无反应或很久之后才弹出用户授权获取手机号码的弹窗,这种情况下,也会出现点击穿透的问题(详见:微信小程序开发——连续快速点击按钮调用小程序api返回后仍然自动重新调用的异常处理) 异常解析: 1. getPhoneNumber的使用: 对于 getPhoneNumber(OBJECT) API,由于小程序需要用户主动触发才能发起获取手机号接口,所以该功能不由 API 来调用,需用 <button> 组件的点击来触发(具体使用方法详见getP

微信小程序开发之从相册获取图片 使用相机拍照 本地图片上传

1.index.wxml 1 <!--index.wxml--> 2 <button style="margin:30rpx;" bindtap="chooseimage">获取图片</button> 3 <image src="{{tempFilePaths }}" mode="aspecFill" style="width: 100%; height: 450rpx&qu

【微信小程序】request请求POST提交数据,记得要加上header

wx.request({ url: '*******', data: { "type":"nearest_village", "district": that.data.district, }, header: { "Content-Type": "application/x-www-form-urlencoded" }, method: 'POST', success: function(res) { /

微信小程序开发(九)获取手机连接的wifi信息

// succ.wxml <view>WIFI ssid:{{wifissid}}</view> <view>WIFI bssid:{{wifiBssid}}</view> // succ.js var app = getApp() Page({ data: { wifissid: '', // WIFI ssid wifiBssid: '' // WIFI bssid }, onLoad: function (e) { // 获取参数 var that =

《微信小程序》, request 请求数据

wx.request({ url: "路径", method: 'post', header: { "Content-Type": "application/x-www-form-urlencoded" }, data: { }, success: function (res) { console.log(res) } }) 点击详情,本地设置,选择不校验合法域名 把这个勾选. 原文地址:https://www.cnblogs.com/yetie

微信小程序开发《三》:微信小程序请求不能使用session的原因及解决办法

本人在前面的微信小程序开发<二>中提到要想在服务端保持状态需要在客户端第一次请求服务器的时候给客户端返回一个sessionid,由客户端在本地保存,下次请求的时候在header里面带上这个sessionid,写到cookie字段里.但是最近发现请求时哪怕每次在header里带上sessionid还是不能拿到同一个session,百度后终于发现坑了(也不知道微信为啥要这么做),原来微信对wx.request这个API做了修改,小程序发起的请求并不是直接请求我们的后台服务器,而是先通过微信的服务器

微信小程序开发如何获取定位信息

当我们在使用微信小程序时,会弹出一个获取你的定位信息.那么这个功能是怎样实现的,下面木鱼小铺(https://www.muyu007.cn)就和大家科普一下微信小程序开发如何获取定位信息? 我们一般通过调用wx.getLocation()获取当前的地理位置,为了能够获得准确的定位信息,我们还需要借助第三方地图服务API来实现.比如腾讯地图或百度地图. 下面我们就以借助腾讯地图为例,看看如何获取定位信息. 第一步:你需要去腾讯地图平台上注册一个账号,在管理后台中创建密钥. 第二步:登录进入有一个界