wafer小程序服务器,Wafer - 企业级微信小程序全栈方案

Wafer 服务端 SDK - C#

68747470733a2f2f63692e6170707665796f722e636f6d2f6170692f70726f6a656374732f7374617475732f6769746875622f74656e63656e7479756e2f77656170702d6373686172702d7365727665722d73646b3f7376673d74727565

68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f6c6963656e73652f74656e63656e7479756e2f77656170702d6a6176612d7365727665722d73646b2e737667

本项目是 Wafer 组成部分,以 SDK 的形式为业务服务器提供以下服务:

SDK 获取

本项目遵守 MIT 协议,可以直接下载 SDK 源码进行修改、编译和发布。

如果使用自动部署并选择 C# 语言,则分配的业务服务器里已经部署了本 SDK 和 Demo 的发行版本。

API

请参考本项目 Wiki。

使用示例(ASP.NET MVC)

获得 SDK 源码后,需要在解决方案中添加 SDK 项目。创建 ASP.NET MVC 网站项目,并且添加对 SDK 项目的引用。

ff00d98ef89972775f7d8cc7b95521de.png

6743e541f8b7769d3c2e6e9fe93ecb2c.png

添加引用后,就可以使用 SDK 提供的服务。

配置 SDK

SDK 必须经过初始化配置之后才能使用。可以选择使用代码初始化或者使用配置文件初始化。初始化配置建议在 Application_Start 里进行。

使用代码初始化:

using QCloud.WeApp.SDK;

var configuration = new Configuration() {

// 业务服务器访问域名

ServerHost = "199447.qcloud.la",

// 鉴权服务地址

AuthServerUrl = "http://10.0.12.135/mina_auth/",

// 信道服务地址

TunnelServerUrl = "https://ws.qcloud.com/",

// 信道服务签名 key

TunnelSignatureKey = "my$ecretkey",

// 网络请求超时设置,单位为豪秒

NetworkTimeout = 30000

};

ConfigurationManager.Setup(configuration);

使用配置文件初始化:

using QCloud.WeApp.SDK;

var configFilePath = "C:\\qcloud\sdk.config";

ConfigurationManager.SetupFromFile(configFilePath);

关于 SDK 配置字段的含义以及配置文件格式的更多信息,请参考服务端 SDK 配置。

使用会话服务

登录

业务服务器提供一个路由处理客户端的登录请求,直接把该请求交给 SDK 来处理即可完成登录。登录成功后,可以获取用户信息。

using QCloud.WeApp.SDK.Authorization;

public class LoginController : Controller

{

/// GET /login

/// 实现登录接口,配合客户端 SDK 建立会话

public ActionResult Index()

{

try

{

// 使用 Request 和 Response 初始化登录服务

LoginService loginService = new LoginService(Request, Response);

// 调用登录接口,如果成功可以获得用户信息。如有需要,可以使用用户信息进行进一步的业务操作

UserInfo userInfo = loginService.Login();

Debug.WriteLine(userInfo);

}

catch (LoginServiceException ex)

{

// 登录失败会抛出登录异常

Debug.WriteLine(ex);

}

// 登录无论成功还是失败,都无需返回响应结果,因为登录服务已经使用 HTTP Response 进行输出

return null;

}

}

如果登录失败,Login() 方法会抛出异常,需要使用 try-catch 来捕获异常。该异常可以不用处理,抛出来是为了方便业务服务器可以进行记录和监控。

获取会话状态

客户端交给业务服务器的请求,业务服务器可以通过 SDK 来检查该请求是否包含合法的微信小程序会话。如果包含,则会返回会话对应的用户信息。

using QCloud.WeApp.SDK.Authorization;

/// GET /user

/// 利用建立的会话获取用户信息

public class UserController : Controller

{

// GET: User

public ActionResult Index()

{

try

{

// 使用 Request 和 Response 初始化登录服务

LoginService loginService = new LoginService(Request, Response);

// 调用检查登录接口,成功后可以获得用户信息,进行正常的业务请求

UserInfo userInfo = loginService.Check();

Response.AddHeader("Content-Type", "application/json");

// 获取会话成功,需要返回 HTTP 视图,这里作为示例返回了获得的用户信息

return Content(JsonConvert.SerializeObject(new

{

code = 0,

message = "OK",

data = new { userInfo }

}));

}

catch (Exception error)

{

// 可以处理登录失败的情况,但是注意此时无需返回 ActionResult,

// 因为登录失败的时候,登录服务已经输出登录失败的响应

Debug.WriteLine(error);

return null;

}

}

}

