微信公众平台开发之处理图片.Net代码解析
举个例子,有人对着我们的公共微信号拍个照片发送过来,然后我们处理这个照片,比如进行ocr识别字(随后就会降到这个例子),或者人脸识别,或者拍照取证等,这些功能都是相当有用的。那么我们现在就要分析一下这个过程。微信平台肯定不能帮助我们ocr或者人脸识别等功能,要做这些功能首先到得到图片!用户拍摄的照片首先被上传到了wenxin的服务器,然后就有了一个mediaid,我们用这个mediaid可以下载到我们自己的服务器上然后处理,把结果给微信平台,由微信平台最终反馈给用户(关注者)。微信的开发文档已经给出了下载资源的办法,我改造为.net的,如下:
/// <summary> /// 下载保存多媒体文件,返回多媒体保存路径 /// </summary> /// <param name="access_token"></param> /// <param name="media_id"></param> /// <returns></returns> public string getmultimedia(string access_token, string media_id) { string file = string.empty; string content = string.empty; string strpath = string.empty; string savepath = string.empty; string sturl = "http://file.api.weixin.qq.com/cgi-bin/media/get?access_token=" + access_token + "&media_id=" + media_id; httpwebrequest req = (httpwebrequest)httpwebrequest.create(sturl); req.method = "get"; using (webresponse wr = req.getresponse()) { httpwebresponse myresponse = (httpwebresponse)req.getresponse(); strpath = myresponse.responseuri.tostring(); writelog("接收类别://" + myresponse.contenttype); webclient mywebclient = new webclient(); savepath = server.mappath("image") + "\\" + datetime.now.tostring("yyyymmddhhmmssfff") + (new random()).next().tostring().substring(0, 4) + ".jpg"; writelog("路径://" + savepath); try { mywebclient.downloadfile(strpath, savepath); file = savepath; } catch (exception ex) { savepath = ex.tostring(); } } return file; }
上面的两个参数很好理解,第一就是access_token,之前说过很多了,第二就是在微信服务器上的资源id,即mediaid。如果我们要下载微信服务器上的资源总要知道id吧。但是media_id又是怎么产生的呢?我首先改造一下之前的消息实体类,加入mediaid 属性
class wxmessage { public string fromusername { get; set; } public string tousername { get; set; } public string msgtype { get; set; } public string eventname { get; set; } public string content { get; set; } public string recognition { get; set; } public string mediaid { get; set; } public string eventkey { get; set; } }
然后改造一下getwxmessage(),给mediaid赋值。
private wxmessage getwxmessage() { wxmessage wx = new wxmessage(); streamreader str = new streamreader(request.inputstream, system.text.encoding.utf8); xmldocument xml = new xmldocument(); xml.load(str); wx.tousername = xml.selectsinglenode("xml").selectsinglenode("tousername").innertext; wx.fromusername = xml.selectsinglenode("xml").selectsinglenode("fromusername").innertext; wx.msgtype = xml.selectsinglenode("xml").selectsinglenode("msgtype").innertext; if (wx.msgtype.trim() == "text") { wx.content = xml.selectsinglenode("xml").selectsinglenode("content").innertext; } if (wx.msgtype.trim() == "event") { wx.eventname = xml.selectsinglenode("xml").selectsinglenode("event").innertext; wx.eventkey = xml.selectsinglenode("xml").selectsinglenode("eventkey").innertext; } if (wx.msgtype.trim() == "voice") { wx.recognition = xml.selectsinglenode("xml").selectsinglenode("recognition").innertext; } if (wx.msgtype.trim() == "image") { wx.mediaid = xml.selectsinglenode("xml").selectsinglenode("mediaid").innertext; } return wx; }
如果我们在修改一下消息接受的代码,就可以做到,客户发一个照片给微信平台,程序检测到时图片,然后根据mediaid,调用getmultimedia方法把图片下载到自己的服务器上。后面的工作嘛,你就想干什么干什么了。
刚才的例子好像是用户(关注者),发图片,然后通过微信平台到我们的服务器中,还有一种情况,用户发一个用户名:例如“hemeng”,然后我需要调用已经存在服务器中的hemeng头像的图片反馈给用户,这怎么办呢?如何把我们的图片传给微信平台,然后传给用户呢?我们就用到了上传得方法:
/// <summary> /// 上传多媒体文件,返回 mediaid /// </summary> /// <param name="access_token"></param> /// <param name="type"></param> /// <returns></returns> public string uploadmultimedia(string access_token, string type) { string result = ""; string wxurl = "http://file.api.weixin.qq.com/cgi-bin/media/upload?access_token=" + access_token + "&type=" + type; string filepath = server.mappath("image") + "\\hemeng80.jpg";(本地服务器的地址) writelog("上传路径:" + filepath); webclient mywebclient = new webclient(); mywebclient.credentials = credentialcache.defaultcredentials; try { byte[] responsearray = mywebclient.uploadfile(wxurl, "post", filepath); result = system.text.encoding.default.getstring(responsearray, 0, responsearray.length); writelog("上传result:" + result); uploadmm _mode = jsonhelper.parsefromjson<uploadmm>(result); result = _mode.media_id; } catch (exception ex) { result = "error:" + ex.message; } writelog("上传mediaid:" + result); return result; }
第二个参数如果是图片"image",可以参照微信的文档。函数的返回值就是一个mediaid,这样你就可以利用发送图片的函数,发给客户了,发送图片的函数如下:
protected string sendpictextmessage(msg _mode, string mediaid) { string res = string.format(@"<xml> <tousername><![cdata[{0}]]></tousername> <fromusername><![cdata[{1}]]></fromusername> <createtime>{2}</createtime> <msgtype><![cdata[image]]></msgtype> <image> <mediaid><![cdata[{3}]]></mediaid> </image> </xml> ", _mode.fromusername, _mode.tousername, datetime.now, mediaid); return res; }
其他视频,语音的操作也类似,就不再冗余介绍了。有了这些知识我们是不是能做不少应用了?当然是肯定的,但是我们的代码还不够优化,结构也不合理,不着急,我们会逐渐介绍到的,因为我们还没有完全了解完微信的强大功能。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。