当前位置:网站首页>. Net core - a queuing system for wechat official account
. Net core - a queuing system for wechat official account
2022-07-03 10:52:00 【Dotnet cross platform】
Part1 Preface
Wechat code scanning login , Wechat scanning code to obtain queuing information is very common , But you know how the principle is realized ? Today I'm going to solve your doubts !
Part2 Overall process
1 The browser requests the server to get the QR code image
The browser generates a unique value uuid
adopt uuid Get the QR code with parameters , take uuid As key Put in redis Cache server
Server generation uuid Back to the browser
adopt uuid Get the QR code with parameters , take uuid As key Put in redis Cache server
2 User scan code
Scan QR code by mobile phone , Then carry it with your mobile phone uuid And user information to send a request to the server of the mobile phone , The mobile server will carry it after receiving it uuid Go to redis The server queries the user .
Sweep the login code :
After querying the user successfully, a Token To web server , By parsing this Token You can take out the user's information , Then the browser successfully logged into wechat .
Push queue information Call the template message after querying the user successfully , Then the queue information push succeeds .
Part3 Development
Take wechat scanning code to obtain queuing information as an example
First step , obtain uuid
To simplify the process , And generated by the front end uuid.
The second step , obtain Access token
public async Task<string> GetAccessToken()
{
var accesstoken = await "https://api.weixin.qq.com/cgi-bin/token"
.SetQueryParams(new
{
grant_type = "client_credential",
appid = WeixinSetting.Appid,
secret = WeixinSetting.Appsecret
})
.GetJsonAsync<AccessToken>();
return accesstoken.Access_Token;
}The third step , Use uuid Create QR code ticket
public async Task<string> GetTicket(string uuid, string token)
{
var accesstoken = await "https://api.weixin.qq.com/cgi-bin/qrcode/create"
.SetQueryParams(new
{
access_token = token
})
.PostJsonAsync(new
{
expire_seconds = 604800,
action_name = "QR_STR_SCENE",
action_info = new
{
scene = new
{
scene_str = uuid
}
}
}).ReceiveJson<TicketUrl>();
return accesstoken.Ticket;
}Step four , adopt ticket In exchange for QR code
If you have passed ticket Requirements for generating QR code , It can be handled by itself , If there is no interface that can directly access wechat official account
public async Task<byte[]> GetQrCode(string ticket)
{
return await "https://mp.weixin.qq.com/cgi-bin/showqrcode"
.SetQueryParams(new
{
ticket = ticket
})
.GetBytesAsync();
}The complete code is as follows
[HttpGet("GetQrCode")]
public async Task<IActionResult> GetQrCode(string uuid)
{
return new FileContentResult( await _qrCodeServices.ShowQrCode(uuid), "image/jpeg");
}public async Task<byte[]> ShowQrCode(string uuid)
{
string token = await GetAccessToken();
string ticket = await GetTicket(uuid, token);
return await GetQrCode(ticket);
}In this way, we will generate a QR code image with parameters

Step six , Wechat scanning code for callback
Handle the message template push logic in the callback method
[HttpPost]
public async Task<string> post()
{
IHttpBodyControlFeature httpBodyControlFeature = Request.HttpContext.Features.Get<IHttpBodyControlFeature>();
if (httpBodyControlFeature != null )
{
httpBodyControlFeature.AllowSynchronousIO = true;
}
string content = new StreamReader(Request.Body).ReadToEnd();
await qrCodeServices.PushTemplateMessage(content);
return "success";
}public async Task PushTemplateMessage(string content)
{
XmlDocument doc = new XmlDocument();
doc.LoadXml(content);
if (doc.DocumentElement["MsgType"].InnerText != "Event") return;
if (doc.DocumentElement["Event"].InnerText != "SCAN") return;
string value = doc.DocumentElement["FromUserName"].InnerText;
string token = await GetAccessToken();
var accesstoken = await "https://api.weixin.qq.com/cgi-bin/message/template/send"
.SetQueryParams(new
{
access_token = token
})
.PostJsonAsync(new
{
touser = value,
template_id = "i4h4yHvgMgIoJ8-Mr49XcpbhMxmRXFJ5EF5DoOTGOMc",
data = new
{
first = new
{
value = " Current queue location ",
color = "#173177"
},
keyword1 = new
{
value = "70",
color = "#173177"
},
keyword2 = new
{
value = "40 minute ",
color = "#173177"
}
}
});
}In this way, it is successful to scan wechat code to obtain queuing information

Part4 summary
The article comes from every bit of life , This is also my improvisation , If you have better skills , Welcome to exchange , It is much joyful to share the joy than enjoy alone. , That's all for this article , I hope it will help you .
边栏推荐
- How to make a blood bar in the game
- 现在零基础转行软件测试还OK吗?
- Mysql5.7 installation and configuration tutorial (Graphic ultra detailed version)
- Flink -- 内置函数(ALL)
- Flink <-->Redis的使用介绍+with参数
- 正常一英寸25.4厘米,在影像领域是16厘米
- FileNotFoundError: Could not find module ‘... dll‘ (or one of its dependencies).
- 2021-09-22
- QT:QSS自定义 QSlider实例
- If you always feel that you need to persist in learning English
猜你喜欢

Install yolov3 (Anaconda)

8、 Transaction control language of MySQL

DAY 7 小练习

How to make a blood bar in the game

Leetcode skimming ---367

Unity小组工程实践项目《最强外卖员》策划案&纠错文档

多路IO转接——前导

Multilayer perceptron (pytorch)
![[SQL] an article takes you to master the operations related to query and modification of SQL database](/img/d7/7ac7788a586c4b9c0d7cdf54d974eb.png)
[SQL] an article takes you to master the operations related to query and modification of SQL database

Traversal of map set
随机推荐
Unity小组工程实践项目《最强外卖员》策划案&纠错文档
7、 Data definition language of MySQL (2)
Large scale e-commerce project - environment construction
年中了,准备了少量的自动化面试题,欢迎来自测
Strategic management of project organization
Leetcode skimming ---704
Unity group engineering practice project "the strongest takeaway" planning case & error correction document
The story of a 30-year-old tester struggling, even lying flat is extravagant
C project - dormitory management system (1)
Take you into the cloud native database industry, Amazon Aurora
Model selection for neural network introduction (pytorch)
游戏测试相关 测试一个英雄的技能(春招被问比较多的一道题)
Leetcode skimming ---75
snownlp情感分析
[untitled]
Bidding website architecture project progress -- Network Security
Uni app learning 1 bottom menu and parent-child components
Flink < --> Introduction to JDBC +with parameter
QT:QSS自定义QListView实例
Flink--自定义函数