如果检查会话失败,或者会话无效,Check() 方法会抛出异常,需要使用 try-catch 来捕获异常。该异常可以不用处理,抛出来是为了方便业务服务器可以进行记录和监控。

阅读解决方案文档中的会话服务了解更多解决方案中关于会话服务的技术资料。

使用 SDK 提供信道服务

业务在一个路由上提供信道服务,只需把该路由上的请求都交给 SDK 的信道服务处理即可。

public class TunnelController : Controller

{

private TunnelService tunnelService = null;

/// GET /tunnel

/// 请求建立隧道连接

///

/// POST /tunnel

/// 用于信道服务器推送消息到业务服务器

public ActionResult Index()

{

// 创建信道服务处理信道相关请求

tunnelService = new TunnelService(Request, Response);

// 信道服务会自动响应请求,请不要使用 Response 进行二次请求

tunnelService.Handle(

// 需要实现信道处理器,ChatTunnelHandler 是一个实现的范例

handler: new ChatTunnelHandler(),

// 配置是可选的,配置 CheckLogin 为 true 的话,会在隧道建立之前获取用户信息,以便业务将隧道和用户关联起来

options: new TunnelHandleOptions() { CheckLogin = true }

);

// 返回 null 确保 MVC 框架不进行输出

return null;

}

}

使用信道服务需要实现处理器,来获取处理信道的各种事件,具体可参考接口 ITunnelHandler 的 API 文档以及配套 Demo 中的 ChatTunnelHandler 的实现。

阅读解决方案文档中的信道服务了解更多解决方案中关于鉴权服务的技术资料。

在DEMO基础上做开发

程序部署在  C:\inetpub\wwwwroot\

反馈和贡献

如有问题,欢迎使用 Issues 提出,也欢迎广大开发者给我们提 Pull Request。

LICENSE

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/472312.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android学习按键事件监听与Command模式

Android学习按键事件监听与Command模式 - Dufresne - 博客园 Android学习按键事件监听与Command模式 一 Command模式 意图: 将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化; 对请求排队或记录请求日志,以及支持…

postek二次开发_20190626_二次开发BarTender打印机_C#代码_一边读取TID_一边打印_打印机POSTEK...

demo代码如下:private void btnPrint_Click(object sender, EventArgs e){if (this.btnPrint.Text "停止打印"){SetBtnPrintUIEnable();return;}//禁用界面上的相关按钮SetBtnPrintUIDisable();var dt new DataTable();new Task(() >{///开始的打印//1. 获取选中…

fileinputstream_从Java中的FileInputStream读取字节

以下示例显示了如何从Java中的FileInputStream读取字节。import java.io.File;import java.io.FileInputStream;public class fileInputStream {public static void main(String[] args) {byte[] data new byte[1024]; //allocates memory for 1024 bytes//be careful about h…

LeetCode 1839. 所有元音按顺序排布的最长子字符串(滑动窗口)

文章目录1. 题目2. 解题1. 题目 当一个字符串满足如下条件时,我们称它是 美丽的 : 所有 5 个英文元音字母(a ,e ,i ,o ,u)都必须 至少 出现一次。这些元音字母的顺序都必须按照 字…

安川服务器显示run电机没电,安川变频器启动不运行是什么原因

即使按操作器的 RUN 键或输入外部运行信号,电机也不按照指令旋转? 电机不旋转变频器非驱动模式 确认 LED 操作器的 DRV 指示灯是否点亮。? 请操作 LED 操作器,进入驱动模式。(参照 77 页)按了 LO/RE 功能选择键(从控制回路端子输入指令时)在变频器停止…

EhLib TitleButton SVisibleColumnsEh = '错误的列';

unit EhLibConsts; interface resourcestring SClearSelectedCellsEh 清除选择的单元?; SInvalidTextFormatEh 错误的文本格式; SInvalidVCLDBIFFormatEh 错误的 VCLDBIF 格式; SErrorDuringInsertValueEh 插入值过程中出错:; SIgnoreErrorEh 忽略错…

python rpc webservice_PythonXMLRPC服务器端和客户端实例

一、远程过程调用RPCXML-RPC is a Remote Procedure Call method that uses XML passed via HTTP as a transport. With it, a client can call methods with parameters on a remote server (the server is named by a URI) and get back structured data. This module suppor…

python是动态_1.2. Python是动态语言

python是动态语言 1. 动态语言的定义 动态编程语言 是 高级程序设计语言 的一个类别,在计算机科学领域已被广泛应用。它是一类 在运行时可以改变其结构的语言 :例如新的函数、对象、甚至代码可以被引进,已有的函数可以被删除或是其他结构上的…

特征处理

学自 极客时间 《深度学习推荐系统实战》 特征分为两类: 类别特征(性别、地理位置、季节、天气、风格)数值型特征(年龄、收入、点击量、点击率) 类别特征经过 One-Hot 编码后放入特征向量、或者 多个的特征值采用 M…

C#整理1——进制转换

进制转换:二进制,八进制,十进制,十六进制。 (一)二进制转十进制: 1.写2 2.标指数,从右向左,从0开始依次标记 3.乘系数,一一对应。 4.相加。 例:二…

matlab打开笔记本摄像头_基于MATLAB调用电脑摄像头获取视频和图像

clear all;hwaitbar(0.1,请等待);%waitbar的作用是打开或者更新进度条 h waitbar(x,message)x表示进度条的比例长度,message是在进度条上显示的信息global vid;% global 的作用是定义全局变量vid videoinput(winvideo,1);close(h);preview(vid);%得到预览下的默认…

WIN 10 安装 Hadoop 2.7.7 + Spark 2.4.7 记录

文章目录0. 常规解压安装,并添加环境变量1. 下载并覆盖 bin 文件夹2. 使VERSION文件的clusterID一致3. 贴下单机配置4. 测试 Hadoop5. 安装Spark环境:win 10 java 1.8.0_281 Scala 2.11.11 Hadoop 2.7.7 Spark2.4.70. 常规解压安装,并添加…

ios验证邮箱格式

今天做注册界面时,用户在输入邮箱账号后,我不知道如何去辨别用户是否输入有误,我回想起最初我学过一个叫做"正则表达式"的方法, 但是不知道苹果是否能做到,果断的上网查找了一些相关资料。 最简单的就是利用…

canal mysql从库_canal中间件|数据增量同步解决方案

上一文中提到延时双删等策略实现数据一致性的时候,可能存在删除缓存失败的情况,就会出现缓存和数据库不一致的问题。为了应对删除缓存失败而导致数据不一致的问题,可以通过回溯数据库日志文件,提供一个保障的重试机制即可。流程如…

dbscan聚类算法matlab_密度聚类DBSCAN、HDBSCAN(转)

# 密度聚类DBSCAN、HDBSCANDBSCANDBSCAN(Density-Based Spatial Clustering of Applications with Noise,具有噪声的基于密度的聚类方法)是一种基于密度的空间聚类算法。该算法将具有足够密度的区域划分为簇,并在具有…

Spark IDEA 编程环境配置

文章目录1. 下载资料准备2. 建立项目、添加环境设置3. 第一个 Spark 程序学自:Spark机器学习实战 https://book.douban.com/subject/35280412/ 记录一下踩过的坑: 环境:win 10 java 1.8.0_281 Scala 2.11.11 Hadoop 2.7.7 Spark2.4.7 …

Makefile 基本知识

Technorati 标签: Makefile 基本知识最常见的书写方式: CC gcc LD ld STRIP strip CFLAGS : -Os -static -DEZ_OS_LINUX CLFLAGS : -Os -static all: mainEXEC main OBJS main.o mytool1.o mytool2.o INCS mytool1.h mytool2.ha…

python考试题库程序改错_求助,程序改错

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 最近在学习python,其中遇到一道习题是改错的。 原代码如下 def break_words(stuff): """This function will break up words for us.""" words stuff.split( ) return words def sort_…

redis 查看key的有效期_redis中key设置过期时间

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":9,"count":9}]},"card":[{"des":"兼容Redis协议标准的、提供持久化的内存数据…

天池 在线编程 订单分配(回溯)

文章目录1. 题目2. 解题1. 题目 描述 打车派单场景, 假定有N个订单,待分配给N个司机。 每个订单在匹配司机前,会对候选司机进行打分,打分的结果保存在N*N的矩阵score,其中score[i][j]代表订单 i 派给司机 j 的分值。 假定每个订单…