GVKun编程网logo

JFinal 极速开发微信公众号(java公众号开发)

11

如果您想了解JFinal极速开发微信公众号的相关知识,那么本文是一篇不可错过的文章,我们将对java公众号开发进行全面详尽的解释,并且为您提供关于C#可以开发微信公众号吗?、C#开发微信公众号接口开发

如果您想了解JFinal 极速开发微信公众号的相关知识,那么本文是一篇不可错过的文章,我们将对java公众号开发进行全面详尽的解释,并且为您提供关于C# 可以开发微信公众号吗?、C#开发微信公众号接口开发、C#开发微信公众号接口开发详细介绍、flask开发微信公众号的有价值的信息。

本文目录一览:

JFinal 极速开发微信公众号(java公众号开发)

JFinal 极速开发微信公众号(java公众号开发)

10 分钟搭建属于自己的 ngork 服务器,实现内网穿透

Android 微信、支付 App 支付 SDK

IJPay 让支付触手可及,实现微信、支付宝系列支付

  1. 项目下载并导入 IDE
  2. 开启开发模式
  3. 消息交互详解
  4. 自定义菜单
  5. 授权获取用户信息
  6. 一键导出微信所有用户信息到 Excel
  7. 如何使用 JSSDK
  8. 微信买单
  9. 微信公众号支付
  10. 微信扫码支付
  11. 微信刷卡支付
  12. 微信模板消息
  13. 微信红包
  14. 会员注册、找回密码、登陆(邮箱与手机验证码)
  15. 微信 APP 支付
  16. 推广支持 - 临时、永久二维码
  17. 支付宝 Wap 支付
  18. 支付宝 APP 支付
  19. 一张二维码同时支持微信、支付宝支付
  20. PC 微信扫码登陆、UnionID 机制获取用户基本信息
  21. 微信一次性订阅消息
  22. 微信 H5 支付
  23. H5 仿微信支付键盘

C# 可以开发微信公众号吗?

C# 可以开发微信公众号吗?

只学了 C# 和一点儿前端基础。

回复内容:

能 楼主说的是 微信公众账号 开发吗?

您可以看一下 Senparc.Weixin ,他是一款开源的 SDK,可以很简单的让您完成与微信公众平台的对接。

传送门:GitHub - JeffreySu/WeiXinMPSDK: 微信公众平台SDK Senparc.Weixin for C#,已支持微信公众号、企业号、开放平台、微信支付、JSSDK。 看在你基础如此薄弱的情况下Dos.WeChat 微信开发组件 拿去,中文的文档,nuget里面可以直接安装 wp上的微信不就是c#写得么 哦,我自己的微信机器人就是用C#开发的了,并且部署到azure上。
现在有一个叫做DragonGate 的项目https://dragongate.live.com/,已经用C#封装好了微信的一些接口,同时可以连接到office 365和one drive,你可以看看。 最简单是用http://asp.net写个web窗体来响应就可以了,C#实现,也不用写前端代码 你的基础还是不行… php 可以开发微信吗?
python可以开发微信吗?
ruby可以开发微信吗?
golang可以开发微信吗?
erlang可以开发微信吗?
java可以开发微信吗?
等等。。。。

你对C#得多不信任啊。。。 能做Web开发的就能开发微信号 当然可以啊 !这个和语言关系不大!

C#开发微信公众号接口开发

C#开发微信公众号接口开发

具体实现方式不多说了,请看下文

一、前言

当下微信公众号几乎已经是每个公司必备的,但是大部分微信公众账号用户体验都欠佳,特别是涉及到用户绑定等,需要用户进行复杂的操作才可以和网站绑定,或者很多公司直接不绑定,而是每次都让用户填写账号密码。作为微信接口开发人员我们知道网页授权可以用作微信网页用作安全登录,带参数二维码的使用用作记录用户来源,模板消息用作购物消费等消息的通知,但是很少看到有综合利用这些高级接口做出体验比较好的公众账号,这里分享一些我开发的用户绑定和验证码的一些心得。所需要的接口有基础的回复、网页授权、带参数二维码、模板消息。所以这里所讲的必须是认证服务号(没办法腾讯接口限制真的好为难我们这些开发人员)。

