Ruby on Rails微信开发4——通过网页授权获取用户的基本信息

分类: 微信公众平台开发 Ruby 260人阅读 评论(0) 收藏 举报

接着Ruby on Rails微信开发3——自定义菜单的创建,假如“代码是小三”按钮对应了一个我的技术博客的网页链接,该链接只能允许特定的用户打开,此时就需要对用户的身份进行验证。

参照开发者文档网页授权获取用户基本信息对用户身份进行验证

1、网页授权回调域名的配置



2、修改按钮链接,对按钮的链接进行修改

  1. def create_menu  
  2.   post_url = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=#{get_access_token}"  
  3.   wechat_button_yml = load_yml_file "wechat_button.yml"  
  4.   post_hash = wechat_button_yml['menu’]  
  5.   #修改按钮链接  
  6.   post_hash["button"][0]["sub_button"][0]["url"]=generate_oauth_path post_hash["button"][0]["sub_button"][0]["url"]  
  7.   Typhoeus::Request.post(post_url, body: generate_post_hash(post_hash))  
  8. end  
  9.   
  10. #为按钮生成oauth链接  
  11. def generate_oauth_path origin_path  
  12.   "https://open.weixin.qq.com/connect/oauth2/authorize?appid=#{get_app_id}&redirect_uri=#{origin_path}&response_type=code&scope=snsapi_base#wechat_redirect"  
  13. end  

因为我在这里只需要获取用户的open_id,scope为snsapi_base,故只需要两步即可:1)、获取code;2)、通过code获取open_id
3、获取code,并且通过code获取open_id

因为按钮对应的链接符合第一步中设置的合法域名,故用户点击按钮后在对应的action中可以获取code参数

  1. def test  
  2.   session[:open_id]=get_open_id(params[:code])  
  3.   respond_to do |format|  
  4.     format.html { render :layout => "wechat" }  
  5.   end  
  6. nd  
  1. #通过code获取open_id  
  2.   def get_open_id code  
  3.     url="https://api.weixin.qq.com/sns/oauth2/access_token?appid=#{get_app_id}&secret=#{get_app_secret}&code=#{code}&grant_type=authorization_code"  
  4.     JSON.parse(URI.parse(url).read)["openid"]  
  5.   end  
成功获取到open id之后,就可以通过比对当前用户的open id与权限表中存储的open id进行比对,判断用户是否有权限访问啦
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值