支付宝小程序开发练习-重构,在app.js获取用户信息(三)

支付宝小程序在前端只能获取到用户昵称和头像,但是这是远远不够的,我们至少需要获取到用户的支付宝User ID,这个时候就必须在后端利用支付宝的SDK来获取了,当然前端要发出 httprequest 请求,下面结合前两篇的例子进行修改

支付宝小程序前端

app.js

App({
  globalData:{
    studentid:'',
    username:'',
    apiurl: 'http://XXX'
  }, 
  getUserInfo(){
    var that = this
    return new Promise((resovle,reject)=>{
      if(this.userInfo) resovle(this.userInfo);
      
      //调用用户授权 api 获取用户信息
      my.getAuthCode({
        scopes: 'auth_user', 
        success:(res) =>{
           if (res.authCode) {    
             my.httpRequest({
               url: that.globalData.apiurl + '/api/AliPay/GetUserInfo',
               method: 'GET',
               data: {
                  auth_code: res.authCode
               },
               dataType: 'json',
               success: function(res) {
                  that.globalData.studentid = res.data.data.student_id;
                  that.globalData.username = res.data.data.user_name;
                  //获取用户信息,照片、昵称
                  my.getAuthUserInfo({
                    scopes: ['auth_user'],
                    success: (res) => {
                      that.userInfo = res;
                      resovle(that.userInfo);
                   },
                   fail:() =>{
                      reject({});
                   }
                  });
                  console.log('返回UserDetail', res.data.data);         
               },
               fail: function(res) {
                  my.alert({content: 'fail'});
               },
               complete: function(res) {
                  my.hideLoading();
               }
            });
          }
        },
        fail:() =>{
          reject({});
        }
      });
    });
  },

  onLaunch(options) {

  },
  onShow(options) {
    // 从后台被 scheme 重新打开
  },
});

上面的代码调取后端webapi  http://XXX/api/AliPay/GetUserInfo 来获取用户信息,并把取到的userid,username 存到全局变量 globalData 里面

const app = getApp();

Page({
  data: {
    src: '',
    username: '',
    studentid: ''
  },
  imageError: function (e) {
    console.log('image 发生错误', e.detail.errMsg)
  },
  imageLoad: function (e) {
    console.log('image 加载成功', e);
  },
  onLoad(query) {
    // 页面加载
    app.getUserInfo().then(
      user => {
            console.info(user);
            //设置头像
            if (user.avatar.length > 0) {
               this.setData({src: user.avatar});
            }
            else{
               this.setData({src: '/images/tou.png'});
            } 
            //设置用户名    
            if (app.globalData.username)
            {
               this.setData({username: app.globalData.username});
            }
            else
            {
               this.setData({username: user.nickName});
            }

            if(app.globalData.studentid)
            {
               //设置UserId
               this.setData({studentid: app.globalData.studentid}); 
            }
        }
    );
  },
  onShow() {
    // 页面显示
       
  },
  onReady() {

     
  }
});

本来官方只提供了.net framwork 的SDK,但网上已经有人移植了.net core 的版本,运行 Install-Package Alipay.AopSdk.Core 进行安装,在 appsettings.json 进行如下的配置,写上你的小程序公匙,私匙,appid 等参数 uid 可以不写

  "Alipay": {
    //校园码支付宝小程序正式环境
    "AlipayPublicKey": "",
    "AppId": "",
    "CharSet": "UTF-8",
    "GatewayUrl": "https://openapi.alipay.com/gateway.do",
    "PrivateKey": "",
    "SignType": "RSA2",
    "Uid": ""
  }

然后在后端core还需要注入Service

 Startup.cs 代码就补贴全部了,只贴相关的,这段代码就干这么个事,读取 appsettings.json  并注入服务

        private void ConfigureAlipay(IServiceCollection services)
        {
            var alipayOptions = Configuration.GetSection("Alipay").Get<AlipayOptions>();
            //检查RSA私钥
            AlipayConfigChecker.Check(alipayOptions.SignType, alipayOptions.PrivateKey);
            services.AddAlipay(options => options.SetOption(alipayOptions)).AddAlipayF2F();
        }


        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            //配置alipay服务
            ConfigureAlipay(services);
            ......