二、需求

1.pc网站绑定个人微信账号2.pc网站获取验证码(用户注册即绑定、找回密码等场景)

三、实现流程及与传统方法对比

1.pc网站绑定个人微信账号:

传统的方法--是输入账号和密码,然后通过网页授权绑定,下次可以免登陆

利用微信接口--方法1、网页授权

在pc端生成一个网页授权的二维码:url+id=32132312其中id为用户的唯一标识,用微信扫描 保存id和openid在对应的用户表即绑定成功

       方法2、申请带参数二维码+网页授权

在通过微信接口申请临时的带参数二位码显示在pc网页上,所带参数是根据登录用户生成的唯一标识一串数字 ,当用户扫描的时候微信回复的参数即为这串数字,将这串数字和openid保存在数据库对应的用户表中即可。

注意:在这建议使用第2中方法:第1中方法是直接在网页中绑定,用户可能没有关注我们的公众账号,而第二种方法当用户没有关注的时候提示先关注,关注完之后自动绑定,并且提示成功,如果关注也是直接跳转到我们的公众账号

四、用户绑定流程图

1.网页授权绑定的流程图:

2.带参数二维码绑定

五、用户绑定实现方法主要代码

这里以绑定第二种方法为例(网页授权参考我之前文章C#微信公众号开发-高级接口-之网页授权oauth2.0获取用户基本信息(二))

1.首先用户登录pc网站 获取到唯一标识也可以即时生成,然后以唯一标识为参数向微信服务器申请带参数的二维码方法详情可参照我之前的文章:C#微信公众号接口开发实例-高级接口-申请带参数的二维码

主要代码获取ticket 其中 scene_id即为用户唯一标识 二维码链接https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET 嵌入到网页中即可

 1 /// <summary> 2 /// 调用微信接口获取带参数临时二维码的ticket 3 /// 使用方法:https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET 4 /// </summary> 5 /// <param name="scene_id">二维码带的参数</param> 6 /// <returns>json:ticket:换取二维码的凭证,expire_seconds:凭证有效时间,url:二维码解析后的地址。此处返回ticket 否则返回错误码</returns> 7 public string GetQrcode(string appid,string appsecret,Int32 scene_id) 8 { 9   string QrcodeUrl = "https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token={0}";//WxQrcodeAPI接口10   string Accesstoken = getTokenSession(appid,appsecret);//拉取全局的Accesstoken11   QrcodeUrl = string.Format(QrcodeUrl,Accesstoken);12   string PostJson = "{\"expire_seconds\": 1800,\"action_name\": \"QR_SCENE\",\"action_info\": {\"scene\": {\"scene_id\": " + scene_id + "}}}";13   string ReText = WebRequestPostOrGet(QrcodeUrl,PostJson);//post提交14   Dictionary<string,object> reDic = (Dictionary<string,object>)Jss.DeserializeObject(ReText);15   if (reDic.ContainsKey("ticket"))16   {17     return reDic["ticket"].ToString();//成功18   }19   else20   {21     return reDic["errcode"].ToString();//返回错误码22   }23 }

2.用户扫描带参数二维码(此处为临时二维码),非关注用户提示关注,关注后直接绑定,关注用户可以直接绑定,原理是扫描带参数二维码,微信会接收到xml形式的数据 可参考我之前文章C#/ASP.NET MVC微信公众号接口开发之从零开发(二) 接收微信消息并且解析XML(附源码):

解析获取到scene_id因为消息也带用户信息openid 将scene_id和openid保存到用户表即完成主要代码如下:

 1 switch (WxXmlModel.Event) 2 { 3   case "subscribe": 4     if (string.IsNullOrEmpty(WxXmlModel.EventKey)) 5     { 6       XML = sohovan.com.wxapi.ResponseMessage.GetText(WxXmlModel.FromUserName,WxXmlModel.ToUserName,"关注成功"); 7     } 8     else 9     {10       XML = sohovan.com.wxapi.ResponseMessage.SubScanQrcode(WxXmlModel.FromUserName,WxXmlModel.EventKey);//扫描带参数二维码先关注后推送事件11     }12     break;13   case "SCAN":14     XML = sohovan.com.wxapi.ResponseMessage.ScanQrcode(WxXmlModel.FromUserName,WxXmlModel.EventKey);//扫描带参数二维码已关注 直接推送事件15     break;16 }

扫描分为两种一种是先关注后进入公众号(Event=="subscribe")还有一种是直接进入公众号 (Event="SCAN") 其中FromUserName是用户的openid微信唯一标识 此时将openid 和scene_id保存到对应用户表即可需要

注意的是关注扫描中EventKey为qrscene_加标识 如果标识为321312那么EventKey="qrscene_321312",已经关注的EventKey="321312"。

六、模板消息获取验证码实现方法

上一步已经将pc网站和微信绑定,如果我们忘记密码,传统的做法是可以通过短信找回,弊端是对于手机号码经常换的用户可能找不回,相信对于大部分年轻人来说换10个手机号码也不会去换一个QQ好一个微信号,这个时候我们通过微信找回我们的密码是相对安全的

实现方法很多,比如在微信中修改,但是麻烦(需要查找到公众账号,找到对应的按钮等等),这里可以利用带参数二维码用户扫描pc网站的方式获取,类似上面的方法,而此时利用微信模板消息,体验又更加方便。

获取验证码流程图:

这个过程就是和短信类似,但是我觉得无论是从经济还是用营销上考虑都是好处多多,比较如果量大,每个月验证各种东西以万条算的网站短信费用就可以省不小一笔,同时还可以为微信引流一举多得。

希望大家能够喜欢。

C#开发微信公众号接口开发详细介绍

C#开发微信公众号接口开发详细介绍

这篇文章主要介绍了C#微信公众号接口开发,灵活利用网页授权、带参数二维码、模板消息,提升用户体验之完成用户绑定个人微信及验证码获取,需要的朋友可以参考下

具体实现方式不多说了,请看下文

一、前言

当下微信公众号几乎已经是每个公司必备的,但是大部分微信公众账号用户体验都欠佳,特别是涉及到用户绑定等,需要用户进行复杂的操作才可以和网站绑定,或者很多公司直接不绑定,而是每次都让用户填写账号密码。作为微信接口开发人员我们知道网页授权可以用作微信网页用作安全登录,带参数二维码的使用用作记录用户来源,模板消息用作购物消费等消息的通知,但是很少看到有综合利用这些高级接口做出体验比较好的公众账号,这里分享一些我开发的用户绑定和验证码的一些心得。所需要的接口有基础的回复、网页授权、带参数二维码、模板消息。所以这里所讲的必须是认证服务号(没办法腾讯接口限制真的好为难我们这些开发人员)。

二、需求

1.pc网站绑定个人微信账号2.pc网站获取验证码(用户注册即绑定、找回密码等场景)

三、实现流程及与传统方法对比

1.pc网站绑定个人微信账号:

传统的方法--是输入账号和密码,然后通过网页授权绑定,下次可以免登陆

利用微信接口--方法1、网页授权

在pc端生成一个网页授权的二维码:url+id=32132312其中id为用户的唯一标识,用微信扫描 保存id和openid在对应的用户表即绑定成功

       方法2、申请带参数二维码+网页授权

在通过微信接口申请临时的带参数二位码显示在pc网页上,所带参数是根据登录用户生成的唯一标识一串数字 ,当用户扫描的时候微信回复的参数即为这串数字,将这串数字和openid保存在数据库对应的用户表中即可。

注意:在这建议使用第2中方法:第1中方法是直接在网页中绑定,用户可能没有关注我们的公众账号,而第二种方法当用户没有关注的时候提示先关注,关注完之后自动绑定,并且提示成功,如果关注也是直接跳转到我们的公众账号

四、用户绑定流程图

1.网页授权绑定的流程图:

C#开发微信公众号接口开发详细介绍

2.带参数二维码绑定

C#开发微信公众号接口开发详细介绍

五、用户绑定实现方法主要代码

这里以绑定第二种方法为例

1.首先用户登录pc网站 获取到唯一标识也可以即时生成,然后以唯一标识为参数向微信服务器申请带参数的二维码方法详情可参照我之前的文章:C#微信公众号接口开发实例-高级接口-申请带参数的二维码

主要代码获取ticket 其中 scene_id即为用户唯一标识 二维码链接https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET 嵌入到网页中即可

 /// <summary> 
 /// 调用微信接口获取带参数临时二维码的ticket 
 /// 使用方法:https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET 
 /// </summary> 
 /// <param name=scene_id>二维码带的参数</param> 
 /// <returns>json:ticket:换取二维码的凭证,expire_seconds:凭证有效时间,url:二维码解析后的地址。此处返回ticket 否则返回错误码</returns> 
 public string GetQrcode(string appid, string appsecret, Int32 scene_id) 
 { 
   string QrcodeUrl = https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token={0};//WxQrcodeAPI接口
   string Accesstoken = getTokenSession(appid, appsecret);//拉取全局的Accesstoken11   QrcodeUrl = string.Format(QrcodeUrl, Accesstoken);
   string PostJson = {\expire_seconds\: 1800, \action_name\: \QR_SCENE\, \action_info\: {\scene\: {\scene_id\:  + scene_id + }}};
   string ReText = WebRequestPostOrGet(QrcodeUrl, PostJson);//post提交
   Dictionary<string, object> reDic = (Dictionary<string, object>)Jss.DeserializeObject(ReText);
   if (reDic.ContainsKey(ticket))
 
     return reDic[ticket].ToString();//成功
   }
  else
   {
     return reDic[errcode].ToString();//返回错误码
   }
 }


2.用户扫描带参数二维码(此处为临时二维码),非关注用户提示关注,关注后直接绑定,关注用户可以直接绑定,原理是扫描带参数二维码,微信会接收到xml形式的数据

解析获取到scene_id因为消息也带用户信息openid 将scene_id和openid保存到用户表即完成主要代码如下:

 switch (WxXmlModel.Event) 
 { 
   case subscribe: 
     if (string.IsNullOrEmpty(WxXmlModel.EventKey)) 
     { 
       XML = sohovan.com.wxapi.ResponseMessage.GetText(WxXmlModel.FromUserName, WxXmlModel.ToUserName,关注成功); 
     } 
     else 
     {
       XML = sohovan.com.wxapi.ResponseMessage.SubScanQrcode(WxXmlModel.FromUserName, WxXmlModel.ToUserName, WxXmlModel.EventKey);
 //扫描带参数二维码先关注后推送事件11     }
     break;
   case SCAN:
     XML = sohovan.com.wxapi.ResponseMessage.ScanQrcode(WxXmlModel.FromUserName, WxXmlModel.ToUserName, WxXmlModel.EventKey);
 //扫描带参数二维码已关注 直接推送事件
     break;
 }

扫描分为两种一种是先关注后进入公众号(Event==subscribe)还有一种是直接进入公众号 (Event=SCAN) 其中FromUserName是用户的openid微信唯一标识 此时将openid 和scene_id保存到对应用户表即可需要

注意的是关注扫描中EventKey为qrscene_加标识 如果标识为321312那么EventKey=qrscene_321312,已经关注的EventKey=321312。

六、模板消息获取验证码实现方法

上一步已经将pc网站和微信绑定,如果我们忘记密码,传统的做法是可以通过短信找回,弊端是对于手机号码经常换的用户可能找不回,相信对于大部分年轻人来说换10个手机号码也不会去换一个QQ好一个微信号,这个时候我们通过微信找回我们的密码是相对安全的

实现方法很多,比如在微信中修改,但是麻烦(需要查找到公众账号,找到对应的按钮等等),这里可以利用带参数二维码用户扫描pc网站的方式获取,类似上面的方法,而此时利用微信模板消息,体验又更加方便。

获取验证码流程图:

C#开发微信公众号接口开发详细介绍

这个过程就是和短信类似,但是我觉得无论是从经济还是用营销上考虑都是好处多多,比较如果量大,每个月验证各种东西以万条算的网站短信费用就可以省不小一笔,同时还可以为微信引流一举多得。

flask开发微信公众号

flask开发微信公众号

 

1.进入微信公众号首页,进行注册登录 https://mp.weixin.qq.com/

2.进入个人首页,进行公众号设置

可参照 公众号文档 进行开发

开发前 先阅读 接口权限列表

3.配置服务器 服务器地址(URL) 令牌(Token)
 开发者基本配置

import hashlib
@app.route(''/wx'',methods=[''GET'',''POST''])
def wx():
    if request.method == ''GET'':
        signature = request.args.get(''signature'')
        timestamp = request.args.get(''timestamp'')
        echostr = request.args.get(''echostr'')
        nonce = request.args.get(''nonce'')
        token = ''mytoken1''
        if len(request.args)==0:
            return "hello, this is handle view"
        list = [token, timestamp, nonce]
        list.sort()
        s = list[0]+list[1]+list[2]
        hashcode = hashlib.sha1(s.encode(''utf-8'')).hexdigest()
        if hashcode == signature:
            return echostr
        else:
            print(''验证失败'')
            return ""

重新启动成功后(python main.py 80),点击提交按钮。若提示”token验证失败”, 请认真检查代码或网络链接等。若token验证成功,会自动返回基本配置的主页面,点击启动按钮

4.接收用户发送的消息 (即粉丝给公众号发送的文本消息)
公众平台发送的xml至开发者服务器。
形式:

发送xml

# 接收
        import xml.etree.cElementTree as ET
        
        xml = ET.fromstring(request.data)
        toUser = xml.find(''ToUserName'').text
        fromUser = xml.find(''FromUserName'').text
        msgType = xml.find("MsgType").text

5.自动回复 文本消息

     if msgType == ''text'':
		......
        reply = ''''''<xml>
                            <ToUserName><![CDATA[%s]]></ToUserName>
                            <FromUserName><![CDATA[%s]]></FromUserName>
                            <CreateTime>%s</CreateTime>
                            <MsgType><![CDATA[text]]></MsgType>
                            <Content><![CDATA[%s]]></Content>
                            </xml>''''''
        response = make_response(reply % (fromUser, toUser, str(int(time.time())), end))
        response.headers[''content-type''] = ''application/xml''
        return response

6. 实现“图”尚往来

        elif msgType == ''image'':
            img = xml.find(''MediaId'').text
            reply = ''''''<xml>
                                <ToUserName><![CDATA[%s]]></ToUserName>
                                <FromUserName><![CDATA[%s]]></FromUserName>
                                <CreateTime>%s</CreateTime>
                                <MsgType><![CDATA[image]]></MsgType>
                                 <Image>
                                 <MediaId><![CDATA[%s]]></MediaId>
                                 </Image>
                                </xml>''''''
            response = make_response(reply % (fromUser, toUser, str(int(time.time())), img))
            response.headers[''content-type''] = ''application/xml''
            return response

7.临时素材

class Basic(object):
    def __init__(self):
        self.accessToken = ''''
        self.leftTime = ''''

    def real_get_access_token(self):
        AppID = ''....''
        AppSecret = ''...''
        postUrl = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s" % (AppID, AppSecret)
        resp = requests.get(url=postUrl)
        urlResp = json.loads(resp.text)
        access_token = urlResp[''access_token'']
        print(''access_token是'',access_token)
        return access_token
class Media(object):
    def __init__(self):
        self.access_token = Basic().real_get_access_token()

    def upload(self,type=''image'',path=None):
        files = {''apk'': open(path, ''rb'')}
        data = {''enctype'': ''multipart/form-data''}
        post_url = ''https://api.weixin.qq.com/cgi-bin/media/upload?access_token=%s&type=%s''%(self.access_token,type)
        resp = requests.post(url=post_url,data=data,files=files)
        urlResp = json.loads(resp.text)
        print(urlResp)

media = Media()
media.upload(path=''123.png'')

8.关注和取消事件

用户在关注与取消关注公众号时,微信会把这个事件推送到开发者填写的URL。方便开发者给用户下发欢迎消息或者做帐号的解绑。为保护用户数据隐私,开发者收到用户取消关注事件时需要删除该用户的所有信息。

微信服务器在五秒内收不到响应会断掉连接,并且重新发起请求,总共重试三次。
形式:
视图处理:

        elif msgType == ''event'':
            event = xml.find(''Event'').text
            if event == ''subscribe'':   #关注
                msg = ''输入想要视频资源关键字试试~''  
            else:  #取消关注
                msg = ''期待你的下次关注~''
            reply = ''''''<xml>
                                <ToUserName><![CDATA[%s]]></ToUserName>
                                <FromUserName><![CDATA[%s]]></FromUserName>
                                <CreateTime>%s</CreateTime>
                                <MsgType><![CDATA[text]]></MsgType>
                                <Content><![CDATA[%s]]></Content>
                                </xml>''''''
            response = make_response(reply % (fromUser, toUser, str(int(time.time())), msg))
            response.headers[''content-type''] = ''application/xml''
            return response

9.回复图文消息
在这里插入图片描述

            reply = ''''''<xml>
                                <ToUserName><![CDATA[%s]]></ToUserName>
                                <FromUserName><![CDATA[%s]]></FromUserName>
                                <CreateTime>%s</CreateTime>
                                <MsgType><![CDATA[news]]></MsgType>
                                <ArticleCount>1</ArticleCount><Articles><item><Title><![CDATA[%s]]></Title>
                                <Description><![CDATA[%s]]></Description>
                                <PicUrl><![CDATA[%s]]></PicUrl><Url>
                                <![CDATA[%s]]></Url></item></Articles>
                                </xml>''''''
            response = make_response(reply % (fromUser, toUser, int(time.time()), ''voice'',''voice Description'',''http://mmbiz.qpic.cn/mmbiz_jpg/jeXD1dScd9sHxTr4WGwywQiabrcrErmR9p86ZUDthLWcImgLepRMxYrhrVMemibp4nCHpyHFPn7yvYv5A49miarKQ/0?wx_fmt=jpeg'',''https://www.baidu.com''))
            response.headers[''content-type''] = ''application/xml''
            return response

截图:在这里插入图片描述
10.js接口安全域名

设置JS接口安全域名后,公众号开发者可在该域名下调用微信开放的JS接口。

注意事项:

1、可填写三个域名或路径(例:wx.qq.com或wx.qq.com/mp),需使用字母、数字及“-”的组合,不支持IP地址、端口号及短链域名。

2、填写的域名须通过ICP备案的验证。

3、 将文件MP_verify_hS2bkgbglKjk0udm.txt(点击下载)上传至填写域名或路径指向的web服务器(或虚拟主机)的目录(若填写域名,将文件放置在域名根目录下,例如wx.qq.com/MP_verify_hS2bkgbglKjk0udm.txt;若填写路径,将文件放置在路径目录下,例如wx.qq.com/mp/MP_verify_hS2bkgbglKjk0udm.txt),并确保可以访问

步骤1.,将文件引入到 项目同一级目录

步骤2.更改flask查找文件路径

因为查找路径为:wx.qq.com/MP_verify_hS2bkgbglKjk0udm.txt

app = Flask(name,static_url_path=’’)

 

今天的关于JFinal 极速开发微信公众号java公众号开发的分享已经结束,谢谢您的关注,如果想了解更多关于C# 可以开发微信公众号吗?、C#开发微信公众号接口开发、C#开发微信公众号接口开发详细介绍、flask开发微信公众号的相关知识,请在本站进行查询。

本文标签: