首页 > 代码库 > [转载红鱼儿]delphi 实现微信开发(2)接入微信公众号平台
[转载红鱼儿]delphi 实现微信开发(2)接入微信公众号平台
先要学习一下接入的资料,在这里,因为原理都在,所以一定要认真阅读,然后,利用Delphi实现一个对应函数:
function CheckSignature(const signature, timestamp, nonce, token:string): boolean;
var
strs: TStringList;
tmpStr: string;
begin
strs := TStringList.Create;
try
strs.Add(token);
strs.Add(timestamp);
strs.Add(nonce);
strs.Sort;
tmpStr :=strs[0] + strs[1] + strs[2];
tmpStr :=SHA1(tmpStr);
if tmpStr =signature then
Result := True
else
Result := False;
finally
FreeAndNil(strs);
end;
end;
函数的返回结果为真时,表示接入成功!该函数,参考csdn朋友上传的范例,表示感谢。在这个范例中,提供了SHA1函数的单元,所以,你要下载回来。
准备完这个函数,接下来,如何使用这个函数呢?
因为微信服务器是向接入的web服务器发送Get请求,所以,我们要在自己实现的kbmMW webserver的PerformGet方法中来调用这个CheckSignature。
function TDJ_FrmPhoneHTTPService.PerformGet(ClientIdent:TkbmMWClientIdentity; const AURL: string;
const Args: array of Variant): Variant;
var
FuncName: string;
qv: TkbmMWHttpQueryValues;//处理Get请求传递来的参数.
begin
if Length(Args) < 1 then
kbmMWRaiseException(KBMMW_ERR_SERVICE_HTTP_URLMISSING, ‘MissingURL.‘)
else
begin
FuncName :=UpperCase(copy(Args[0], 2, Length(Args[0]) - 1));
ifFuncName.Equals(‘WECHAT.HTML‘) then
begin
// 转微信接口
qv := TkbmMWHttpQueryValues.Create;
qv.AsString := Args[2];//取得get请求传递来的参数.
try
// 验证接入
if qv.ValueByName[‘echostr‘] <> ‘‘then//如果echostr不为空,表明是验证请求
begin
Result := ‘‘;
if dmwx.CheckSignature(qv.ValueByName[‘id‘],qv.ValueByName[‘signature‘],
qv.ValueByName[‘timestamp‘], qv.ValueByName[‘nonce‘]) then
Result :=qv.ValueByName[‘echostr‘];//如果验证成功,返回echostr,告知微信服务器验证成功.
end;
SetResponseMimeType(‘text/HTML‘);
SetResponsecharset(‘utf-8‘);
finally
FreeAndnil(qv);
end;
exit;//结束本次对Get的响应.
end;
....略去下面的实现
在实际的项目,我是这样实现的,将微信的接口代码,实现在一个单元wechatImpl中,再实现一个DataModule,对wechatImpl的方法进一步封装,封装的时候,来实现对数据库的操作。
还是以验证为例,来看一下DataModule中是如何实现的?
function tdmwx.CheckSignature(id, signature, timestamp, nonce:string): Boolean;
begin
result:=False;
if not qWXFWH.Active then
qWXFWH.Open;
if qWXFWH.Locate(‘fid‘, VarArrayOf([id]), [])then//查询服务号表,是否存在对应的id记录
begin
ifwechatImpl.CheckSignature(signature, timestamp, nonce,qWXFWH.FieldByName(‘FToken‘).AsString)//存在,则取在表中定义的token值,去调用验证函数.
then
Result := true;
end;
end;
其中,qWXFWH是一个kbmMWuniDACQuery对象,用以保存微信服务号的一张表,表结构如下:
CREATE TABLE WX_FWH (
FIDINTEGER,//一个服务号的id,达到管理多个服务号的目的。
FTOKENVarChar(32),//每个服务号的token值
FAPPIDVarChar(16),
FAPPSECRETvarchar(16),
FACCESSTOKENVARCHAR (512),
FEXPIRESININTEGER,
FGETDATEDATETIME);
在注册服务器时,要先在这个表中增加注册信息,比如:id=1,token=kbmmwtoken1
对应的注册内容为:
url=www.test.cc/wechat.html?id=1
token=kbmmwtoken1
这样,当微信服务器发送验证请求时,会把id当作参数一并传递过来,datamodule的CheckSignature方法,会根据id的值,取得数据表中定义token值,然后再调用微信接口的验证方法。
总结一下上面的内容,为了实现微信接入,我将实现的代码分为三层:
1.在kbmmw web server的get方法中调用数据库层的验证函数
2.在数据库层实现验证函数,从取表中取得预先定义的微信号的相关信息,如id,token,再调用具体的微信接口
3.实现具体的微信接口,供数据库层调用。
计划等微信接口的实现全部完成后共享给朋友们,无奈近期时间紧,杂事多,还需要一段时间。就先把实现完成的思路先放上来分享。
对接入web server的url地址验证是做微信服务的第一步,所以,上面相关的内容一定要理解,才可继续进行下去。
实际上是这样:
关注你服务号的微信用户,向你的服务号发送消息,微信平台,会往你验证的url进行转发,这就相当于你微信服务号的微信用户,向你的Webserver发送消息。你开发的Web server的目的,就是响应这些消息,与你的微信服务号关注者进行互动!
tmpStr: string;
begin
strs := TStringList.Create;
try
strs.Add(token);
strs.Add(timestamp);
strs.Add(nonce);
strs.Sort;
tmpStr :=strs[0] + strs[1] + strs[2];
tmpStr :=SHA1(tmpStr);
if tmpStr =signature then
Result := True
else
Result := False;
finally
FreeAndNil(strs);
end;
end;
函数的返回结果为真时,表示接入成功!该函数,参考csdn朋友上传的范例,表示感谢。在这个范例中,提供了SHA1函数的单元,所以,你要下载回来。
准备完这个函数,接下来,如何使用这个函数呢?
因为微信服务器是向接入的web服务器发送Get请求,所以,我们要在自己实现的kbmMW webserver的PerformGet方法中来调用这个CheckSignature。
function TDJ_FrmPhoneHTTPService.PerformGet(ClientIdent:TkbmMWClientIdentity; const AURL: string;
const Args: array of Variant): Variant;
var
FuncName: string;
qv: TkbmMWHttpQueryValues;//处理Get请求传递来的参数.
begin
if Length(Args) < 1 then
kbmMWRaiseException(KBMMW_ERR_SERVICE_HTTP_URLMISSING, ‘MissingURL.‘)
else
begin
FuncName :=UpperCase(copy(Args[0], 2, Length(Args[0]) - 1));
ifFuncName.Equals(‘WECHAT.HTML‘) then
begin
// 转微信接口
qv := TkbmMWHttpQueryValues.Create;
qv.AsString := Args[2];//取得get请求传递来的参数.
try
// 验证接入
if qv.ValueByName[‘echostr‘] <> ‘‘then//如果echostr不为空,表明是验证请求
begin
Result := ‘‘;
if dmwx.CheckSignature(qv.ValueByName[‘id‘],qv.ValueByName[‘signature‘],
qv.ValueByName[‘timestamp‘], qv.ValueByName[‘nonce‘]) then
Result :=qv.ValueByName[‘echostr‘];//如果验证成功,返回echostr,告知微信服务器验证成功.
end;
SetResponseMimeType(‘text/HTML‘);
SetResponsecharset(‘utf-8‘);
finally
FreeAndnil(qv);
end;
exit;//结束本次对Get的响应.
end;
....略去下面的实现
在实际的项目,我是这样实现的,将微信的接口代码,实现在一个单元wechatImpl中,再实现一个DataModule,对wechatImpl的方法进一步封装,封装的时候,来实现对数据库的操作。
还是以验证为例,来看一下DataModule中是如何实现的?
function tdmwx.CheckSignature(id, signature, timestamp, nonce:string): Boolean;
begin
result:=False;
if not qWXFWH.Active then
qWXFWH.Open;
if qWXFWH.Locate(‘fid‘, VarArrayOf([id]), [])then//查询服务号表,是否存在对应的id记录
begin
ifwechatImpl.CheckSignature(signature, timestamp, nonce,qWXFWH.FieldByName(‘FToken‘).AsString)//存在,则取在表中定义的token值,去调用验证函数.
then
Result := true;
end;
end;
其中,qWXFWH是一个kbmMWuniDACQuery对象,用以保存微信服务号的一张表,表结构如下:
CREATE TABLE WX_FWH (
FIDINTEGER,//一个服务号的id,达到管理多个服务号的目的。
FTOKENVarChar(32),//每个服务号的token值
FAPPIDVarChar(16),
FAPPSECRETvarchar(16),
FACCESSTOKENVARCHAR (512),
FEXPIRESININTEGER,
FGETDATEDATETIME);
在注册服务器时,要先在这个表中增加注册信息,比如:id=1,token=kbmmwtoken1
对应的注册内容为:
url=www.test.cc/wechat.html?id=1
token=kbmmwtoken1
这样,当微信服务器发送验证请求时,会把id当作参数一并传递过来,datamodule的CheckSignature方法,会根据id的值,取得数据表中定义token值,然后再调用微信接口的验证方法。
总结一下上面的内容,为了实现微信接入,我将实现的代码分为三层:
1.在kbmmw web server的get方法中调用数据库层的验证函数
2.在数据库层实现验证函数,从取表中取得预先定义的微信号的相关信息,如id,token,再调用具体的微信接口
3.实现具体的微信接口,供数据库层调用。
计划等微信接口的实现全部完成后共享给朋友们,无奈近期时间紧,杂事多,还需要一段时间。就先把实现完成的思路先放上来分享。
对接入web server的url地址验证是做微信服务的第一步,所以,上面相关的内容一定要理解,才可继续进行下去。
实际上是这样:
关注你服务号的微信用户,向你的服务号发送消息,微信平台,会往你验证的url进行转发,这就相当于你微信服务号的微信用户,向你的Webserver发送消息。你开发的Web server的目的,就是响应这些消息,与你的微信服务号关注者进行互动!
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。