当前位置: 移动技术网 > IT编程>开发语言>.net > 微信公众平台开发之处理图片.Net代码解析

微信公众平台开发之处理图片.Net代码解析

2017年12月12日  | 移动技术网IT编程  | 我要评论
举个例子,有人对着我们的公共微信号拍个照片发送过来,然后我们处理这个照片,比如进行ocr识别字(随后就会降到这个例子),或者人脸识别,或者拍照取证等,这些功能都是相当有用的

举个例子,有人对着我们的公共微信号拍个照片发送过来,然后我们处理这个照片,比如进行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;
  }

其他视频,语音的操作也类似,就不再冗余介绍了。有了这些知识我们是不是能做不少应用了?当然是肯定的,但是我们的代码还不够优化,结构也不合理,不着急,我们会逐渐介绍到的,因为我们还没有完全了解完微信的强大功能。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网