在得到从前端传过来的授权码之后,利用授权得到用户信息 

        private AlipayUserInfoShareResponse GetShareResponse(string auth_code)
        {
            var alipaySystemOauthTokenRequest = new AlipaySystemOauthTokenRequest
            {
                Code = auth_code,
                GrantType = "authorization_code"
            };
            var oauthTokenResponse = _alipayService.Execute(alipaySystemOauthTokenRequest);
            AlipayUserInfoShareRequest requestUser = new AlipayUserInfoShareRequest();
            AlipayUserInfoShareResponse userinfoShareResponse = _alipayService.Execute(requestUser, oauthTokenResponse.AccessToken);
            return userinfoShareResponse;
        }

        /// <summary>
        /// 获取用户信息
        /// </summary>
        /// <param name="auth_code"></param>
        /// <returns></returns>
        [HttpGet]
        [Route("GetUserInfo")]
        public ActionResult GetUserInfo(string auth_code)
        {
            try
            {
                AlipayUserInfoShareResponse userinfoShareResponse = GetShareResponse(auth_code);
                return new JsonResult(new { data = userinfoShareResponse });
            }
            catch (Exception ex)
            {
                log.Error("错误:" + ex.ToString());
                return new JsonResult(new { data = ex.ToString() });
            }
        }

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: PyCharm是一款Python集成开发环境,是JetBrains公司开发的一款强大的Python IDE。它提供了许多先进的功能,包括代码自动完成、代码检查、调试工具、Web开发支持等等,并可以与 Git、GitHub、Docker等常用的开发工具集成。PyCharm分为专业版和社区版两种,其中社区版是免费的,适合个人开发者和初学者学习使用。pycharm-community-2021.2.3.exe是PyCharm社区版的安装文件,它可以在Windows操作系统上运行。用户可以通过下载、运行这个安装文件来安装PyCharm社区版,之后便可以使用这个IDE进行Python开发。PyCharm在开发过程中提供了许多方便的工具和快捷键,使开发效率大大提高。同时,它还支持多种开发插件,可以根据自己的需要来选择安装使用。总之,PyCharm是一款非常优秀的Python IDE,如果您需要进行Python开发,它绝对是您不错的选择。 ### 回答2: pycharm-community-2021.2.3.exe是一款Python开发工具,它是由JetBrains公司推出的一款开源软件。它的主要功能是提供一个集成的开发环境,让Python开发者可以更加高效地编写代码。该软件支持Python的各种开发工作,包括代码编辑、调试、测试、版本控制等。同时,它还提供了丰富的插件来支持不同的Python框架和库。该软件还提供了智能代码补全、语法高亮、代码格式化等功能,可以大大提高Python开发者的编码效率。由于pycharm-community-2021.2.3.exe是开源软件,因此它可以免费使用和修改。总之,它是一个非常实用的软件,对于Python开发者来说是一款不可或缺的工具。 ### 回答3: pycharm-community-2021.2.3.exe是一个Python编程语言的开发环境软件,它是免费版本的PyCharm,由JetBrains开发。该软件支持Windows、Mac OS和Linux操作系统,具有很多有用的功能和特性,例如:语法高亮、源代码自动补全、代码调试、代码重构、版本控制、单元测试等,使得Python程序开发更加方便和高效。此外,该软件还支持多种框架和库,如Django、Flask、Numpy、Pandas、Matplotlib等。 该版本的PyCharm解决了之前存在的一些小bug,提供更好的稳定性和性能。对于那些想要学习Python编程或者从事Python开发的人来说,pycharm-community-2021.2.3.exe是一个非常好的选择,因为它可以帮助他们更容易地编写和调试Python程序,并提供了许多有用的开发工具和集成的第方库,极大地提高了工作效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值